MFC菜单项添加图标 禁用菜单项 设置默认菜单项

void CbuttonDlg::OnLButtonDown(UINT nFlags, CPoint point) {  // TODO: 在此添加消息处理程序代码和/或调用默认值  CMenu menu;//菜单  CMenu* pPopupMenu;//菜单指针  CBitmap m_bitmap1,m_bitmap2,m_bitmap3;//位图

 menu.LoadMenu(IDR_MENU1);//加载ID为IDR_MENU1的菜单  m_bitmap1.LoadBitmap(IDB_BITMAP1);//加载ID为IDB_BITMAP1的位图  m_bitmap2.LoadBitmap(IDB_BITMAP2);//加载ID为IDB_BITMAP2的位图  m_bitmap3.LoadBitmap(IDB_BITMAP3);

 pPopupMenu = menu.GetSubMenu(0); //获取弹出菜单的第一层子菜单的类指针

 //为菜单的第一和第三项设置图标  pPopupMenu->CheckMenuItem(0,MF_BYPOSITION|MF_CHECKED); //设置第1个为被选中状态 图标显示为选中后的图标  pPopupMenu->CheckMenuItem(1,MF_BYPOSITION|MF_CHECKED); //设置第2个为被选中状态 因为没有加载图标 前面会显示 勾  pPopupMenu->EnableMenuItem(4,MF_BYPOSITION|MF_GRAYED); //设置第四项为灰色禁用  pPopupMenu->SetDefaultItem(ID_MENU1_32772,FALSE);  //当第二个参数为FALSE时,前面一个参数需要为ID标识名称 这里是设置第二个菜单为默认菜单项 会显示粗体  pPopupMenu->SetDefaultItem(3,TRUE);      //因为菜单中有分隔符,所有这里要设置标号为3 即第4项为默认菜单项  并且一个菜单中只能有一个默认项  pPopupMenu->SetMenuItemBitmaps(0,MF_BYPOSITION,&m_bitmap1,&m_bitmap3); // 其中第三个参数是未选中时图标,第四个参数是选中的图标,由于上面设置该菜单已选中,图标显示m_bitmap2  pPopupMenu->SetMenuItemBitmaps(3,MF_BYPOSITION,&m_bitmap2,&m_bitmap3);

 ClientToScreen(&point);//将鼠标单击处的坐标转换为屏幕坐标

 //弹出菜单函数,第一个参数表示快捷菜单的下边界与由参数y指定的坐标对齐

 //第二和第三个为x、y坐标,第四个表示拥有此菜单的窗口句柄,

 //第五个默认为NULL,表示当用户在菜单以外的区域按鼠标键时,菜单会消失

 pPopupMenu->TrackPopupMenu(TPM_LEFTALIGN,point.x,point.y,this,NULL);

 CDialog::OnLButtonDown(nFlags, point); }

void CbuttonDlg::OnMenu132771() {  // TODO: 在此添加命令处理程序代码  MessageBox(L"点击菜单弹出的对话框"); }

CheckMenuItem函数

    函数功能:该函数取得与指定菜单项相联系的菜单标志。如果该菜单项打开了一个子菜单,该函数也返回子菜单里的菜单项数。

  函数原型:DWORD CheckMenuItem(HMENU hmenu, UINT uIDCheckItem, UINT uCheck); 

  参数:

  hmenu:含有其菜单项的标志将被提取得的菜单的句柄。

  uIDCheckItem:制定要修改的菜单项。

  uCheck:表示标记的状态。此参数可取下列值之一:

  MF_BYCOMMAND:表示参数uId给出菜单项的标识符。如果MF_BYCOMMAND和MF_BYPOSITION都没被指定,则MF_BYCOMMAND是缺省值。

  MF_BYPOSITION:表示参数uId给出菜单项相对于零的位置。

  返回值:如果指定的项不存在,返回值是OXFFFFFFFF;如果菜单项打开了一个子菜单,则返回值的低位含有与菜单相联系的菜单标志,高位含有子菜单的项数。否则,返回值是莱单标志的掩码(布尔OR)。

  下面列出与菜单项相关的菜单标志。

  MF_CHECKED:放置选取标记于菜单项旁边(只用于下拉式菜单、子菜单或快捷菜单)。

  MF_DISABLED:使菜单项无效。MF_GRAYED:使菜单项无效并交灰。MF_HILITE:加亮菜单项。

  MF_MENUBARBREAK:对下拉式菜单、子菜单和快捷菜单,新列和旧列由垂直线隔开,其余功能同MF_MENUBREAK标志。

  MF_MENUBREAK:将菜单项放于新行(对菜单条)或无分隔列地放于新列(对下拉式菜单、子菜单或快捷菜单)。

  MF_SEPARATOR:创建一个水平分隔线(只用于下拉式菜单、子菜单或快捷菜单)。

  MF_UNCHECKED: Acts as a toggle with MF_CHECKED to remove a check mark next to the item

 

SetMenuItemBitmaps 函数

该函数将一个位图与制定菜单条目相关联。无论菜单条目被选中或被清除,系统都将在菜单条目之前显示一个(大小适当的)位图。

Syntax

BOOL SetMenuItemBitmaps(      HMENU hMenu, UINT uPosition, UINT uFlags, HBITMAP hBitmapUnchecked, HBITMAP hBitmapChecked );

Parameters

hMenu [in] 菜单句柄 uPosition [in] 指定将要改变的菜单条目,由uFlags参数决定。 uFlags [in] 指定uPosition参数如何被解释。该参数必须为下列值之一:

MF_BYCOMMAND 表明uPosition参数赋给菜单条目的标识符。如果MF_BYCOMMAND和MF_BYPOSITION都未被指定,MF_BYCOMMAND就是默认的标识。 MF_BYPOSITION 表明uPosition赋给菜单条目相对位置。

hBitmapUnchecked [in] 菜单项未被选中时的位图句柄 hBitmapChecked [in] 菜单项被选中时位图的句柄

Return Value

如果函数成功,返回非零值;如果函数失败,返回零值。

Remarks

如果hBitmapUnchecked 或 hBitmapChecked 参数为NULL,系统将不会在相应的选择状态下显示任何位图。如果此二参数都为NULL,系统将在菜单项被选中时显示默认的选中位图,并在取消该菜单项的选择后移除该位图。 当菜单被摧毁后,这些位图不会被摧毁;直到应用程序来摧毁他们为止。

选择和清除位图应该为单色的。系统使用布尔值AND操作符来合并位图和菜单项,这样位图白色部分会变得透明,黑色部分会变成与菜单项颜色一致的颜色。如果使用彩色位图,结果可能出乎意料。 使用带有 CXMENUCHECK 和 CYMENUCHECK 值的GetSystemMetrics 函数可以获得位图的尺寸。  

你可能感兴趣的:(mfc)