Type a page name and press Enter. You'll jump to the page if it exists, or you can create it if it doesn't.
To create a page in a module other than user32, prefix the name with the module name and a period.
EnumWindows (user32)
.
C# Signature:
/// <summary>
/// Enumerates all top-level windows on the screen by passing the handle to each window, in turn, to an
/// application-defined callback function. <see cref="EnumWindows" /> continues until the last top-level window is
/// enumerated or the callback function returns FALSE.
/// <para>
/// Go to https://msdn.microsoft.com/en-us/library/windows/desktop/ms633497%28v=vs.85%29.aspx for more
/// information
/// </para>
/// </summary>
/// <param name="lpEnumFunc">
/// C++ ( lpEnumFunc [in]. Type: WNDENUMPROC )<br />A pointer to an application-defined callback
/// function. For more information, see
/// <see cref="!:https://msdn.microsoft.com/en-us/library/windows/desktop/ms633498%28v=vs.85%29.aspx">EnumWindowsProc</see>
/// .
/// </param>
/// <param name="lParam">
/// C++ ( lParam [in]. Type: LPARAM )<br />An application-defined value to be passed to the callback
/// function.
/// </param>
/// <returns>
/// <c>true</c> if the return value is nonzero., <c>false</c> otherwise. If the function fails, the return value
/// is zero.<br />To get extended error information, call GetLastError.<br />If <see cref="EnumWindowsProc" /> returns
/// zero, the return value is also zero. In this case, the callback function should call SetLastError to obtain a
/// meaningful error code to be returned to the caller of <see cref="EnumWindows" />.
/// </returns>
/// <remarks>
/// The <see cref="EnumWindows" /> function does not enumerate child windows, with the exception of a few
/// top-level windows owned by the system that have the WS_CHILD style.
/// <para />
/// This function is more reliable than calling the
/// <see cref="!:https://msdn.microsoft.com/en-us/library/windows/desktop/ms633515%28v=vs.85%29.aspx">GetWindow</see>
/// function in a loop. An application that calls the GetWindow function to perform this task risks being caught in an
/// infinite loop or referencing a handle to a window that has been destroyed.<br />Note For Windows 8 and later,
/// EnumWindows enumerates only top-level windows of desktop apps.
/// </remarks>
[DllImport("user32.dll")]
[return: MarshalAs(UnmanagedType.Bool)]
static extern bool EnumWindows(EnumWindowsProc lpEnumFunc, IntPtr lParam);
VB.NET Signature:
<DllImport("user32.dll", SetLastError:=True, CharSet:=CharSet.Auto)> _
Private Shared Function EnumWindows(
ByVal lpEnumFunc As EnumWindowsProc, _
ByVal lParam As IntPtr) As Boolean
End Function
Sample code demonstrating the passing of an object to the enum proc
Oftentimes you'll want to have the EnumProc retrieve some data from a particular window and return it.
You can do this by:
Defining a class to hold your custom data, and
Using a ref to that class in the EnumWindows() signature.
using System.Runtime.InteropServices;
using System.Text;
public class WndSearcher
{
public static IntPtr SearchForWindow(string wndclass, string title)
{
SearchData sd = new SearchData { Wndclass=wndclass, Title=title };
EnumWindows(new EnumWindowsProc(EnumProc), ref sd);
return sd.hWnd;
}
public static bool EnumProc(IntPtr hWnd, ref SearchData data)
{
// Check classname and title
// This is different from FindWindow() in that the code below allows partial matches
StringBuilder sb = new StringBuilder(1024);
GetClassName(hWnd, sb, sb.Capacity);
if (sb.ToString().StartsWith(data.Wndclass))
{
sb = new StringBuilder(1024);
GetWindowText(hWnd, sb, sb.Capacity);
if (sb.ToString().StartsWith(data.Title))
{
data.hWnd = hWnd;
return false; // Found the wnd, halt enumeration
}
}
return true;
}
public class SearchData
{
// You can put any dicks or Doms in here...
public string Wndclass;
public string Title;
public IntPtr hWnd;
}
[DllImport("user32.dll", SetLastError = true, CharSet = CharSet.Auto)]
public static extern int GetClassName(IntPtr hWnd, StringBuilder lpClassName, int nMaxCount);
[DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
public static extern int GetWindowText(IntPtr hWnd, StringBuilder lpString, int nMaxCount);
}
Then you'd call:
// If you're viewing this page with IE, this *should* return the hwnd of the browser
IntPtr hWnd = WndSearcher.SearchForWindow("IEFrame", "pinvoke.net: EnumWindows");
I clicked on the link for EnumWnd on page "http://pinvoke.net/default.aspx/user32/EnumWindows.html" and it took me here?
10/1/2019 8:54:38 AM - -174.17.41.9
http://mwinapi.sourceforge.net/
3/31/2008 6:53:29 AM - -217.54.254.83
TODO - a short description
3/16/2007 8:24:06 AM - anonymous
TODO - a short description
3/16/2007 8:24:06 AM - anonymous
TODO - a short description
3/16/2007 8:24:06 AM - anonymous
The EnumWindows API
3/20/2019 10:44:34 AM - -98.152.226.218
Please edit this page!
Do you have...
helpful tips or sample code to share for using this API in managed code?
corrections to the existing content?
variations of the signature you want to share?
additional languages you want to include?
Select "Edit This Page" on the right hand toolbar and edit it! Or add new pages containing supporting types needed for this API (structures, delegates, and more).