UDF > GUI > GuiMenu >


_GUICtrlMenu_CreatePopup

Cr�e un menu d�roulant, un sous-menu ou un raccourci

#include <GuiMenu.au3>
_GUICtrlMenu_CreatePopup ( [$iStyle = $MNS_CHECKORBMP] )

Param�tre

$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

Valeur de retour

Succ�s: Retourne le handle du menu cr��.
�chec: Retourne 0.

Remarque

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

En relation

_GUICtrlMenu_CreateMenu, _GUICtrlMenu_DestroyMenu

Voir aussi

Consultez CreatePopupMenu dans la librarie MSDN.

Exemple

#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