Wie lässt sich das Handle eines Fensters anhand dessen Fenstertitel ermitteln? Leider funktioniert das nur dann korrekt, wenn man den exakten Fenstertitel kennt, wobei sogar die Groß-/Kleinschreibung beachtet werden muss! Was aber, wenn man bspw. nur den Anfang des Fenstertitels weiß? Kopieren Sie nachfolgenden Code in ein Modul: Option Explicit ' benötigte API-Deklarationen Private Declare Function FindWindow Lib "user32" _ Alias "FindWindowA" ( _ ByVal lpClassName As String, _ ByVal lpWindowName As String) As Long Private Declare Function GetWindowTextLength Lib "user32" _ Alias "GetWindowTextLengthA" ( _ ByVal hwnd As Long) As Long Private Declare Function GetWindowText Lib "user32" _ Alias "GetWindowTextA" ( _ ByVal hwnd As Long, _ ByVal lpString As String, _ ByVal cch As Long) As Long Private Declare Function GetWindow Lib "user32" ( _ ByVal hwnd As Long, _ ByVal wCmd As Long) As Long Private Const GW_HWNDNEXT = 2 ' Ermittelt das Handle eines Fensters anhand dessen Fenstertitel ' ' sTitel: muss nicht der exakte Fenstertitel sein ' hier kann bspw. auch nur der Anfang des Fenstertitel ' angegeben werden, z.B.: Fenstertitel* ' Public Function FindWindowHandle(ByVal sTitle As String) As Long Dim lngHWnd As Long Dim sText As String ' alle Fenster durchlaufen lngHWnd = FindWindow(vbNullString, vbNullString) Do While lngHWnd <> 0 ' Fensterttitel ermitteln sText = GetWindowTitle(lngHWnd) If Len(sText) > 0 And LCase$(sText) Like LCase$(sTitle) Then FindWindowHandle = lngHWnd: Exit Do End If ' Nächstes Fenster lngHWnd = GetWindow(lngHWnd, GW_HWNDNEXT) Loop End Function ' Hilfsfunktion zum Ermitteln des Fenstertitels Public Function GetWindowTitle(ByVal hwnd As Long) As String Dim lResult As Long Dim sTemp As String lResult = GetWindowTextLength(hwnd) + 1 sTemp = Space(lResult) lResult = GetWindowText(hwnd, sTemp, lResult) GetWindowTitle = Left(sTemp, Len(sTemp) - 1) End Function Aufrufbeispiel: Dim hWnd As Long hWnd = FindWindowHandle("MyApplication [*") If hWnd <> 0 Then ... Erweiterung: Fügen Sie hierzu noch folgende API-Funktion in das Modul ein: Private Declare Function SetForegroundWindow Lib "user32" ( _ ByVal hwnd As Long) As Long Und hier der Code: Dim hWnd As Long ' Fensterhandle suchen hWnd = FindWindowHandle("Fenstertitel") If hWnd <> 0 Then ' Fenster aktivieren und in den Vordergrund holen SetForegroundWindow hWnd End If Dieser Tipp wurde bereits 31.731 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 Mai 2024 Hermann Röttger Wochentage eines Datumsbereichs ermitteln Wochentage eines Datumsbereichs ermitteln, optional mit Feiertagsberechnung Neu! sevEingabe 3.0 Einfach stark! Ein einziges Eingabe-Control für alle benötigten Eingabetypen und -formate, inkl. Kalender-, Taschenrechner und Floskelfunktion, mehrspaltige ComboBox mit DB-Anbindung, ImageComboBox 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. |