• <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
            <2007年9月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456

            潛心看書研究!

            常用鏈接

            留言簿(19)

            隨筆分類(81)

            文章分類(89)

            相冊

            ACM OJ

            My friends

            搜索

            •  

            積分與排名

            • 積分 - 219046
            • 排名 - 118

            最新評論

            閱讀排行榜

            評論排行榜

            轉自: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 閱讀(3441) 評論(0)  編輯 收藏 引用 所屬分類: MFC
            77777亚洲午夜久久多喷| 99久久婷婷国产一区二区| 午夜视频久久久久一区 | 国产一区二区精品久久岳| 无码人妻少妇久久中文字幕 | 国产精品成人久久久| 日本精品一区二区久久久| 久久中文字幕无码专区| 国产巨作麻豆欧美亚洲综合久久| 亚洲性久久久影院| 久久精品国产精品青草| 2021国内久久精品| 国产精品久久久久天天影视| 久久国产亚洲精品| 久久精品无码一区二区三区免费| 亚洲午夜久久久影院| 国产免费福利体检区久久| 久久青青草原亚洲av无码app| 手机看片久久高清国产日韩| 四虎国产精品免费久久5151 | 亚洲欧美伊人久久综合一区二区| 国产福利电影一区二区三区久久久久成人精品综合 | 久久久久久伊人高潮影院| 狠狠精品久久久无码中文字幕| 伊人久久大香线焦AV综合影院| 久久精品成人免费国产片小草| 91精品国产9l久久久久| 久久国产色AV免费看| 亚洲精品国产字幕久久不卡| 亚洲精品无码久久一线| 一本色综合网久久| 亚洲精品无码久久久久sm| 777午夜精品久久av蜜臀| 亚洲乱码精品久久久久..| 亚洲AV无码久久精品蜜桃| 精品国产乱码久久久久软件| 18岁日韩内射颜射午夜久久成人| 久久精品国产久精国产一老狼| 久久久久久久久66精品片| 午夜精品久久久久久久久| 综合久久国产九一剧情麻豆|