【MFC】工具栏按钮单选效果
生活随笔
收集整理的這篇文章主要介紹了
【MFC】工具栏按钮单选效果
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
00. 目錄
文章目錄
- 00. 目錄
- 01. 案例概述
- 02. 開發環境
- 03. 關鍵技術
- 04. 程序設計
- 05. 秘笈心法
- 06. 源碼下載
- 07. 附錄
01. 案例概述
Visual C++在設計對話框資源的時候,有一個控件選擇的工具欄,該工具欄上的按鈕只有一個是有效的。案例效果如下圖所示。
02. 開發環境
系統環境:Windows 10
開發環境:Visual Studio 2019
03. 關鍵技術
使用工具欄類CToolBar的SetButtonInfo方法可以修改工具欄按鈕的樣式,方法中的nStyle參數就是用來設置按鈕具體的樣式,將樣式設置為TBBS_GROUP和TBBS_CHECKGROUP就可以實現單選效果。TBBS_GROUP決定哪些按鈕是一組單選按鈕,用TBBS_CHECKGROUP分別設置每個按鈕。
04. 程序設計
(1)新建一個基于單文檔視圖結構的應用程序。
(2)在CMainFrame類中聲明一個CToolBar對象和CImageList對象。
protected: // 控件條嵌入成員//CToolBar m_wndToolBar;CStatusBar m_wndStatusBar;CToolBar m_ToolBar;CImageList m_ImageList;CRect m_RectFloat;(3)在CMainFrame類的OnCreate函數中創建工具欄,函數實現代碼如下。
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) {if (CFrameWnd::OnCreate(lpCreateStruct) == -1)return -1;//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_MAINFRAME))//{// TRACE0("未能創建工具欄\n");// return -1; // 未能創建//}if (!m_wndStatusBar.Create(this)){TRACE0("未能創建狀態欄\n");return -1; // 未能創建}m_wndStatusBar.SetIndicators(indicators, sizeof(indicators)/sizeof(UINT)); TODO: 如果不需要可停靠工具欄,則刪除這三行//m_wndToolBar.EnableDocking(CBRS_ALIGN_ANY);//EnableDocking(CBRS_ALIGN_ANY);//DockControlBar(&m_wndToolBar);if (!m_ToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD | WS_VISIBLE | CBRS_TOP | CBRS_GRIPPER | CBRS_TOOLTIPS | CBRS_FLYBY | CBRS_SIZE_DYNAMIC)){TRACE0("未能創建工具欄\n");return -1; // 未能創建}//創建圖像列表m_ImageList.Create(24, 24, ILC_COLOR32 | ILC_MASK, 0, 0);//向圖像列表中添加圖像CString strPath;HICON hIcon;for (int i = 0; i < 10; i++){strPath.Format(TEXT(".\\res\\toolbar\\%02d.ico"), i);hIcon = (HICON)LoadImage(NULL, strPath, IMAGE_ICON, 32, 32, LR_LOADFROMFILE);m_ImageList.Add(hIcon);}//設置工具欄按鈕m_ToolBar.SetButtons(NULL, 6);//設置工具欄首按鈕的狀態UINT nStyle;m_ToolBar.SetButtonInfo(0, ID_POINTER, TBBS_GROUP | TBBS_CHECKGROUP, 0);//獲取工具欄按鈕的狀態nStyle = m_ToolBar.GetButtonStyle(0);//設置工具欄按鈕是否另行顯示nStyle &= ~TBBS_WRAPPED;//設置工具欄按鈕的樣式m_ToolBar.SetButtonStyle(0, nStyle);m_ToolBar.SetButtonInfo(1, ID_PEN, TBBS_CHECKGROUP, 1);//獲取工具欄按鈕的狀態nStyle = m_ToolBar.GetButtonStyle(1);//設置工具欄按鈕是否另行顯示nStyle &= ~TBBS_WRAPPED;//設置工具欄按鈕的樣式m_ToolBar.SetButtonStyle(1, nStyle);m_ToolBar.SetButtonInfo(2, ID_RECTANGLE, TBBS_CHECKGROUP, 2);//獲取工具欄按鈕的狀態nStyle = m_ToolBar.GetButtonStyle(2);//設置工具欄按鈕是否另行顯示nStyle &= ~TBBS_WRAPPED;//設置工具欄按鈕的樣式m_ToolBar.SetButtonStyle(2, nStyle);m_ToolBar.SetButtonInfo(3, ID_PARALLE, TBBS_CHECKGROUP, 3);//獲取工具欄按鈕的狀態nStyle = m_ToolBar.GetButtonStyle(3);//設置工具欄按鈕是否另行顯示nStyle &= ~TBBS_WRAPPED;//設置工具欄按鈕的樣式m_ToolBar.SetButtonStyle(3, nStyle);m_ToolBar.SetButtonInfo(4, ID_ROUND, TBBS_CHECKGROUP, 4);//獲取工具欄按鈕的狀態nStyle = m_ToolBar.GetButtonStyle(4);//設置工具欄按鈕是否另行顯示nStyle &= ~TBBS_WRAPPED;//設置工具欄按鈕的樣式m_ToolBar.SetButtonStyle(4, nStyle);m_ToolBar.SetButtonInfo(5, ID_ROUNDRECT, TBBS_CHECKGROUP, 5);//獲取工具欄按鈕的狀態nStyle = m_ToolBar.GetButtonStyle(5);//設置工具欄按鈕是否另行顯示nStyle &= ~TBBS_WRAPPED;//設置工具欄按鈕的樣式m_ToolBar.SetButtonStyle(5, nStyle);//刷新工具欄m_ToolBar.Invalidate();//重新計算框架內窗體布局m_ToolBar.GetParentFrame()->RecalcLayout();//設置工具欄按鈕大小m_ToolBar.GetToolBarCtrl().SetButtonSize(CSize(31, 32));//設置工具欄圖標列表m_ToolBar.GetToolBarCtrl().SetImageList(&m_ImageList);//設置工具欄??糠绞?/span>m_ToolBar.EnableDocking(0);//設置窗口停靠方式EnableDocking(0);m_ToolBar.SetWindowTextW(TEXT("工具欄"));GetWindowRect(&m_RectFloat);//計算工具欄顯示位置CPoint point(m_RectFloat.left + 100, m_RectFloat.top + 100);//將工具欄進行浮動顯示FloatControlBar(&m_ToolBar, point, CBRS_ALIGN_LEFT);return 0; }(4)將命令ID映射到處理函數
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)ON_WM_CREATE()ON_COMMAND_RANGE(ID_POINTER, ID_POINTER + 6, OnMenuClick) // ON_WM_MENUSELECT() END_MESSAGE_MAP()void CMainFrame::OnMenuClick(UINT nId) {}05. 秘笈心法
工具欄按鈕的Group屬性
取值TBBS_GROUP用法和單選按鈕控件(Radio Button)的Group屬性相同,單選按鈕控件的Group屬性只在一組按鈕中的第一按鈕上設置,其后的單選按鈕都和第一個設置Group屬性的按鈕是一組,一個窗體只要有一個Group屬性的單選按鈕控件就可以實現單選效果。
06. 源碼下載
下載:【MFC】工具欄按鈕單選效果.rar
07. 附錄
總結
以上是生活随笔為你收集整理的【MFC】工具栏按钮单选效果的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【MFC】定义XP风格的工具栏
- 下一篇: 【MFC】工具栏按钮多选效果本