MENUINFO 结构
注:本文档由 TOP_LK 翻译,小甲鱼校对。原文链接 -> 传送门
MENUINFO 结构
MENUINFO 结构体包含一个菜单的信息。
结构原型:
typedef struct tagMENUINFO {
DWORD cbSize;
DWORD fMask;
DWORD dwStyle;
UINT cyMax;
HBRUSH hbrBack;
DWORD dwContextHelpID;
ULONG_PTR dwMenuData;
} MENUINFO, *LPMENUINFO, const *LPCMENUINFO;
成员解析:
成员 含义
cbSize1. 指定结构体的大小,以字节为单位
2. 调用者必须将此成员设置为 sizeof(MENUINFO)
fMask1. 指示要获取或设置的成员(除了 MIM_APPLYTOSUBMENUS)
2. 该成员可以是下列值中的一个或多个:
值 含义
MIM_APPLYTOSUBMENUS
(0x80000000)1. 设置适用于菜单和它的所有子菜单
2. SetMenuInfo 函数使用该标识,GetMenuInfo 函数不使用该标识
MIM_BACKGROUND
(0x00000002)获取或设置 hbrBack 成员
MIM_HELPID
(0x00000004)获取或设置 dwContextHelpID 成员
MIM_MAXHEIGHT
(0x00000001)获取或设置 cyMax 成员
MIM_MENUDATA
(0x00000008)获取或设置 dwMenuData 成员
MIM_STYLE
(0x00000010)获取或设置 dwStyle 成员
dwStyle1. 指定了菜单风格
2. 该成员可以是下列值中的一个或多个:
值 含义
MNS_AUTODISMISS
(0x10000000) 当鼠标在菜单外约 10 秒时,菜单会自动结束
MNS_CHECKORBMP
(0x04000000) 相同的空间是保留给复选标记和位图的。如果复选标记被绘制,则位图不会被绘制。所有的复选标记和位图是一致的。被用于一些项目使用复选标记和位图的菜单
MNS_DRAGDROP
(0x20000000) 菜单项是 OLE 拖放目标或阻力的来源。菜单所有者会收到 WM_MENUDRAG 和 WM_MENUGETOBJECT 的消息
MNS_MODELESS
(0x40000000) 菜单是非模态的;也就是说,菜单中没有菜单模式消息循环,当菜单是活动的
MNS_NOCHECK
(0x80000000) 没有空间被保留给项目的左边用于复选标记。项目仍然能被选择,但是复选标记将不会显示在项目的旁边
MNS_NOTIFYBYPOS
(0x08000000) 菜单所有者接收 WM_MENUCOMMAND 消息而不是 WM_COMMAND 消息,当用户进行选择。MNS_NOTIFYBYPOS 是一个菜单标题风格,应用于单个子菜单时没有效果
cyMax 指定了菜单中以像素为单位的最大高度。当菜单项超过可用空间时,则会自动使用滚动条。默认值(0)是屏幕高度
hbrBack 指向被用于菜单的背景的画笔的句柄
dwContextHelpID 指定上下文帮助标识符。在 GetMenuContextHelpId 函数和 SetMenuContextHelpId 函数中使用相同的值
dwMenuData 指定了一个应用程序定义的值
需求:
Minimum supported client Windows 2000 专业版 [仅桌面应用程序]
Minimum supported server Windows 2000 服务器版 [仅桌面应用程序]
Header Winuser.h (包含于 Windows.h)
【API档案】版权归鱼C工作室(www.fishc.com)所有,转载请注明来源。
页:
[1]