_NewMenu( ) (Rutina de biblioteca API)
Crea un nuevo menú del tipo especificado.
int _NewMenu(int mtype, MENUID menuid)
int mtype; /* Menu type. */
MENUID menuid; /* Menu identifier. */
Observaciones
Puede especificar MPOPUP o MBAR como parámetro mtype . El identificador del menú debe ser único.
Utilice _GetNewMenuId( ) para obtener un identificador del menú disponible. _NewMenu( ) devuelve 0 si logra crear un nuevo menú. Si no lo crea, _NewMenu( ) devuelve un entero negativo cuyo valor absoluto es un número de error de Visual FoxPro.
Para obtener más información acerca de cómo crear una biblioteca API e integrarla con Visual FoxPro, vea Acceso a la API de Visual FoxPro.
Ejemplo
El ejemplo siguiente emplea _NewMenu( ) para crear un menú.
Código Visual FoxPro
SET LIBRARY TO NEWMENU
Código 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
};
Vea también
_ActivateMenu( ) (Rutina de biblioteca API) | _GetNewMenuId( ) (Rutina de biblioteca API) | _GetNewMenuId( ) (Rutina de biblioteca API) | Acceso a la API de Visual FoxPro