【轉載】MFC中tabcontrol控件的使用

原博地址:https://www.cnblogs.com/lzmfywz/archive/2012/04/07/2436571.html#undefinedhtml

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裏面添加以下代碼: 
m_tab.InsertItem(0,"參數一");  //添加參數一選項卡 
m_tab.InsertItem(1,"參數二");  //添加參數二選項卡 
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, 分別是三個子對話框的實例. 代碼以下:

CResult m_result; 
CPara2 m_para2; 
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裏面添加以下代碼: //關聯對話框,而且將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) ,函數體代碼以下: 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; }
相關文章
相關標籤/搜索