Das nachfolgende Beispiel zeigt, wie man neue Einträge dem Systemmenü eines Formulars hinzufügen kann. Das Ausführen einer bestimmten Aktion nach dem Klicken auf einen dieser neuen Einträge setzt Subclassing voraus, d.h. die Windows-Systemmeldung muß von Ihrer Anwendung entsprechend "abgefangen" und ausgewertet werden. ' zunächst die benötigten API-Deklarationen ' Der nachfolgende Code muß in ein Modul eingefügt werden Declare Function CallWindowProc Lib "user32" _ Alias "CallWindowProcA" ( _ ByVal lpPrevWndFunc As Long, _ ByVal hWnd As Long, _ ByVal MSG As Long, _ ByVal wParam As Long, _ ByVal lParam As Long) As Long Declare Function SetWindowLong Lib "user32" _ Alias "SetWindowLongA" ( _ ByVal hWnd As Long, _ ByVal nIndex As Long, _ ByVal dwNewLong As Long) As Long Declare Function GetSystemMenu Lib "user32" ( _ ByVal hWnd As Long, _ ByVal bRevert As Long) As Long Declare Function AppendMenu Lib "user32" _ Alias "AppendMenuA" ( _ ByVal hMenu As Long, _ ByVal wFlags As Long, _ ByVal wIDNewItem As Long, _ ByVal lpNewItem As Any) As Long Declare Function DeleteMenu Lib "user32" ( _ ByVal hMenu As Long, _ ByVal nPosition As Long, _ ByVal wFlags As Long) As Long Public Const MF_STRING = &H0& Public Const MF_BYPOSITION = &H400& Public Const GWL_WNDPROC = (-4&) Public Const WM_SYSCOMMAND = &H112 Dim PrevWndProc As Long ' Wird benötigt für das Aufrufen der WWW-Adresse Private Declare Function ShellExecute Lib "shell32.dll" _ Alias "ShellExecuteA" ( _ ByVal hWnd As Long, _ ByVal lpOperation As String, _ ByVal lpFile As String, _ ByVal lpParameters As String, _ ByVal lpDirectory As String, _ ByVal nShowCmd As Long) As Long ' Systemmeldungen an die Prozedur WndProc "umleiten" Public Sub InitSubclassing(hWnd As Long) PrevWndProc = SetWindowLong(hWnd, GWL_WNDPROC, _ AddressOf WndProc) End Sub ' Subclassing beenden Public Sub EndSubclassing(hWnd As Long) Call SetWindowLong(hWnd, GWL_WNDPROC, PrevWndProc) End Sub ' Systemmeldung "abfangen" und auswerten Public Function WndProc(ByVal hWnd As Long, _ ByVal MSG As Long, ByVal wParam As Long, _ ByVal lParam As Long) As Long Dim Result As Long ' Klick auf einen Eintrag im Systemmenü If MSG = WM_SYSCOMMAND Then Select Case wParam Case &H200 ' Neuer Eintrag 1: www.vbarchiv.de Call ShellExecute(hWnd, "Open", _ "http://www.vbarchiv.de", "", "", 1) Case &H201 ' Neuer Eintrag 2: Info... MsgBox "Info..." End Select End If WndProc = CallWindowProc(PrevWndProc, hWnd, MSG, _ wParam, lParam) End Function Der nachfolgende Code bezieht sich auf das Formular, dessen Systemmenü angepasst werden soll. ' Handle des Systemmenüs Dim Handle As Long Private Sub Form_Load() ' Handle des Systemmenüs Handle = GetSystemMenu(hWnd, False) ' Subclassing starten InitSubclassing Me.hWnd ' Systemmenü modifizieren ' Maximieren entfernen DeleteMenu Handle, 4, MF_BYPOSITION ' Einfügen: www.vbarchiv.de AppendMenu Handle, MF_STRING, &H200, "www.vbarchiv.de" ' Einfügen: Info... AppendMenu Handle, MF_STRING, &H201, "&Info..." End Sub Private Sub Form_Unload(Cancel As Integer) ' Subclassing beenden EndSubclassing Me.hWnd End Sub Dieser Tipp wurde bereits 14.583 mal aufgerufen. Voriger Tipp | Zufälliger Tipp | Nächster Tipp
Anzeige
Diesen und auch alle anderen Tipps & Tricks finden Sie auch auf unserer aktuellen vb@rchiv Vol.6 (einschl. Beispielprojekt!) Ein absolutes Muss - Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! - nahezu alle Tipps & Tricks und Workshops mit Beispielprojekten - Symbol-Galerie mit mehr als 3.200 Icons im modernen Look Weitere Infos - 4 Entwickler-Vollversionen (u.a. sevFTP für .NET), Online-Update-Funktion u.v.m. |
vb@rchiv CD Vol.6 Geballtes Wissen aus mehr als 8 Jahren vb@rchiv! Online-Update-Funktion Entwickler-Vollversionen u.v.m. Tipp des Monats April 2024 Skyfloy Chart von Microsoft und dazu noch gratis Tutorial für Microsoft Chart Controls für Microsoft .NET Framework 3.5 sevOutBar 4.0 Vertikale Menüleisten á la Outlook Erstellen von Outlook ähnlichen Benutzer- interfaces - mit beliebig vielen Gruppen und Symboleinträgen. Moderner OfficeXP-Style mit Farbverläufen, Balloon-Tips, u.v.m. |
||||||||||||||||
Microsoft, Windows und Visual Basic sind entweder eingetragene Marken oder Marken der Microsoft Corporation in den USA und/oder anderen Ländern. Weitere auf dieser Homepage aufgeführten Produkt- und Firmennamen können geschützte Marken ihrer jeweiligen Inhaber sein. |