Отображает заданное меню на экране и сразу же возвращает управление в вызывающую программу.
void _ActivateMenu(MENUID menuid) MENUID menuid /* Идентификатор меню. |
Remarks
Если вы зафиксировали в данном меню нажатие клавиши или кнопки мыши, вы можете вызвать _MenuInteract( ) чтобы определить, какой элемент меню выбран пользователем.
Для получения дополнительной информации о том, как создавать библиотеку API и интегрировать её в Visual FoxPro, смотрите Доступ к API Visual FoxPro.
Пример
В следующем примере строится меню из трех элементов. _ActivateMenu( ) отображает меню. Это меню является немодальным в том смысле, что оно не влечет принудительного взаимодействия, как в случае _MenuInteract( ). Наоборот, когда пользователь делает выбор, вызывается _OnSelection( ), выбранный элемент выводится на экран и меню убирается.
Код Visual FoxPro
Copy Code | |
---|---|
SET LIBRARY TO ACTIMENU WAIT WINDOW "Make selection from menu." NOWAIT SUSPEND |
Код C
Copy Code | |
---|---|
#include <pro_ext.h> static MENUID menuId; void putLong(long n) { Value val; val.ev_type = 'I'; val.ev_long = n; val.ev_width = 10; _PutValue(&val); } FAR onSelection(long menuId, long itemId) { _PutStr("\nitemId = "); putLong(itemId); } FAR deactivateMenu(ParamBlk FAR *parm) { _DeActivateMenu(menuId); _DisposeMenu(menuId); } FAR activateMenu(ParamBlk FAR *parm) { ITEMID itemId; Point loc; menuId = _GetNewMenuId(); _NewMenu(MPOPUP, menuId); itemId = _GetNewItemId(menuId); _NewItem(menuId, itemId, -2, "\\<1st item"); itemId = _GetNewItemId(menuId); _NewItem(menuId, itemId, -2, "\\<2nd item"); itemId = _GetNewItemId(menuId); _NewItem(menuId, itemId, -2, "\\<3rd item"); loc.v = 10; loc.h = 20; _SetMenuPoint(menuId, loc); _ActivateMenu(menuId); _OnSelection(menuId, -1, onSelection); } FoxInfo myFoxInfo[] = { {"ONLOAD", (FPFI) activateMenu, CALLONLOAD, ""}, {"ONUNLOAD", (FPFI) deactivateMenu, CALLONUNLOAD, ""}, }; FoxTable _FoxTable = { (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo }; |
Смотрите также
Справочное руководство
Процедура библиотеки API _DeActivateMenu( )Процедура библиотеки API _MenuId( )
Процедура библиотеки API _NewItem( )
Процедура библиотеки API _NewMenu( )
Процедура библиотеки API _OnSelection( )
Процедура библиотеки API _MenuInteract( )
Процедура библиотеки API _OnSelection( )
Концепции
Процедурs библиотеки API от A до ZПрочие ресурсы
Процедуры библиотеки API по категориямc Microsoft Corporation. All rights reserved. Microsoft is not reponsible for the contents of the translated help topics.