• <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>
            隨筆 - 87  文章 - 279  trackbacks - 0
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            潛心看書研究!

            常用鏈接

            留言簿(19)

            隨筆分類(81)

            文章分類(89)

            相冊

            ACM OJ

            My friends

            搜索

            •  

            積分與排名

            • 積分 - 216558
            • 排名 - 117

            最新評論

            閱讀排行榜

            評論排行榜

            轉自:http://hi.baidu.com/blue_never_died/blog/item/04398694249ef71ed21b7007.html

            說實話,我剛開始看見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 2007-09-25 23:37 閱讀(3410) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            精品水蜜桃久久久久久久| 狠色狠色狠狠色综合久久| 91精品国产91久久久久久| 91精品国产91热久久久久福利| 色综合久久中文色婷婷| 精品视频久久久久| 午夜精品久久久久久毛片| 久久精品视频免费| 久久久久久综合网天天| 天堂久久天堂AV色综合| 久久国产精品偷99| 97精品国产91久久久久久| 久久综合给合综合久久| 99久久99久久久精品齐齐| 思思久久99热免费精品6| 国产美女久久久| 一本一本久久aa综合精品| 久久精品一区二区影院 | 四虎国产永久免费久久| 久久天天躁狠狠躁夜夜不卡| 老司机国内精品久久久久| 亚洲va久久久噜噜噜久久天堂| 婷婷久久综合| 精品水蜜桃久久久久久久| 99久久精品国产毛片| 久久这里只有精品首页| 精品久久久久久无码专区不卡| 久久久久99这里有精品10| 久久综合鬼色88久久精品综合自在自线噜噜| 久久只这里是精品66| 午夜精品久久久内射近拍高清| 久久精品国内一区二区三区| 久久亚洲精品国产精品| 久久综合九色综合欧美就去吻| 国产午夜免费高清久久影院| 久久免费高清视频| 夜夜亚洲天天久久| 久久久久人妻一区精品| 国产亚洲欧美成人久久片| 久久久精品国产亚洲成人满18免费网站| 欧美一级久久久久久久大片|