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 32.195 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 Januar 2025 Dieter Otter Zeilen einer MultiLine-TextBox ermitteln (VB.NET) Dieser Zipp zeigt, wie man die Zeilen einer MultiLine-TextBox exakt so ermitteln kann, wie diese auch in der TextBox dargestellt werden. Neu! sevPopUp 2.0 Dynamische Kontextmenüs! Erstellen Sie mit nur wenigen Zeilen Code Kontextmenüs dynamisch zur Laufzeit. Vordefinierte Styles (XP, Office, OfficeXP, Vista oder Windows 8) erleichtern die Anpassung an die eigenen Anwendung... |
||||||||||||||||
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. |