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.639 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. |
sevISDN 1.0 Überwachung aller eingehender Anrufe! Die DLL erkennt alle über die CAPI-Schnittstelle eingehenden Anrufe und teilt Ihnen sogar mit, aus welchem Ortsbereich der Anruf stammt. Weitere Highlights: Online-Rufident, Erkennung der Anrufbehandlung u.v.m. Tipp des Monats März 2024 Dieter Otter UTF-8 Konvertierung von Dateien und Strings VB6 selbst verfügt über keine Funktionen zur UTF-8 Konvertierung von Daten. Mit Hilfe des ADODB.Stream-Objekts lassen sich diese fehlenden Funktionen aber schnell nachrüsten. sevAniGif (VB/VBA) Anzeigen von animierten GIF-Dateien Ab sofort lassen sich auch unter VB6 und VBA (Access ab Version 2000) animierte GIF-Grafiken anzeigen und abspielen, die entweder lokal auf dem System oder auf einem Webserver gespeichert sind. |
||||||||||||||||
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. |