Type a page name and press Enter. You'll jump to the page if it exists, or you can create it if it doesn't.
To create a page in a module other than user32, prefix the name with the module name and a period.
GetMenuString (user32)
.
C# Signature:
[DllImport("user32.dll")]
static extern int GetMenuString(IntPtr hMenu, uint uIDItem,
[Out,MarshalAs(UnmanagedType.LPStr)] StringBuilder lpString, int nMaxCount, uint uFlag);
in Specifies the menu item to be changed, as determined by the uFlag parameter.
lpString
out Pointer to the buffer that receives the NULL-terminated string. If the string is as long or longer than lpString, the string is truncated and the terminating NULL character is added. If lpString is NULL, the function returns the length of the menu string.
nMaxCount
in Specifies the maximum length, in characters, of the string to be copied. If the string is longer than the maximum specified in the nMaxCount parameter, the extra characters are truncated. If nMaxCount is 0, the function returns the length of the menu string.
uFlag
in Specifies how the uIDItem parameter is interpreted. This parameter must be one of the following values.
MF_BYCOMMAND
Indicates that uIDItem gives the identifier of the menu item. If neither the MF_BYCOMMAND nor MF_BYPOSITION flag is specified, the MF_BYCOMMAND flag is the default flag.
MF_BYPOSITION
Indicates that uIDItem gives the zero-based relative position of the menu item.
IntPtr hMenu = GetMenu(hWnd);
if (hMenu.ToInt32() != 0)
{
for (uint i = GetMenuItemCount(hMenu) - 1; i >= 0; i--)
{
StringBuilder menuName = new StringBuilder(0x20);
GetMenuString(hMenu, i, menuName, 0x20, MF_BYPOSITION);
DeleteMenu(hMenu, i, MF_BYPOSITION);
}
}
}
Alternative Managed API:
Do you know one? Please contribute it!
The GetMenuString API
4/29/2008 12:34:53 AM - -202.103.42.72
TODO - a short description of this collection of constants
4/6/2012 12:59:20 AM - anonymous
TODO - a short description of this collection of constants
4/6/2012 12:59:20 AM - anonymous
An IntPtr is a pointer to a memory location (unmanaged) that adapts to the platform it is running on (64-bit, etc.) UNLIKE a standard int/Integer. You should always use this type for unmanaged calls that require it, even though an int will appear to work on your development machine.
1/13/2008 4:00:13 AM - Damon Carr-72.43.165.29
Please edit this page!
Do you have...
helpful tips or sample code to share for using this API in managed code?
corrections to the existing content?
variations of the signature you want to share?
additional languages you want to include?
Select "Edit This Page" on the right hand toolbar and edit it! Or add new pages containing supporting types needed for this API (structures, delegates, and more).