MFC View 分栏显示

2019-08-31 14:41

我们有时候想在单文档的界面上面实现多视图,实现的方法就是对原文档的界面进行分割,以N行M列的形式分割,当然分割也可以递归进行,分割完一次以后,我们还可以在已经分割的其中一个试图上再次分割。

下面举个例子,把一个单文档界面切分成4块。效果如下图所示。

分割的步骤就是先分成1行2列,然后再把分好的第二列分成3行一列(注意的是这里的行列标号都是从0开始的,我们说的第二列其实是1列,前面的是0列) 下面看实现的方法。

1 首先我们建立4个对话框,ID分别为IDD_TREE1 IDD_LIST1 IDD_TREE2 IDD_LIST2 注意对话框的style要选child。

2 建立4个View的类,这里我们让这四个View的类继承于FormView,(这样,可以在上面添加控件)。

CList1View 继承于FormView 关联对话框 IDD_LIST1

CList2View 继承于FormView 关联对话框IDD_LIST2 CTree1View 继承于FormView 关联对话框IDD_TREE1 CTree2View 继承于FormView 关联对话框IDD_TREE2

3 在CMainFrame类中添加两个变量,类型为 CSplitterWnd(关于这类型的介绍请看MSDN)

CSplitterWnd m_wndSplitter; CSplitterWnd m_wndSplitter1; 然后在CMainFrame类中添加虚函数:

virtual BOOL OnCreateClient(LPCREATESTRUCT lpcs, CCreateContext* pContext); 在源文件函数实现添加如下代码:

BOOL CMainFrame::OnCreateClient(LPCREATESTRUCT lpcs, CCreateContext* pContext) {

// TODO: Add your specialized code here and/or call the base class CRect cr;

GetWindowRect( &cr );

//创建一个静态分栏窗口,分为一行二列 if(m_wndSplitter.CreateStatic(this,1,2)==NULL)

return FALSE;

//将TreeView1连接到0行0列窗格上

m_wndSplitter.CreateView(0,0,RUNTIME_CLASS(CTree1View),CSize(cr.Width()/4, cr.Height()), pContext);

if(m_wndSplitter1.CreateStatic(&m_wndSplitter,3,1,WS_CHILD|WS_VISIBLE, m_wndSplitter.IdFromRowCol(0, 1))==NULL)

return FALSE; //将第0行1列再分开3行1列 //将ListView1类连接到第二个分栏对象的0行0列

m_wndSplitter1.CreateView(0,0,RUNTIME_CLASS(CList1View),CSize(3*cr.Width()/4,cr.Height()/3),pContext);

//将TreeView2类连接到第二个分栏对象的1行0列

m_wndSplitter1.CreateView(1,0,RUNTIME_CLASS(CTree2View),CSize(3*cr.Width()/4,cr.Height()/3),pContext);

//将ListView2类连接到第二个分栏对象的2行0列

m_wndSplitter1.CreateView(2,0,RUNTIME_CLASS(CList2View),CSize(3*cr.Width()/4,cr.Height()/3),pContext);

return TRUE;

// return CFrameWnd::OnCreateClient(lpcs, pContext); }

并注意在次源文件头添加include文件: #include \ #include \ #include \ #include \

然后运行程序,窗口就会实现分割。


MFC View 分栏显示.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:如何评价 Swift 语言(知乎)

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: