Создает новое меню заданного типа.
int _NewMenu(int mtype, MENUID menuid) int mtype; /* Тип меню. */ MENUID menuid; /* Идентификатор меню. */ |
Примечания
Вы можете задать MPOPUP или MBAR в качестве параметра mtype. Идентификатор меню должен быть уникальным.
Используйте _GetNewMenuId( ), чтобы получить незадействованный идентификатор меню. _NewMenu( ) возвращает 0, если меню успешно создано. В случае ошибки _NewMenu( ) возвращает отрицательное число, абсолютное значение которого представляет собой номер ошибки Visual FoxPro.
Для получения дополнительной информации о том, как создавать библиотеку API и интегрировать её в Visual FoxPro, смотрите Доступ к API Visual FoxPro.
Пример
В следующем примере с помощью _NewMenu( ) создается новое меню.
Код Visual FoxPro
![]() | |
---|---|
SET LIBRARY TO NEWMENU |
Код C
![]() | |
---|---|
#include <pro_ext.h> void putLong(long n) { Value val; val.ev_type = 'I'; val.ev_long = n; val.ev_width = 10; _PutValue(&val); } FAR GetNewItemId(ParamBlk FAR *parm) { MENUID menuId; ITEMID itemId; Point loc; menuId = _GetNewMenuId(); _NewMenu(MPOPUP, menuId); itemId = _GetNewItemId(menuId); _NewItem(menuId, itemId, -2, "\\<2nd item"); itemId = _GetNewItemId(menuId); _NewItem(menuId, itemId, -1, "\\<1st item"); itemId = _GetNewItemId(menuId); _NewItem(menuId, itemId, -2, "\\<3rd item"); loc.v = 10; loc.h = 20; _SetMenuPoint(menuId, loc); _MenuInteract(&menuId, &itemId); _PutStr("\nmenuId ="); putLong(menuId); _PutStr("\nitemId ="); putLong(itemId); _DisposeMenu(menuId); } FoxInfo myFoxInfo[] = { {"ONLOAD", (FPFI) GetNewItemId, CALLONLOAD, ""}, }; FoxTable _FoxTable = { (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo }; |
Смотрите также

© Microsoft Corporation. All rights reserved. Microsoft is not reponsible for the contents of the translated help topics.