Frage: Wie kommt man von der Prozess-ID zum Fenstertitel der dazugehörigen Anwendung? ' benötigte API-Deklarationen Private Declare Function GetWindowThreadProcessId Lib "user32" ( _ ByVal hwnd As Long, _ lpdwProcessId As Long) As Long Private Declare Function FindWindow Lib "user32" _ Alias "FindWindowA" ( _ ByVal lpClassName As String, _ ByVal lpWindowName As String) As Long Private Declare Function GetWindow Lib "user32" ( _ ByVal hwnd As Long, _ ByVal wCmd As Long) As Long Private Declare Function GetParent Lib "user32" ( _ 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 Const GW_HWNDNEXT = 2 ' Ermittelt das Fensterhandle anhand einer Prozess-ID Private Function ProcID2hWnd(ByVal ProcID As Long) As Long ' alle Fenster durchlaufen und nach Process-ID suchen Dim lngHWnd As Long Dim lngProcTaskID As Long lngHWnd = FindWindow(vbNullString, vbNullString) Do While lngHWnd <> 0 ' Existiert kein Eltern-Fenster, dann ProcssID ' ermitteln und vergleichen If GetParent(lngHWnd) = 0 Then GetWindowThreadProcessId lngHWnd, lngProcTaskID ' Handelt es sich um den gesuchten Prozess? If lngProcTaskID = ProcID Then ' Fenster-Handle zurückgeben und Schleife ' verlassen! ProcID2hWnd = lngHWnd Exit Do End If End If ' Nächstes Fenster lngHWnd = GetWindow(lngHWnd, GW_HWNDNEXT) Loop End Function Beispiel für den Aufruf: Dim nHWnd As Long Dim sTitle As String Dim nResult As Long Dim nProcessID As Long ' Notepad starten nProcessID = Shell("notepad.exe") ' Fensterhandle anhand ProcessID ermitteln nHWnd = ProcID2hWnd(nProcessID) If nHWnd <> 0 Then ' und jetzt den Fenstertitel auslesen sTitle = Space$(255) nResult = GetWindowText(nHWnd, sTitle, Len(sTitle)) If nResult > 0 Then sTitle = Left$(sTitle, nResult) MsgBox sTitle End If End If Dieser Tipp wurde bereits 23.780 mal aufgerufen.
Anzeige
![]() ![]() ![]() (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 sevWizard für VB5/6 ![]() Professionelle Assistenten im Handumdrehen Erstellen Sie eigene Assistenten (Wizards) im Look & Feel von Windows 2000/XP - mit allem Komfort und zwar in Windeseile :-) |
||||||||||||||||
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. |