Windows標準控件:
windows標準控件由Windows 操作系統提供,在Windows 95中還提供了一些新增的控件。所有這些控件對象都是可編程的,我們可以使用Visual C++提供的對話框編輯器把它們添加到對話框中。Microsoft基礎類庫(MFC)提供了封裝這些控件的類,它們列于表6.1。
在MFC 中,類CWnd是所有窗口類的基類,很自然的,它也是所控件類的基類。
Windows標準控件在以下環境下提供:
windows 95
Windows NT 3.51及以后版本
win32s 1.3
注意:visual C++4.2及以后版本不再支持Win32s.
VC++控件工具箱:
用來接收用戶的命令,應用程序在接收到用戶命令后,通常需要進行一些后臺工作。按鈕可以響應單擊或雙擊動作,在按鈕接收到鼠標動作后,向其父窗口發送相應的控件通知,用戶可以對這些控件通知進行消息映射,從而進行相應的處理。
在一個對話框中,可以定義一個默認按鈕,這只要選中按鈕屬性中的“Default”選項。如果在對話框活動的時候按下了Enter鍵,則等同于單擊了默認按鈕。MFC提供了CButton類支持按鈕控件。
用來顯示某種可能的選擇,該項選擇是獨立的,用戶可以選中或取消該選項。在選項被選中的時候核選標記出現,選項被取消時核選標記消失。MFC中由CButton類對核選框進行支持,用戶可以通過SetCheck()函數和GetCheck()函數設置或獲取核選框當前的狀態。
BST_UNCHECKED==((CButton*)GetDlgItem(IDC_CHECK_RES1))->GetCheck()
((CButton*)GetDlgItem(IDC_CHECK_RES1))->SetCheck(true);
用來接收用戶輸入的字符串。通過選擇編輯框的選項,編輯框可以接收字符串、數字、密碼等;編輯框還可以設置成接收多行字符串的模式;可以自動進行大小寫轉換。編輯框可能向父窗口發送多種控件通知,如果用戶需要,可以對這些控件通知進行處理。MFC提供了CEdit類支持編輯框控件。
GetDlgItem(IDC_***)->SetWindowText(Cstring);
GetDlgItem(IDC_***)->GetWindowText(Cstring);
列表框和編輯框的組合,用戶除了可以在列表中對已經存在的選項進行選擇外,還可以輸入新的選擇。MFC提供了CComboBox類對組合框控件進行支持。
CComboBox * AAA = (CComboBox*)(GetDlgItem(IDC_***));
AAA->AddString(_T("***"));
AAA->SelectString(0, _T("***"));
AAA->SetCurSel(0);
int nSel = AAA->GetCurSel();
AAA->GetLBText(nSel, Cstring);
if(strType.Trim() == _T("***"))
用來選擇一系列的可能選擇,用戶通過滾動條可以在這些選擇中瀏覽。在列表框中,可以進行單項選擇,也可以進行多項選擇,這取決于用戶在控件屬性對話框中的設置。MFC提供了CListBox類對列表框控件進行支持。
用來包圍具有邏輯關系的一組控件,在這些控件的周圍加上邊界和標題。需注意的是,組成框僅僅是在視覺效果上對控件進行“成組”,真正的“成組”工作還需要另外一些工作。僅僅在視覺上展現出一組的邏輯關系,并不添加任何代碼
用來選擇某種可能的選擇,與 (Check Box)復選框不同,該選項不是獨立的。
一般是幾個單選按鈕組成一組,同組中的單選按鈕僅有一個按鈕被選中。
MFC同樣使用CButton類對單選按鈕控件進行支持,
SetCheck()函數和GetCheck()函數對單選按鈕也是適用的。
用來在指定的位置顯示特定的字符串,一般用來標識附近另一個控件的內容。顯示在靜態文本控件中的字符串一般不再改變,但是在需要的時候,必須為其指定一個不同食物ID號,通過調用相應的函數來進行設置。MFC提供了CStatic類支持靜態控件。
顯示位圖(Bitmap)和圖標(Icon),圖形繪制與顯示,主要是其方形的區域適合顯示,同樣方形區域也可利用(Static Text)靜態文本框。
這包括水平滾動條和垂直滾動條,除了在視覺效果上的方向不同外,水平滾動條在被滾動時發生WM_HSCROLL消息,而垂直滾動條在被滾動時發送WM_VSCROLL消息。MFC提供了CScrollBar進行支持。
通常用來在程序中接受一系列離散的數值。
用戶可以設置滑塊控件的取值范圍,并可以為控件加上刻度標記以顯示特定位置的含義。
MFC提供了CSliderCtrl類進行支持。
包括一對緊靠在一起的上下箭頭,使用微調按鈕可以增大或者縮小某個特定的數值。
微調按鈕往往都需要一個“伙伴”控件,這通常都是一個編輯框。
當微調按鈕的向上箭頭被單擊時,編輯框中的數字就增大;反之則減小。MFC提供了CPinButtonCtrl類進行支持。
在進行一項需要較長時間的操作時來反應當前的進度。
當操作的進度不斷前進時,進度條就用特色顏色填充進度條框。用戶可以設定進度條的范圍和當前位置。
MFC提供了CProgressCtrl類進行支持。
CProgressCtrl* progressbar = (CProgressCtrl*)GetDlgItem(IDC_PROGRESS_1);
progressbar->SetRange(0, 4);
progressbar->SetPos(0);
熱鍵控件看起來就像一個編輯框,但是在熱鍵控件中能夠立刻反應用戶剛剛按下的鍵組合,這在設置程序的熱鍵時特別有用。
熱鍵控件只是在“視覺”上顯示了按鍵組合,設置熱鍵的工作還需要用戶添加代碼完成。
MFC提供了CHotKey類進行支持。
按一定的排列順序顯示一系列帶圖標的字符串。
列表控件提供了四種顯示模式:大圖標(Icon)、小圖標(Small Icon)、列表(List)和報表(Report)。
用戶可以向列表控件中添加新的項,也可以控制列表控件的顯示模式。
MFC提供了CListCtrl類進行支持。
初始化:
struct INFO { int id; CString time; CString type; }info; CString id; int nRow=0; id.Format(_T("%d"), info.id); m_ListCtrl.InsertItem(nRow,id); m_ListCtrl.SetItemText(nRow, 1, info.time); m_ListCtrl.SetItemText(nRow, 2, info.type); nRow ++;
添加記錄:
struct INFO
{
int id;
CString time;
CString type;
}info;
CString id;
int nRow=0;
id.Format(_T("%d"), info.id);
m_ListCtrl.InsertItem(nRow,id);
m_ListCtrl.SetItemText(nRow, 1, info.time);
m_ListCtrl.SetItemText(nRow, 2, info.type);
nRow ++;
顯示一系列項目的層次關系,最典型的例子是顯示磁盤上的文件與文件夾。
如果有子項目的話,單擊樹形控件中的項目可以展開或者收縮其子項目。
MFC提供了CTreeCtrl類進行支持。
初始化
void CConfigDlg::OnSize(UINT nType, int cx, int cy) { CDialog::OnSize(nType, cx, cy); // TODO: 在此處添加消息處理程序代碼 CRect rcWnd; GetClientRect(&rcWnd); CRect rcChild = rcWnd; rcChild.top = rcWnd.top+10; rcChild.bottom -=10; rcChild.left += 160; rcChild.right -= 10; CRect laneRect = rcChild; if(::IsWindow(m_1Dlg)) m_1Dlg.MoveWindow(rcChild); if(::IsWindow(m_2Dlg)) m_2Dlg.MoveWindow(rcChild); if ( ::IsWindow( pTree.GetSafeHwnd() ) ) { pTree.MoveWindow(rcWnd.left+10,rcWnd.top+30,130,350,1); } }
樹節點切換
void CConfigDlg::OnTvnSelchangedTree(NMHDR *pNMHDR, LRESULT *pResult) { LPNMTREEVIEW pNMTreeView = reinterpret_cast<LPNMTREEVIEW>(pNMHDR); // TODO: 在此添加控件通知處理程序代碼 HTREEITEM hSelected=pNMTreeView->itemNew.hItem; if(hSelected!=NULL) { pTree.SelectItem(hSelected); int nDat = pTree.GetItemData(hSelected); switch(nDat) { case 1: /*MessageBox(_T("YNAME"));*/ if(m_pPreWnd) m_pPreWnd->ShowWindow(SW_HIDE); m_1Dlg.ShowWindow(SW_SHOW); m_pPreWnd = &m_1Dlg; break; case 3: /*MessageBox(_T("XNAME"));*/ if(m_pPreWnd) m_pPreWnd->ShowWindow(SW_HIDE); m_2Dlg.ShowWindow(SW_SHOW); m_pPreWnd = &m_2Dlg; break; default: break; } } *pResult = 0; }
改變位置
void CConfigDlg::OnSize(UINT nType, int cx, int cy) { CDialog::OnSize(nType, cx, cy); // TODO: 在此處添加消息處理程序代碼 CRect rcWnd; GetClientRect(&rcWnd); CRect rcChild = rcWnd; rcChild.top = rcWnd.top+10; rcChild.bottom -=10; rcChild.left += 160; rcChild.right -= 10; CRect laneRect = rcChild; if(::IsWindow(m_1Dlg)) m_1Dlg.MoveWindow(rcChild); if(::IsWindow(m_2Dlg)) m_2Dlg.MoveWindow(rcChild); if ( ::IsWindow( pTree.GetSafeHwnd() ) ) { pTree.MoveWindow(rcWnd.left+10,rcWnd.top+30,130,350,1); } }
包含大量的控件,可以滿足用戶顯示或者獲取大量數據分類顯示的要求,典型例子是Windows任務欄每個程序標簽。
每個屬性表又分為好幾個屬性頁,這些屬性頁由各自的標簽進行區分,這些屬性頁中都可以包容其他控件。
在顯示屬性表的時候,一次只能夠顯示一個屬性頁的全部內容,同時顯示其他屬性頁的標簽,用戶通過單擊標簽打開相應的屬性頁。
MFC提供了CTabCtrl類進行支持。
初始化綁定變量
m_tab_Light.DeleteAllItems();
m_LightParkingDlg.DestroyWindow();
m_LightStatusDlg.DestroyWindow();
m_tab_Light.InsertItem(0, _T("0001")); // 插入第一個標簽
m_tab_Light.InsertItem(1, _T("0002")); // 插入第二個標簽
CRect tabRect; // 標簽控件客戶區的位置和大小
m_tab_Light.GetClientRect(&tabRect); // 獲取標簽控件客戶區Rect
// 調整tabRect,使其覆蓋范圍適合放置標簽頁
tabRect.left += 2;
tabRect.right -= 1;
tabRect.top += 21;
tabRect.bottom -= 2;
m_LightParkingDlg.Create(IDD_DIALOG_LIGHT_PARKING, &m_tab_Light); // 創建第一個標簽頁
m_LightStatusDlg.Create(IDD_DIALOG_LIGHT_STATUS, &m_tab_Light); // 創建第二個標簽頁
//m_LightParkingDlg.InitData();
m_LightParkingDlg.SetWindowPos(NULL, tabRect.left, tabRect.top, tabRect.Width(), tabRect.Height(),SWP_SHOWWINDOW);
控件頁面切換
CRect tabRect; // 標簽控件客戶區的位置和大小
m_tab_Light.GetClientRect(&tabRect); // 獲取標簽控件客戶區Rect
// 調整tabRect,使其覆蓋范圍適合放置標簽頁
tabRect.left += 2;
tabRect.right -= 1;
tabRect.top += 21;
tabRect.bottom -= 2;
switch (m_tab_Light.GetCurSel())
{
case 0:
m_LightStatusDlg.SetWindowPos(NULL, tabRect.left, tabRect.top, tabRect.Width(), tabRect.Height(), SWP_HIDEWINDOW);
m_LightParkingDlg.SetWindowPos(NULL, tabRect.left, tabRect.top, tabRect.Width(), tabRect.Height(), SWP_SHOWWINDOW);
break;
case 1:
m_LightParkingDlg.SetWindowPos(NULL, tabRect.left, tabRect.top, tabRect.Width(), tabRect.Height(), SWP_HIDEWINDOW);
m_LightStatusDlg.SetWindowPos(NULL, tabRect.left, tabRect.top, tabRect.Width(), tabRect.Height(), SWP_SHOWWINDOW);
break;
}
用來播放一段AVI格式的視頻剪輯。用戶可以控制視頻剪輯的播放、停止和定位,但也僅限于這些功能。動畫控件設置不能播放音頻剪輯,如果用戶需要更高層次的視頻或者音頻的支持,請選用MCIWnd控件。
MFC提供了CAnimateCtrl類對動畫控件進行支持。
編輯控件(Edit Control)功能的擴展。在高級編輯框中,除了簡單的輸入和編輯字符串外,用戶還可以為字符或段落指定特定的格式,用戶甚至還可以向高級編輯框中插入OLE項。
高級編輯框基本上實現了一個帶格式的文本編輯器功能,而只需要用戶添加少量的接口。
MFC提供了CRichEditCtrl類進行支持。
向用戶提供了一種直觀的選擇日期和時間的方法、日期/時間選擇器在外觀上類似于一個組合框,但是當用戶單擊下拉箭頭時就會展開一個日歷控件供用戶選擇,而一旦用戶做出了選擇,日期/時間選擇器會自動顯示新的日期/時間。MFC提供了CDateTimeCtrl類進行支持。
SYSTEMTIME times_1; //開始時間日期
SYSTEMTIME timee_1; //結束時間日期
CDateTimeCtrl* dtPickctrs_1 = (CDateTimeCtrl*)GetDlgItem(IDC_DATETIMEPICKER_START1); //獲取時間控件句柄
CDateTimeCtrl* dtPickctre_1 = (CDateTimeCtrl*)GetDlgItem(IDC_DATETIMEPICKER_END1);
memset(×_1,0,sizeof(times_1)); //時鐘初始化
memset(&timee_1,0,sizeof(timee_1));
dtPickctrs_1->GetTime(×_1); //獲取控件所選時間,保存至變量
dtPickctre_1->GetTime(&timee_1);
CString strTimeStart; //將時間轉換為字符串
strTimeStart.Format(_T("%04d-%02d-%02d %02d:%02d:%02d"), times_1.wYear,times_1.wMonth,times_1.wDay,times_2.wHour,times_2.wMinute,times_2.wSecond);
CString strTimeEnd;
strTimeEnd.Format(_T("%04d-%02d-%02d %02d:%02d:%02d"), timee_1.wYear,timee_1.wMonth,timee_1.wDay,timee_2.wHour,timee_2.wMinute,timee_2.wSecond);
獲取系統時間
SYSTEMTIME time;
::GetLocalTime(&time);
如下圖,看似與真正的日歷類似,操作也類似,直觀的為用戶提供了觀察和顯示當前日期的途徑。MFC提供了CMonthCalCtrl類進行支持。
IP地址控件用來輸入和編輯IP地址,MFC提供了CIPAddressCtrl類進行支持。
該控件外觀類似于一個編輯框,但是可以自動對輸入的字符按3個一組進行區分和加間隔圓點。IP地址控件為開發支持Internet技術的程序提供了方便。
在普通組合框(Combo Box)的基礎上還支持圖像列表。
可以在組合框中顯示特定的圖標表示相應的選擇,而不僅僅是顯示文本。
MFC提供了CComboBoxEx類進行支持。
控件使用的時候,它的Class必須有一個類的支持這個窗口類可以VC的類,例如:Button、Edit.在頭文件增加一個CEdit類的成員變量:CEdit m_Text(即點擊右鍵添加變量),然后按照Edit控件使用即可。
1.用于在 MFC 應用程序上添加超鏈接,就像html中的超鏈接一樣。你點下可以鏈接到一個網頁上去。拖控件到頁面上,并綁定一個變量(m_linkCtrl),里面的內容全部是按照標準的html中href的用法寫的。寫錯了自然鏈接不了的。
可以去瞧下html里面的href屬性是怎/么設置的.另外要注意的是字符串中雙引號的處理(記得加個轉義符\),添加單擊響應消息
m_linkCtrl.SetWindowTextW(_T("<a href=\"http://blog.csdn.net/miko_xiaoming\">Miko's Note</a>"));
PNMLINK pNMLink = (PNMLINK) pNMHDR;
ShellExecuteW(NULL, L"open", pNMLink->item.szUrl, NULL, NULL, SW_SHOWNORMAL); //在瀏覽器中打開
2.同按鈕(Button)控件一樣,響應相應的消息
如下圖,實現多選按鈕選擇功能,使用時添加相應菜單
可以直接作為inet_addr(ip)的輸入,分隔符為逗號(,)
不僅可以為按鈕添加相應命令還可以對命令做出注解
ID:控件的資源標識。
Visiable:控件是否可見。
Disabled:控件是否被禁止、被禁止的控件無法接受鍵盤和鼠標輸入。
Group:是否從這個空間開始一個新組。
Tab stop:在程序中是否可以用【Tab】鍵切換到這個控件。
Help ID:是否給控件分配一個幫助標識,幫助標識基于控件本身的資源標識。
Client edge:給控件增加一個凹陷的邊界,使整個控件看起來像是凹下去的一樣。
Static edge:給控件增加一個邊界。
Modal frame:給控件增加一個3維的框架,與Client edge相反,它是凸出來的。
Transparent:擁有此屬性的窗口是透明的,它下面的窗口不會被它遮掩住。
Accept files:擁有此屬性的窗口可以接收拖放文件,如果一個文件被拖動到這個控件上面,控件會收到WM_DROPFILES消息。
No parent notify:表示控件不向其父窗口發送WM_PARENTNOTIFY消息。
Right aligned text:表示文本右對齊。
以上屬性可通過控件的屬性對話框進行設置,在屬性對話框中按【F1】鍵可以查看屬性的幫助信息。
每一種控件都由一個MFC控件類來管理,當通過資源編輯器在對話框上添加一個控件時,visualC++會自動為控件類生成一個實例,即對象,并調用構造函數,當對話框關閉時,其各個子控件對象被自動銷毀。
也可以不使用資源編輯器,自己在程序中寫代碼創建、顯示控件并設置控件的屬性。
所有的控件類都來自CWnd,控件的某些操作和屬性設置需要用到CWnd本身的成員函數,CWnd某些函數經常用來操縱控件和設置控件屬性。
SetWindowText:設置控件上要顯示的標題文本,即用來設置控件的caption屬性
GetWindowText:得到控件的標題文本
EnableWindow:設置控件的Disabled屬性,即社會自控件是否可以接收鍵盤和鼠標的輸入
SetWindowPos:改變窗口的大小、位置和Z軸次序。
MoveWindow:改變窗口的大小和位置
GetWindowRec:得到窗口的大小、位置(信息存放在一個矩形結構中)。
GetClientRect:得到窗口客戶區的大小(信息存放在一個矩形結構中 )
ShowWindow:設置窗口的可見性(即窗口是否可見)
SetWindowText/GetWindowText還可以用來設置/得到對話框的標題文本。
福利來啦~
學習從來不是一個人的事情,要有個相互監督的伙伴,對于C/C++感興趣可以關注小編在后臺私信我:【編程交流】一起來學習哦!可以領取一些C/C++的項目學習視頻資料哦!
CGControlBar庫擁有500多個經過全面設計、測試和充分記錄的MFC擴展類。 我們的組件可以輕松地集成到您的應用程序中,并為您節省數百個開發和調試時間。
BCGControlBar專業版和BCGSuite for MFC v33.3已正式發布了,該版本包含了增強的Ribbon自定義、新的日期/時間數字指示器、帶有文本對齊的組控件、多行支持以及其他一些新功能和改進。最新版點擊下方獲取:
BCGControlBar Professional Edition for MFC官方最新版免費下載試用,歷史版本下載,在線文檔和幫助文件下載-慧都網
1. 實現了使用單個輸入字符在所選文本周圍切換為注釋的功能(例如在c++語言中的'/'),啟用此功能的最簡單方法是向XML設置文件添加一個新標記CommentString,或者調用一個新方法CBCGPEditCtrl::EnableCommentingSelectedText,此外CBCGPEditCtrl類增加了以下新方法:
2. 增加了一個新的方法HasSelection:這個方法告知一些文本是否被選中。
1. Stdafx.cpp/.h文件重命名為BCGPStdAfx.cpp/.h(以避免在用戶應用程序中引用不正確的預編譯頭文件)。
2. CBCGPBaseVisualObject:當父窗口接收WM_SETTINGCHANGE消息時,一個新的虛擬方法OnSystemSettingChange被調用。
3. CBCGPPropertyManager:方法LoadValuesFromRegistry有一個新的可選參數'bNotifyChanges'(默認為FALSE)。如果此參數為TRUE,并且從注冊表加載的屬性值不是默認值,則此屬性將調用OnPropertyChanged。
4. CBCGPLightBoxDialogOptions有一個新成員m_bDisableParentWindow(默認值是FALSE),當此屬性為TRUE時,整個父幀被禁用并顯示為灰色,因此用戶不能調整大小或移動它。
5. 一個新的助手類CBCGPInfoBoxView簡化了創建帶有嵌入式信息框的cview派生類,如果開發人員需要創建一個簡單的信息視圖,請從CBCGPInfoBoxView派生您的類,并在類構造函數中調用SetInfoText。
6. 改進了幾個控件的打印:
7. CBCGPGridCtrl:添加了以下新的訪問方法(用于獲取/更改默認的導出標志)。
isual c++ 提 供 了 功 能 強 大 的 類 庫, 基 本 上 應 用 開 發 的 要 求, 但 對 于 某 些 特 殊 要 求 的 界 面, 如 圖 像 兼 文 字 的 按 紐, 列 表 框 中 插 入 圖 像, 中 國 式 報 表 等 等, 仍 顯 得 力 不 從 心, 因 而 很 有 必 要 創 建 擴 展MFC 類 庫, 以 滿 足 實 際 開 發 的 需 求。But,Toolkit Pro 是MFC開發中最全面界面控件套包,它提供了Windows開發所需要的11種主流的Visual C++ MFC控件。 根據需要可進行下載體驗!
本文通過實例說明MFC工具欄的創建、設計和使用方法,包括三個demo。
demo1:創建一個工具欄
C++代碼
//摘抄自MSDN
demo1 (創建一個工具欄)
1.Create a toolbar resource.
/*可以先插入一個新的工具欄資源
添加分隔符,將按鈕向右拖動一小下
刪除按鈕,將按鈕拖動出工具欄
*/
2.Construct the CToolBar object.
/*
工具欄是 CToolBar 對象,聲明為應用程序的 CMainFrame 類的數據成員。也就是說,工具欄對象嵌入到主框架窗口對象中。這意味著 MFC 在創建框架窗口時創建工具欄,在銷毀框架窗口時銷毀工具欄。
*/
3.Call the Create (or CreateEx) function to create
the Windows toolbar and attach it to the CToolBar object.
4.Call LoadToolBar to load the toolbar resource.
/*
工具欄創建發生在 CMainFrame::OnCreate 中。MFC 在創建框架窗口之后且在窗口可見之前調用 OnCreate。
在 OnCreate 中調用適當的函數來停靠或浮動工具欄、設置它的樣式等。
應用程序向導”生成的默認 OnCreate 執行以下工具欄任務:
1.調用 CToolBar 對象的 Create 成員函數來創建基礎 CToolBarCtrl 對象。
2.調用 LoadToolBar 來加載工具欄資源信息。
3.調用函數來啟用停靠、浮動和工具提示。
*/
class CMainFrame : public CMDIFrameWnd
{
// ...
// Implementation
// ...
protected: // control bar embedded members
CStatusBar m_wndStatusBar;
CToolBar m_wndToolBar;
// Generated message map functions
protected:
afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);
DECLARE_MESSAGE_MAP()
};
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
if (CMDIChildWnd::OnCreate(lpCreateStruct) == -1)
return -1;
//框架類中m_wndMyToolBar成員變量先調用CreateEx函數,再調用LoadToolBar函數
if (! m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP
| CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
! m_wndToolBar.LoadToolBar(IDR_MYTOOLBAR))
{
TRACE0("Failed to create toolbar\n");
return -1; // fail to create
}
//調用CToolBar中的成員函數設置工具欄可停靠的位置
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
//調用框架類中的成員函數設置哪里可以被停靠
EnableDocking(CBRS_ALIGN_ANY);
//Points to the control bar to be docked.
DockControlBar(&m_wndToolBar);
return 0;
}
demo2:停靠和浮動工具欄
C++代碼
demo2 (停靠和浮動工具欄)
/*
如果使用“應用程序向導”來生成應用程序的主干,向導將要求您選擇是否想要可停靠的工具欄。
默認情況下,“應用程序向導”生成代碼來執行將可停靠工具欄放置在應用程序中所需的三個操作:
1.在框架窗口中啟用停靠。
2.為工具欄啟用停靠。
3.停靠工具欄(靠向框架窗口)。
如果這些步驟中的任何一個缺少,應用程序都將顯示標準工具欄。
后兩個步驟對應用程序中的每一個可停靠工具欄都必須執行。
*/
CFrameWnd::EnableDocking()//在框架窗口中啟用停靠
/*
若要將工具欄停靠到某個框架窗口,則必須啟用該框架窗口(或目標)以允許停靠。
這可通過使用 CFrameWnd::EnableDocking 函數來實現,該函數采用一個 DWORD 參數,這是一組指示框架窗口的哪一個邊接受停靠的樣式位。
如果一個工具欄即將停靠并且有多個邊可以停靠,則在傳遞給 EnableDocking 的參數中指示的邊按以下順序使用:頂邊、底邊、左邊、右邊。
如果希望能夠將控制條停靠在任意位置,請將 CBRS_ALIGN_ANY 傳遞給 EnableDocking。
*/
CControlBar::EnableDocking()//為工具欄啟用停靠
/*
準備好停靠目標后,必須以相似的方式準備工具欄(或源)。為想要停靠的每一個工具欄調用 CControlBar::EnableDocking,指定工具欄應停靠的目標邊。如果在 CControlBar::EnableDocking 調用中所指定的邊沒有一個與框架窗口中為停靠啟用的邊匹配,則工具欄無法停靠(它將浮動)。
工具欄一旦浮動,將保持為浮動工具欄,不能停靠到框架窗口。
如果希望工具欄永久浮動,請調用參數為 0 的 EnableDocking。然后調用 CFrameWnd::FloatControlBar。工具欄將保持浮動,永遠不能在任意位置停靠。
*/
CFrameWnd::DockControlBar()//停靠工具欄
/*
當用戶試圖將工具欄放置在允許停靠的框架窗口某一邊時,框架調用 CFrameWnd::DockControlBar。
另外,可以隨時調用該函數將控制條停靠在框架窗口中。這通常在初始化過程中完成。
框架窗口的具體某個邊上可停靠多個工具欄。
*/
CFrameWnd::FloatControlBar()//浮動工具欄
/*
從框架窗口分離可停靠工具欄稱為浮動工具欄。調用 CFrameWnd::FloatControlBar 來執行該操作。指定要浮動的工具欄、將放置的點以及決定浮動工具欄是水平還是垂直的對齊樣式。
當用戶拖動工具欄離開停靠位置并將它放置在一個未啟用停靠的位置時,框架調用該函數。
這可以是框架窗口的內部或外部的任意位置。同 DockControlBar 一樣,也可以在初始化過程中調用該函數。
可停靠工具欄的 MFC 實現不提供一些支持可停靠工具欄的應用程序中有的擴展功能。諸如可自定義工具欄這樣的功能不提供。
*/
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct)
{
//...
//部分代碼略
//...
//調用CToolBar中的成員函數設置工具欄可停靠的位置
m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);
//調用框架類中的成員函數設置哪里可以被停靠
EnableDocking(CBRS_ALIGN_ANY);
//Points to the control bar to be docked.
DockControlBar(&m_wndToolBar);
return 0;
}
demo3:點擊菜單項顯示和隱藏工具欄
C++代碼
demo3 (點擊菜單項顯示和隱藏工具欄)
CFrameWnd::ShowControlBar//顯示和隱藏菜單項
void ShowControlBar( CControlBar* pBar, BOOL bShow, BOOL bDelay );
void CMainFrame::OnViewNewtool()
{
ShowControlBar(&m_newToolBar,!m_newToolBar.IsWindowVisible(),FALSE);//控制顯示和隱藏
}
void CMainFrame::OnUpdateViewNewtool(CCmdUI* pCmdUI)
{
// TODO: Add your command update UI handler code here
pCmdUI->SetCheck(m_newToolBar.IsWindowVisible());//為菜單項打標記
}
MFC擴展類庫
在平時練習的時候我們可以自己手動進行,但是一旦接受一些項目,應用程序開發等,對界面的要求就會高出許多。這時候就有必要借助這些“半成品”實現界面美化提升效率。這里簡單介紹一下,具體可點進去查看每個的詳情以及教程,案例!
Toolkit Pro:
Codejock軟件公司的Xtreme Toolkit Pro是屢獲殊榮的VC界面庫,是MFC開發中最全面界面控件套包,它提供了Windows開發所需要的11種主流的Visual C++ MFC控件,包括Command Bars、Controls、Chart Pro、Calendar、Docking Pane、Property Grid、Report Control、Shortcut Bar、Syntax Edit、Skin Framework 和Task Panel。
BCGControlBar ("Business Components Gallery ControlBar")是MFC擴展庫,使您可以創建具有完全自定義選項(功能區、可自定義工具欄、菜單等)以及一組專業設計的豐富Microsoft Office和Microsoft Visual Studio的應用程序 GUI控件,例如圖表、日歷、網格、編輯器、甘特圖和許多其他控件。
BCGControlBar庫擁有500多個經過全面設計、測試和充分記錄的MFC擴展類。可以輕松地集成到你的應用程序中,并為你節省數百個開發和調試時間。
轉載自:http://www.jizhuomi.com/software/494.html
關注我或者點擊下方“了解更多”獲取一手開發資訊哦!
*請認真填寫需求信息,我們會在24小時內與您取得聯系。