• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            幽幽
             
            posts - 51,  comments - 28,  trackbacks - 0

            說實話,我剛開始看見Tab Control的時候,覺得很簡單。哪知道用了一下,才發現自己錯了。

            要用好它,還是需要一些技巧的。經過網上搜索資料,以及我自己的摸索,把一些要點記錄在這里。

            Tab Control的運行效果有點像Property Sheet,但兩者還是有一些區別。我的理解就是Property Sheet主要用在對話框中,對數據進行進行分類管理。而Tab Control使用范圍更廣一些,既可以用在對話框,也可以用在視圖中,除了可以管理配置數據外,還可以對軟件的組織進行規劃,比如可以通過它來切換不同的視圖等等。

            當然這不是沒有代價的,Tab Control的編程就比Property Sheet的復雜很多。

             我最初有點搞不懂,如何在Tab Control中使用不同的Page,就象Property Page一樣,Tab Control并沒有提供便利的機制讓你輕松做到這一點。還好,VC是最棒的,撒花~通過變通的方法還是可以做到這一點。

            不羅嗦了,上代碼。

            假如我現在有個SDI程序,View是Form View,想在上面放個Tab Control,包含兩個Page。現在讓我們來看看應該怎樣處理。

            首先當然要增加一個Tab Control資源,然后利用Class Wizard,在View中增加一個Control變量。

            接著建立兩個對話框資源,別忘了把Style改為Child,Border改為None。然后就可以在上面加其他控件了。

            接著利用Class Wizard,分別為這兩個對話框建立兩個類,比如CPage1和CPage2。

            然后在View類頭文件中,加入這兩個對話框對象。同時增加一個變量int m_CurSelTab,用了表明是哪個Page即將被切換。

            為了避免用戶在切換Tab時,程序對Tab Index的枚舉,可以利用數組來做這個事情。

            在View的初始化函數中需要把CPage1、CPage2和Tab Control關聯起來,并保存頁面地址,設置初始頁面,等等。

            void CTab_testView::OnInitialUpdate()
            {
               CFormView::OnInitialUpdate();
               GetParentFrame()->RecalcLayout();
               ResizeParentToFit();
                 
                //為Tab Control增加兩個頁面
                m_tab.InsertItem(0, _T("First"));
                m_tab.InsertItem(1, _T("Second"));
                
                //創建兩個對話框
                m_page1.Create(IDD_DIALOG1, &m_tab);
                m_page2.Create(IDD_DIALOG2, &m_tab);

                //設定在Tab內顯示的范圍
                CRect rc;
                m_tab.GetClientRect(rc);
                rc.top += 20;
                rc.bottom -= 8;
                rc.left += 8;
                rc.right -= 8;

                m_page1.MoveWindow(&rc);
                m_page2.MoveWindow(&rc);

                //把對話框對象指針保存起來
                pDialog[0] = &m_page1;
                pDialog[1] = &m_page2;

                //顯示初始頁面
                pDialog[0]->ShowWindow(SW_SHOW);
                pDialog[1]->ShowWindow(SW_HIDE);

                //保存當前選擇
                m_CurSelTab = 0;
            }

            這里面需要注意的是,我用了一個CDialog指針數組來進行保存,數組的大小是Tab Control頁面的個數,數組下標對應著每個頁面的索引(這樣方便快速存取)。

            用戶切換時,需要響應相關的消息。

            void CTab_testView::OnSelchangeTab1(NMHDR* pNMHDR, LRESULT* pResult) 
            {
             // TODO: Add your control notification handler code here
                
                pDialog[m_CurSelTab]->ShowWindow(SW_HIDE);
                m_CurSelTab = m_tab.GetCurSel();
                pDialog[m_CurSelTab]->ShowWindow(SW_SHOW);

             *pResult = 0;
            }

            首先我們先把當前的頁面隱藏起來,然后得到新的頁面索引,最后就把相關頁面顯示出來即可。這比一個個去枚舉簡單多了。

            還有一點比較有意思,那就是DDX/DDV機制的運用。要想獲得Tab Control各個頁面的數據,可以利用DDX/DDV機制,但需要注意,因為這是多個頁面,所以需要顯式調用多次。

            void CTab_testView::OnButton1() 
            {
             // TODO: Add your control notification handler code here
                m_page1.UpdateData();
                m_page2.UpdateData();
                CString str1 = m_page1.m_str1;
                CString str2 = m_page2.m_str2;
                AfxMessageBox(str1);
                AfxMessageBox(str2);
            }

            經過這幾步處理,基本上我們就可以利用Tab Control的強大功能了。

            posted on 2008-05-19 02:18 幽幽 閱讀(1680) 評論(0)  編輯 收藏 引用

            <2010年9月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            常用鏈接

            留言簿(6)

            隨筆分類(35)

            隨筆檔案(51)

            文章分類(3)

            文章檔案(3)

            相冊

            我的鏈接

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久免费99精品国产自在现线| 久久综合色老色| 国产精品久久影院| 狠狠色综合网站久久久久久久| 久久久久亚洲精品中文字幕| 一本色道久久88精品综合| 久久综合精品国产二区无码| 狠狠干狠狠久久| 亚洲精品无码久久久| 69SEX久久精品国产麻豆| 久久99精品久久久久久9蜜桃| 女人高潮久久久叫人喷水| 久久成人国产精品| 久久精品这里只有精99品| 天堂久久天堂AV色综合| 久久久久人妻精品一区三寸蜜桃| 狠狠色综合网站久久久久久久高清 | 婷婷久久五月天| 国产精品对白刺激久久久| 久久精品成人| 亚洲国产精品久久66| 久久精品午夜一区二区福利| 久久久久国产精品嫩草影院| 狠狠色婷婷综合天天久久丁香 | 久久亚洲精品成人av无码网站| 国内精品久久久久久久久| av无码久久久久不卡免费网站| 色8激情欧美成人久久综合电| 久久精品男人影院| 国产精品一久久香蕉国产线看观看| 日韩亚洲国产综合久久久| 亚洲午夜久久影院| 青青热久久综合网伊人| 丁香五月网久久综合| 丰满少妇人妻久久久久久| 亚洲乱码中文字幕久久孕妇黑人| 亚洲国产精品无码久久久久久曰| 国产成人AV综合久久| 91精品国产91久久久久久| 大香网伊人久久综合网2020| 青青青青久久精品国产h|