_DisposeMenu( ), API-Bibliotheksroutine

Gibt das angegebene Menü einschließlich aller Ereignisse sowie den mit diesem Menü verbundenen Speicher frei.

void _DisposeMenu(MENUID menuid)
MENUID menuid;            /* Menu identifier. */

Hinweise

_DisposeMenu( ) gibt keine Untermenüs frei, die mit dem Menü verbunden sind.

Weitere Informationen zum Erstellen einer API-Bibliothek und ihrer Integration in Visual FoxPro finden Sie unter Zugreifen auf die Visual FoxPro-API.

Beispiel

Im folgenden Beispiel wird _DisposeMenu( ) aufgerufen, nachdem der Benutzer einen Menüeintrag ausgewählt hat.

Visual FoxPro-Code

SET LIBRARY TO DISPMENU

C-Code

#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 onSelection(long menuId, long itemId)
{
   _PutStr("\nitemId = "); putLong(itemId);
   _DisposeMenu(menuId);
}

FAR activateMenu(ParamBlk FAR *parm)
{
   MENUID menuId;
   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, ""},
};
FoxTable _FoxTable = {
   (FoxTable FAR *) 0, sizeof(myFoxInfo)/sizeof(FoxInfo), myFoxInfo
};

Siehe auch

_GetNewMenuId( ), API-Bibliotheksroutine | _GetNewMenuId( ), API-Bibliotheksroutine | _NewMenu( ), API-Bibliotheksroutine | Zugreifen auf die Visual FoxPro-API