MFC实现多TAB页的切换

风雨无阻

只有一条路不能选择——那就是放弃的路;只有一条路不能拒绝——那就是成长的路。

MFC Tab Control控件的详细使用

 

1. 新建一个MFC工程, 取名MyTab, 选择Dialog based, 然后Finish.
2. 删除对话框上默认添加的三个控件. 添加Tab Control控件并在Property属性中设置ID为IDC_TABTEST 在More Styles里勾上Bottom. 调速尺寸使其布满整个对话框, 我这边Tab Control的尺寸最后为164X203. 在ClassWizard为其添加变量, 变量名为m_tab. 类型为CTabCtrl.
3. 在对话框的初始化函数OnInitDialog里面添加如下代码:
clip_image001m_tab.InsertItem(0,"参数一");  //添加参数一选项卡
clip_image001[1]m_tab.InsertItem(1,"参数二");  //添加参数二选项卡
clip_image001[2]m_tab.InsertItem(2,"结果");    //添加结果选项卡

4.在对话框资源里面添加三个对话框资源, ID分别命名为IDD_PARA1, IDD_PARA2, IDD_RESULT. 字体为宋体, 字号为9, style为Child, Border为None, 宽度调整为161. 再分别为其添加对应的基于CDialog类CPara1, CPara2, CResult.
5. 在CMyTabDlg类中添加三个成员变量m_para1, m_para2, m_result, 分别是三个子对话框的实例. 代码如下:

clip_image001[3]CResult m_result;
clip_image001[4]CPara2 m_para2;
clip_image001[5]CPara1 m_para1;
6. 在IDD_PARA1对话框上添加静态文本控件内容为"参数一" 再在后面插入一个文本框控件, 用ClassWizard将其关联为一个int型变量,名为m_nPara1;
在IDD_PARA2对话框上添加静态文本控件内容为"参数二" 再在后面插入一个文本框控件, 用ClassWizard将其关联为一个int型变量,名为m_nPara2;
在IDD_RESULT对话框上添加静态文本控件内容为"结果" 再在后面插入一个文本框控件, 用ClassWizard将其关联为一个int型变量,名为m_nResult;
7. 为CPara1类添加成员函数int GetParaValue() 代码如下:
clip_image001[6]int CPara1::GetParaValue()
clip_image002clip_image003...{
clip_image004 return m_nPara1;
clip_image005}
为CPara2类添加成员函数int GetParaValue() 代码如下:
clip_image001[7]int CPara2::GetParaValue()
clip_image002[1]clip_image003[1]...{
clip_image004[1] return m_nPara2;
clip_image005[1]}
为CResult类添加成员函数void SetResultValue(int nResult) 代码如下:
clip_image001[8]void CResult::SetResultValue(int nResult)
clip_image002[2]clip_image003[2]...{
clip_image004[2]     m_nResult = nResult;
clip_image005[2]}
8. 在IDD_MYTAB_DIALOG对话框的初始化函数OnInitDialog里面添加如下代码:
clip_image001[9]//关联对话框,并且将IDC_TABTEST控件设为父窗口
clip_image001[10]m_para1.Create(IDD_PARA1,GetDlgItem(IDC_TABTEST));
clip_image001[11]m_para2.Create(IDD_PARA2,GetDlgItem(IDC_TABTEST));
clip_image001[12]m_result.Create(IDD_RESULT,GetDlgItem(IDC_TABTEST));
clip_image001[13]
clip_image001[14]//获得IDC_TABTEST客户区大小
clip_image001[15]CRect rs;
clip_image001[16]m_tab.GetClientRect(&rs);
clip_image001[17]//调整子对话框在父窗口中的位置
clip_image001[18]rs.top+=1;
clip_image001[19]rs.bottom-=60;
clip_image001[20]rs.left+=1;
clip_image001[21]rs.right-=2;
clip_image001[22]
clip_image001[23]//设置子对话框尺寸并移动到指定位置
clip_image001[24]m_para1.MoveWindow(&rs);
clip_image001[25]m_para2.MoveWindow(&rs);
clip_image001[26]m_result.MoveWindow(&rs);
clip_image001[27]
clip_image001[28]//分别设置隐藏和显示
clip_image001[29]m_para1.ShowWindow(true);
clip_image001[30]m_para2.ShowWindow(false);
clip_image001[31]m_result.ShowWindow(false);
clip_image001[32]
clip_image001[33]//设置默认的选项卡
clip_image001[34]m_tab.SetCurSel(0);

9. 添加Tab Control控件的TCN_SELCHANGE事件响应函数OnSelchangeTabtest(NMHDR* pNMHDR, LRESULT* pResult) ,函数体代码如下:

clip_image001[35]int CurSel = m_tab.GetCurSel();
clip_image001[36] switch(CurSel)
clip_image002[3]clip_image003[3] ...{
clip_image004[3] case 0:
clip_image004[4]         m_para1.ShowWindow(true);
clip_image004[5]         m_para2.ShowWindow(false);
clip_image004[6]         m_result.ShowWindow(false);
clip_image004[7] break;
clip_image004[8] case 1:
clip_image004[9]         m_para1.ShowWindow(false);
clip_image004[10]         m_para2.ShowWindow(true);
clip_image004[11]         m_result.ShowWindow(false);
clip_image004[12] break;
clip_image004[13] case 2:
clip_image004[14]         m_para1.ShowWindow(false);
clip_image004[15]         m_para2.ShowWindow(false);
clip_image004[16]         m_result.ShowWindow(true);
clip_image004[17] break;
clip_image004[18] default:
clip_image004[19]         ;
clip_image005[3]     }    
clip_image001[37]
clip_image001[38]    *pResult = 0;

10. 在IDD_MYTAB_DIALOG对话框下面添加一个按钮, 标题为"计算" 为其添加事件响应函数, 代码如下:

clip_image001[39]m_para1.UpdateData(true);
clip_image001[40]     m_para2.UpdateData(true);
clip_image001[41]     m_result.SetResultValue(m_para1.GetParaValue()+m_para2.GetParaValue());
clip_image001[42]     m_result.UpdateData(false);   

11. 最后演示结果如下:

clip_image007

clip_image009

clip_image010

12. 这个小程序很简单,但是他说明了Tab Control控件的基本用法.

用法2

VC中的CTabCtrl用法与VB、Delphi的选项卡控件有很大的不同,每个属性页是用一个“窗体”(对话框)来实现,于是要为每个属性页对话框建类,还要关联、初始化„„实在麻烦得多。但是CTabCtrl可重用性比ActiveX的选项卡控件好,因为一个属性页可以被多个不同的选项卡对话框调用,就像MFC中很多属性选项卡有“General”这一选项页,可以被多个控件的属性页调用,作为“通用”的,有符合现代软件工程可重用性要求。

下面发一个最简单的代码,使用CTabCtrl控件实现属性页功能。

1、建立一个基于对话框的应用程序;

2、画CTabCtrl控件,类向导中关联变量名为m_tab,新建三个对话框属性设为Child,None,用ClassWizard生成新的类,基类为Cdialog,分别为Cpage0,Cpage1,Cpage2,ID号分别为IDD_DIALOG0,IDD_DIALOG1,IDD_DIALOG2。在主对话框中加入三个变量,Cpage0 page0;Cpage1 page1;Cpage2 page2。别忘了在主对话框的头文件中要加入#include "Page0.h",#include "Page1.h",#include "Page2.h"

3、在主对话框的OnInitDialog()内初始化 :

// TODO: Add extra initialization here

//初始化m_tab控件

m_tab.InsertItem(0," 呵呵,茂叶工作室 ");

m_tab.InsertItem(1," 嘻嘻 ");

m_tab.InsertItem(2," 哈哈,www.maoyeah.com ");

//建立属性页各页

page0.Create(IDD_DIALOG0,GetDlgItem(IDC_TAB1));

page1.Create(IDD_DIALOG1,GetDlgItem(IDC_TAB1));

page2.Create(IDD_DIALOG2,GetDlgItem(IDC_TAB1));

//设置页面的位置在m_tab控件范围内

CRect rect;

m_tab.GetClientRect(&rect);

rect.top+=20;

rect.bottom-=5;

rect.left+=5;

rect.right-=5;

page0.MoveWindow(&rect);

page1.MoveWindow(&rect);

page2.MoveWindow(&rect);

page1.ShowWindow(TRUE);

m_tab.SetCurSel(1);

4、m_tab控件属性页选择时显示各页:

void CMy3Dlg::OnSelchangeTab1(NMHDR* pNMHDR, LRESULT* pResult)

{

// TODO: Add your control notification handler code here

int CurSel;

CurSel=m_tab.GetCurSel();

switch(CurSel)

{

case 0:

page0.ShowWindow(TRUE);

page1.ShowWindow(FALSE);

page2.ShowWindow(FALSE);

break;

case 1:

page0.ShowWindow(FALSE);

page1.ShowWindow(TRUE);

page2.ShowWindow(FALSE);

break;

case 2:

page0.ShowWindow(FALSE);

page1.ShowWindow(FALSE);

page2.ShowWindow(TRUE);

break;

default: ;

}

*pResult = 0;

}

 

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
你可以通过使用MFC框架中的文档视图模型(Document-View)来实现MFC单文档应用程序中的多界面切换。下面是一种常见的实现方法: 1. 首先,在你的MFC应用程序中创建多个对话框资源,每个对话框资源代表一个界面。 2. 在你的文档类(CMyDoc)中添加一个成员变量,用于保存当前显示的对话框的指针。 ```cpp CDialog* m_pCurrentDialog; ``` 3. 在你的文档类的构造函数中,初始化该成员变量为NULL。 ```cpp m_pCurrentDialog = NULL; ``` 4. 在你的文档类的OnNewDocument函数中,创建初始对话框并显示。 ```cpp BOOL CMyDoc::OnNewDocument() { if (!CDocument::OnNewDocument()) return FALSE; // 创建初始对话框 CMyDialog* pDialog = new CMyDialog; // 设置当前对话框指针 m_pCurrentDialog = pDialog; // 创建对话框窗口 pDialog->Create(IDD_MY_DIALOG, AfxGetMainWnd()); // 显示对话框 pDialog->ShowWindow(SW_SHOW); return TRUE; } ``` 5. 在你的文档类中添加一个函数,用于切换界面。在该函数中,先隐藏当前对话框,然后根据需要创建并显示新的对话框。 ```cpp void CMyDoc::SwitchDialog(int nDialogID) { // 隐藏当前对话框 m_pCurrentDialog->ShowWindow(SW_HIDE); // 销毁当前对话框 m_pCurrentDialog->DestroyWindow(); delete m_pCurrentDialog; // 根据需要创建新的对话框 if (nDialogID == IDD_DIALOG1) { m_pCurrentDialog = new CDialog1; } else if (nDialogID == IDD_DIALOG2) { m_pCurrentDialog = new CDialog2; } // 可以根据需要添加更多的对话框 // 创建对话框窗口 m_pCurrentDialog->Create(nDialogID, AfxGetMainWnd()); // 显示对话框 m_pCurrentDialog->ShowWindow(SW_SHOW); } ``` 6. 在你的视图类(CMyView)中添加一个成员变量,用于保存文档指针。 ```cpp CMyDoc* m_pDoc; ``` 7. 在你的视图类的构造函数中,将文档指针赋值给成员变量。 ```cpp CMyView::CMyView() { m_pDoc = GetDocument(); } ``` 8. 在你的视图类中添加一个消息处理函数,用于响应界面切换的消息。 ```cpp void CMyView::OnSwitchDialog() { // 调用文档类的切换界面函数 m_pDoc->SwitchDialog(IDD_NEW_DIALOG); } ``` 9. 在你的菜单资源中添加一个菜单项,并将它与界面切换的消息关联起来。 ```cpp ON_COMMAND(ID_SWITCH_DIALOG, &CMyView::OnSwitchDialog) ``` 这样,当你点击菜单项时,就会调用文档类的切换界面函数,实现多界面切换效果。你可以根据需要在文档类中添加更多的界面切换函数,并在视图类中添加相应的消息处理函数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值