MFC对话框响应ON_UPDATE_COMMAND_UI事件

简介:
以对话框为父窗口创建的菜单,菜单响应函数可以写在对话框类中。
菜单响应函数的映射和普通菜单响应映射一样。
但是菜单状态更新命令,需要特殊处理。
复制代码
BEGIN_MESSAGE_MAP(CDlg, CDialogEx)
    ON_WM_INITMENU()
    ON_WM_INITMENUPOPUP()
     //  大气象
    ON_UPDATE_COMMAND_UI_RANGE( 1001, 1002,&OnMenuItemUI)
END_MESSAGE_MAP()

//  设置Check或Enable
void CDlg::OnMenuItemUI(CCmdUI *pCmdUI)
{
     if (pCmdUI->m_nID ==  1001)
    {
        pCmdUI->SetCheck( 1);
    }
     if (pCmdUI->m_nID ==  1002)
    {
        pCmdUI->Enable(FALSE);
    }
}

BOOL CDlg::OnInitDialog()
{
    CDialogEx::OnInitDialog();

     //  TODO:  在此添加额外的初始化
    CMenu menuMain;
    menuMain.CreateMenu();

    CMenu menuChild;
    menuChild.CreatePopupMenu();
    menuChild.AppendMenu(MF_STRING, 1001, " menu1 ");
    menuChild.AppendMenu(MF_STRING, 1002, " menu2 ");

    menuMain.AppendMenu(MF_POPUP,(UINT)menuChild.Detach(), " menu0 ");

    SetMenu(&menuMain);
    menuMain.Detach();

     return TRUE;   //  return TRUE unless you set the focus to a control
    
//  异常: OCX 属性页应返回 FALSE
}
//  大气象:需要在这里做特殊处理。
void CDlg::OnInitMenuPopup(CMenu* pPopupMenu, UINT nIndex, BOOL bSysMenu)
{
    CDialogEx::OnInitMenuPopup(pPopupMenu, nIndex, bSysMenu);

     //  TODO: 在此处添加消息处理程序代码
    CCmdUI state; 
    state.m_pMenu = pPopupMenu; 
    ASSERT(state.m_pOther == NULL); 
    ASSERT(state.m_pParentMenu == NULL); 

     //  Determine if menu is popup in top-level menu and set m_pOther to 
    
//  it if so (m_pParentMenu == NULL indicates that it is secondary popup). 
    HMENU hParentMenu; 
     if (AfxGetThreadState()->m_hTrackingMenu == pPopupMenu->m_hMenu) 
        state.m_pParentMenu = pPopupMenu;     //  Parent == child for tracking popup. 
     else  if ((hParentMenu = ::GetMenu(m_hWnd)) != NULL) 
    { 
        CWnd* pParent =  this
         //  Child windows don't have menus--need to go to the top! 
         if (pParent != NULL && 
            (hParentMenu = ::GetMenu(pParent->m_hWnd)) != NULL) 
        { 
             int nIndexMax = ::GetMenuItemCount(hParentMenu); 
             for ( int nIndex =  0; nIndex < nIndexMax; nIndex++) 
            { 
                 if (::GetSubMenu(hParentMenu, nIndex) == pPopupMenu->m_hMenu) 
                { 
                     //  When popup is found, m_pParentMenu is containing menu. 
                    state.m_pParentMenu = CMenu::FromHandle(hParentMenu); 
                     break
                } 
            } 
        } 
    } 

    state.m_nIndexMax = pPopupMenu->GetMenuItemCount(); 
     for (state.m_nIndex =  0; state.m_nIndex < state.m_nIndexMax; 
        state.m_nIndex++) 
    { 
        state.m_nID = pPopupMenu->GetMenuItemID(state.m_nIndex); 
         if (state.m_nID ==  0
             continue//  Menu separator or invalid cmd - ignore it. 

        ASSERT(state.m_pOther == NULL); 
        ASSERT(state.m_pMenu != NULL); 
         if (state.m_nID == (UINT)- 1
        { 
             //  Possibly a popup menu, route to first item of that popup. 
            state.m_pSubMenu = pPopupMenu->GetSubMenu(state.m_nIndex); 
             if (state.m_pSubMenu == NULL || 
                (state.m_nID = state.m_pSubMenu->GetMenuItemID( 0)) ==  0 || 
                state.m_nID == (UINT)- 1
            { 
                 continue;        //  First item of popup can't be routed to. 
            } 
            state.DoUpdate( this, TRUE);    //  Popups are never auto disabled. 
        } 
         else 
        { 
             //  Normal menu item. 
            
//  Auto enable/disable if frame window has m_bAutoMenuEnable 
            
//  set and command is _not_ a system command. 
            state.m_pSubMenu = NULL; 
            state.DoUpdate( this, FALSE); 
        } 

         //  Adjust for menu deletions and additions. 
        UINT nCount = pPopupMenu->GetMenuItemCount(); 
         if (nCount < state.m_nIndexMax) 
        { 
            state.m_nIndex -= (state.m_nIndexMax - nCount); 
             while (state.m_nIndex < nCount && 
                pPopupMenu->GetMenuItemID(state.m_nIndex) == state.m_nID) 
            { 
                state.m_nIndex++; 
            } 
        } 
        state.m_nIndexMax = nCount; 
    } 
}
//  大气象:注意不是这里
void CDlg::OnInitMenu(CMenu* pMenu)
{
    CDialogEx::OnInitMenu(pMenu);

     //  TODO: 在此处添加消息处理程序代码
}
复制代码

对话框里创建的菜单,响应函数可以写在其他类。
需要源码的,留下邮箱索取。
url: http://greatverve.cnblogs.com/archive/2012/11/28/dlg-on-update-command-ui.html 
参考:
http://support.microsoft.com/kb/242577/zh-cn
http://greatverve.cnblogs.com/archive/2012/11/21/mfc-dlg-menu-cmd.html 




    本文转自wenglabs博客园博客,原文链接:http://www.cnblogs.com/greatverve/archive/2012/11/28/dlg-on-update-command-ui.html ,如需转载请自行联系原作者

相关文章
|
7月前
|
JavaScript
Vue给Element UI的el-popconfirm绑定按钮事件
Vue给Element UI的el-popconfirm绑定按钮事件
|
7月前
使用element clickoutside自定义指令事件,点击元素外部触发(element-ui/src/utils/clickoutside)
使用element clickoutside自定义指令事件,点击元素外部触发(element-ui/src/utils/clickoutside)
|
4月前
|
编解码 前端开发 vr&ar
从零开始的PICO教程(4)--- UI界面绘制与响应事件
这篇文章是PICO开发系列教程的第四部分,主要介绍了如何在PICO 4 VR环境中创建UI界面,包括Canvas和Panel的配置、UI元素的绘制、以及Button和Slider的事件响应绑定,并通过示例展示了数字增减和滑块功能的具体实现。
从零开始的PICO教程(4)--- UI界面绘制与响应事件
|
4月前
|
前端开发 开发者 开发框架
JSF与Bootstrap,打造梦幻响应式网页!让你的应用跨设备,让用户爱不释手!
【8月更文挑战第31天】在现代Web应用开发中,响应式设计至关重要,以确保不同设备上的良好用户体验。本文探讨了JSF(JavaServer Faces)与Bootstrap框架的结合使用,展示了如何构建响应式网页。JSF是一个基于Java的Web应用框架,提供丰富的UI组件和表单处理功能;而Bootstrap则是一个基于HTML、CSS和JavaScript的前端框架,专注于实现响应式设计。通过结合两者的优势,开发者能够更便捷地创建自适应布局,提升Web应用体验。然而,这种组合也有其局限性,如JSF组件库较小和较高的学习成本等,因此在选择开发框架时需综合考虑具体需求和应用场景。
56 0
|
5月前
element UI【解决方案】消息弹框被对话框遮挡($message消息框被dialog或$alert遮罩)
element UI【解决方案】消息弹框被对话框遮挡($message消息框被dialog或$alert遮罩)
217 3
|
5月前
Element UI【实战范例】下拉选择 el-select 的 change 事件传入选中值+自定义参数
Element UI【实战范例】下拉选择 el-select 的 change 事件传入选中值+自定义参数
838 1
|
JavaScript 前端开发
前端学习笔记202306学习笔记第五十四天-react.js & material-ui之Dialog表单提交,ICon样式事件,删除功能5
前端学习笔记202306学习笔记第五十四天-react.js & material-ui之Dialog表单提交,ICon样式事件,删除功能5
49 0
|
JavaScript 前端开发
前端学习笔记202306学习笔记第五十四天-react.js & material-ui之Dialog表单提交,ICon样式事件,删除功能4
前端学习笔记202306学习笔记第五十四天-react.js & material-ui之Dialog表单提交,ICon样式事件,删除功能4
44 0
|
JavaScript
Vue中使用element-ui的el-dialog对话框,实现拖拽效果(整理)
Vue中使用element-ui的el-dialog对话框,实现拖拽效果(整理)
|
JavaScript 前端开发
前端学习笔记202306学习笔记第五十四天-react.js & material-ui之Dialog表单提交,ICon样式事件,删除功能5
前端学习笔记202306学习笔记第五十四天-react.js & material-ui之Dialog表单提交,ICon样式事件,删除功能5
58 0