Rubrik: Oberfläche · Menüs | VB-Versionen: VB5, VB6 | 26.01.04 |
Status-Infos für Menü-Einträge Wie man zusätzliche Informationen zu Menü-Einträgen beispielsweise in der Statusbar anzeigt, das erfahren Sie in diesem Tipp. | ||
Autor: Dieter Otter | Bewertung: | Views: 12.282 |
www.tools4vb.de | System: Win9x, WinNT, Win2k, WinXP, Win7, Win8, Win10, Win11 | Beispielprojekt auf CD |
In vielen Anwendungen werden zusätzliche Informationen zu Menü-Einträgen in einer Statusbar angezeigt. Diese Infos erscheinen immer dann, wenn ein Menü geöffnet ist und ein Menü-Eintrag mit der Maus oder per Tastatur selektiert wird.
Wie auch Sie das in Ihrer Anwendung realisieren können, das zeigen wir Ihnen heute. Hierzu muss die Form "gesubclassed" werden, d.h. wir fangen alle Windows-Nachrichten ab und prüfen, ob sich darunter "zufällig" die Nachricht "WM_MENUSELECT" befindet.
Erstellen Sie ein neues Projekt und fügen nachfolgenden Code in ein Modul ein.
Option Explicit ' Benötigte API-Deklarationen Private 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 Private Declare Function SetWindowLong Lib "user32" _ Alias "SetWindowLongA" ( _ ByVal hwnd As Long, _ ByVal nIndex As Long, _ ByVal dwNewLong As Long) As Long Private Const GWL_WNDPROC = (-4) Private Const WM_MENUSELECT = &H11F Private OldWndProc As Long
' Subclassing starten Public Sub StartSubclass(ByVal hwnd As Long) OldWndProc = SetWindowLong(hwnd, GWL_WNDPROC, AddressOf NewWindowProc) End Sub
' Subclassing beenden Sub EndSubclass(ByVal hwnd As Long) SetWindowLong hwnd, GWL_WNDPROC, OldWndProc End Sub
' Windows-Message abfangen Public Function NewWindowProc(ByVal hwnd As Long, _ ByVal uMsg As Long, _ ByVal wParam As Long, _ ByVal lparam As Long) As Long Dim sInfo As String Dim LoWord As Long If uMsg = WM_MENUSELECT Then ' Balken wird auf Menü bewegt LoWord = CLng("&H" & Right$(Right$("00000000" & Hex$(wParam), 8), 4)) Select Case LoWord Case 2 sInfo = "Neues Dokument erstellen..." Case 3 sInfo = "Bestehenden Dokument öffnen..." Case 4 sInfo = "Aktuelles Dokument speichern..." Case 6 sInfo = "Anwendung beenden..." End Select ' Statustext anzeigen Form1.StatusBar1.SimpleText = sInfo Exit Function End If ' Nachricht an die ursprüngliche ' Fensterprozedur weiterleiten NewWindowProc = CallWindowProc(OldWndProc, hwnd, uMsg, _ wParam, ByVal lparam) End Function
Platzieren Sie eine StatusBar auf die Form1 und erstellen mit Hilfe des VB-Menüeditors ein Menu wie nachfolgend dargestellt:
Fügen Sie jetzt noch nachfolgenden Code in den Codeteil der Form ein und starten Sie das Projekt:
' Subclassing starten Private Sub Form_Load() StartSubclass Me.hwnd End Sub
' Subclassing korrekt beenden Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer) EndSubclass Me.hwnd End Sub