Cr�e un menu d�roulant, un sous-menu ou un raccourci
#include <GuiMenu.au3>
_GUICtrlMenu_CreatePopup ( [$iStyle = $MNS_CHECKORBMP] )
$iStyle | [optionnel] Style du menu. Peut prendre une ou plusieurs des valeurs suivantes : $MNS_AUTODISMISS - La menu se ferme automatiquement lorsque la souris reste en dehors du menu pendant 10 secondes $MNS_CHECKORBMP - Le m�me espace est r�serv� pour la case � cocher et le bitmap (valeur par d�faut) $MNS_DRAGDROP - Les �l�ments du menu sont cibles d'un Drop OLE ou sources d'un Drag $MNS_MODELESS - Le menu est une bo�te modale $MNS_NOCHECK - Pas d'espace est r�serv� � gauche d'un �l�ment pour une case � cocher $MNS_NOTIFYBYPOS - Le propri�taire du menu re�oit un message WM_MENUCOMMAND � la place d'un message WM_COMMAND pour les s�lections |
Succ�s: | Retourne le handle du menu cr��. |
�chec: | Retourne 0. |
Les ressources de menu qui sont affect�s � une fen�tre sont lib�r�s automatiquement. Si le menu n'est pas affect� � une fen�tre, une application doit lib�rer les ressources syst�me associ�es au menu avant la fermeture.
Une application lib�re les ressources d'un menu en appelant la fonction _GUICtrlMenu_DestroyMenu().
$MNS_NOTIFYBYPOS est un style d'en-t�te de menu et n'a aucun effet lorsqu'elle est appliqu�e � des sous-menus
_GUICtrlMenu_CreateMenu, _GUICtrlMenu_DestroyMenu
Consultez CreatePopupMenu dans la librarie MSDN.
#include <GUIConstantsEx.au3> #include <GuiMenu.au3> #include <WinAPIError.au3> #include <WindowsConstants.au3> Global Enum $e_idOpen = 1000, $e_idSave, $e_idInfo Example() Func Example() ; Cr�e une GUI GUICreate("Menu", 400, 300) GUISetState(@SW_SHOW) ; Cr�e un gestionnaire de messages GUIRegisterMsg($WM_COMMAND, "WM_COMMAND") GUIRegisterMsg($WM_CONTEXTMENU, "WM_CONTEXTMENU") ; Boucle jusqu'� ce que l'utilisateur quitte. Do Until GUIGetMsg() = $GUI_EVENT_CLOSE EndFunc ;==>Example ; R�pond aux messages WM_COMMAND Func WM_COMMAND($hWnd, $iMsg, $wParam, $lParam) #forceref $hWnd, $iMsg, $lParam Switch $wParam Case $e_idOpen _WinAPI_ShowMsg("Open") Case $e_idSave _WinAPI_ShowMsg("Save") Case $e_idInfo _WinAPI_ShowMsg("Info") EndSwitch EndFunc ;==>WM_COMMAND ; G�re les messages WM_CONTEXTMENU Func WM_CONTEXTMENU($hWnd, $iMsg, $wParam, $lParam) #forceref $hWnd, $iMsg, $lParam Local $hMenu $hMenu = _GUICtrlMenu_CreatePopup() _GUICtrlMenu_InsertMenuItem($hMenu, 0, "Open", $e_idOpen) _GUICtrlMenu_InsertMenuItem($hMenu, 1, "Save", $e_idSave) _GUICtrlMenu_InsertMenuItem($hMenu, 3, "", 0) _GUICtrlMenu_InsertMenuItem($hMenu, 3, "Info", $e_idInfo) _GUICtrlMenu_TrackPopupMenu($hMenu, $wParam) _GUICtrlMenu_DestroyMenu($hMenu) Return True EndFunc ;==>WM_CONTEXTMENU