VBcoders Guest



Don't have an account yet? Register
 


Forgot Password?



Getting all windows

by Tim Fischer (2 Submissions)
Category: Windows API Call/Explanation
Compatability: Visual Basic 3.0
Difficulty: Intermediate
Date Added: Wed 3rd February 2021
Rating: (3 Votes)

This code explains how to use the API call EnumWindows to change captions, minimize all windows, or anything you need to do with a handle.
I explain many things you can do with the base of the code.

Assumes
All explanation is in the module with the base function. Use the following to call get windows: Call EnumWindows(AddressOf EnumWindowProc, &H0)
API Declarations
Public Const MAX_PATH = 260
Public Const SW_HIDE = 0
Public Const SW_SHOW = 5
Public Const SW_MAXIMIZE = 3
Public Const SW_MINIMIZE = 6
Public Const SW_NORMAL = 1
Public Const SW_RESTORE = 9
Public Const WM_CLOSE = &H10
Public Declare Function SendMessage Lib "user32" _
Alias "SendMessageA" (ByVal hwnd As Long, _
ByVal wMsg As Long, _
ByVal wParam As Integer, _
ByVal lParam As Long) As Long
Public Declare Function ShowWindow Lib "user32" _
(ByVal hwnd As Long, _
ByVal nCmdShow As Long) As Long
Public Declare Function IsWindowVisible Lib "user32" _
(ByVal hwnd As Long) As Long
Public Declare Function EnumWindows _
Lib "user32" (ByVal lpEnumFunc As Long, _
ByVal lParam As Long) As Long

Public Declare Function GetClassName Lib "user32" _
Alias "GetClassNameA" _
(ByVal hwnd As Long, _
ByVal lpClassName As String, _
ByVal nMaxCount As Long) As Long
Public Declare Function GetWindowText Lib "user32" _
Alias "GetWindowTextA" _
(ByVal hwnd As Long, _
ByVal lpString As String, _
ByVal cch As Long) As Long
Public Function EnumWindowProc(ByVal hwnd As Long, ByVal lParam As Long) As Long


Dim sTitle As String
Dim sClass As String
Dim sLoc As String


sTitle = Space$(MAX_PATH)
sClass = Space$(MAX_PATH)
sLoc = Space$(MAX_PATH)
Call GetClassName(hwnd, sClass, MAX_PATH) 'sClass
Call GetWindowText(hwnd, sTitle, MAX_PATH) 'and sTitle
'are given
'their values through
'these functions

'You now have a handle, caption, and class name.
'If you wanted to minimize all windows you could do
'the following:

'ShowWindow hwnd, SW_MINIMIZE

'In Windows it is not this simple though.
'There are many programs not meant to be hidden
'like tooltips and OLE programs. You can implement
'the IsWindowVisible function to check if it is
'supposed to be minimized:

'If IsWindowVisible(hwnd) Then
'ShowWindow hwnd, SW_MINIMIZE
'End if

'You can change the SW_MINIMZE to any other constant
'to make it maximize, restore to normal, or any other
'combo. To close the windows you can do this:

'If IsWindowVisible(hwnd) Then
'SendMessage hwnd, WM_CLOSE, 0, 0
'End if

'You can also change captions and many other things
'knowing the handle. The one thing I have come across
'is getting the path of an application. This is not
'possible through VB but can be achieved through DLLs.
'I have come across a very good one created by
'Jürgen Thümmler .



EnumWindowProc = 1 'To keep EnumWindows from
'continuing it's loop, have
'your function return 1.
End Function

Rate Getting all windows

'You can place the function in any event. 
'Call function like this:
Call EnumWindows(AddressOf EnumWindowProc, &H0)

Download this snippet    Add to My Saved Code

Getting all windows Comments

No comments have been posted about Getting all windows. Why not be the first to post a comment about Getting all windows.

Post your comment

Subject:
Message:
0/1000 characters