Копирует текст строки меню или заголовка меню в буфер, указанный параметром text.
void _GetItemText(MENUID menuid, ITEMID itemid, char FAR *text) MENUID menuid; /* Идентификатор меню. */ ITEMID itemid; /* Идентификатор элемента меню. */ char FAR *text; /* Адрес буфера для занесения текста. */ |
Примечания
Длина буфера должна составлять не менее 80 байтов.
Для получения дополнительной информации о том, как создавать библиотеку API и интегрировать её в Visual FoxPro, смотрите Доступ к API Visual FoxPro.
Пример
В следующем примере создается меню, содержащее три элемента, а затем с помощью _GetItemText( ) извлекается текст каждого элемента.
Код Visual FoxPro
![]() | |
---|---|
SET LIBRARY TO GETITEXT |
Код C
![]() | |
---|---|
#include <pro_ext.h> FAR GetItemTextEx(ParamBlk FAR *parm) { MENUID menuId; ITEMID itemId; Point loc; char FAR *itemText; 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); if ((itemText = _Alloca(80)) == 0) { _Error(182); // "Insufficient memory" } _GetItemText(menuId, _GetItemId(menuId, 0), itemText); _PutStr("\nItem text of 1st item = "); _PutStr(itemText); _GetItemText(menuId, _GetItemId(menuId, 1), itemText); _PutStr("\nItem text of 2nd item = "); _PutStr(itemText); _GetItemText(menuId, _GetItemId(menuId, 2), itemText); _PutStr("\nItem text of 3rd item = "); _PutStr(itemText); _Execute("WAIT WINDOW"); _DisposeMenu(menuId); } FoxInfo myFoxInfo[] = { {"ONLOAD", (FPFI) GetItemTextEx, CALLONLOAD, ""}, }; FoxTable _FoxTable = { (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo }; |