C# Windows Api的一些方法 封装 以及 常用参数
using System;
using System.Collections.Generic;
using System.Drawing;
using System.Diagnostics;
using System.Windows.Forms;
using System.Runtime.InteropServices;
using System.Text;
namespace WindowsApi
{
public class ApiMethod
{
#region Dll Import
[DllImport("User32.dll", EntryPoint = "FindWindow")]
private static extern IntPtr FindWindow(string lpClassName, string lpWindowName);
[DllImport("user32.dll", EntryPoint = "FindWindowEx")]
private static extern IntPtr FindWindowEx(IntPtr hwndParent, IntPtr hwndChildAfter, string lpszClass, string lpszWindow);
[DllImport("User32.dll", EntryPoint = "SendMessage")]
private static extern int SendMessage(IntPtr hWnd, int Msg, IntPtr wParam, string lParam);
[DllImport("User32.dll", EntryPoint = "SendMessage")]
public static extern int SendMessage(IntPtr hWnd, int Msg, int wParam, int lParam);
[DllImport("User32.dll", EntryPoint = "SendMessage")]
public static extern int SendMessage(IntPtr hWnd, int Msg, int wParam, IntPtr lParam);
[DllImport("user32.dll")]
public static extern bool SetWindowPos(IntPtr hWnd, int hWndInsertAfter, int X, int Y, int cx, int cy, int uFlags);
/// <summary>
/// 获得窗体大小 得到的矩形 为窗体起始 到结束的 坐标。
/// </summary>
/// <param name="hwnd">窗体句柄</param>
/// <param name="lpRect">装数据的矩形对象</param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "GetWindowRect")]
public static extern int GetWindowRect(IntPtr hwnd, ref System.Drawing.Rectangle lpRect);
[DllImport("user32.dll", EntryPoint = "GetWindow")]
public static extern IntPtr GetWindow(IntPtr hwnd, int cmd);
/// <summary>
/// 获得窗体 用户区域大小 其他同 GetWindowRect
/// </summary>
/// <param name="hwnd"></param>
/// <param name="lpRect"></param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "GetClientRect")]
public static extern int GetClientRect(IntPtr hwnd, ref System.Drawing.Rectangle lpRect);
[DllImport("user32.dll", EntryPoint = "GetDlgItem")]
public static extern IntPtr GetDlgItem(IntPtr hwnd, int cmd);
/// <summary>
/// 通过全屏幕坐标获取控件句柄
/// </summary>
/// <param name="w">坐标</param>
/// <returns>坐标位置的控件句柄</returns>
[DllImport("user32.dll", EntryPoint = "WindowFromPoint")]
public static extern IntPtr WindowFromPoint(Point w);
/// <summary>
/// 移动窗体的Windows函数
/// </summary>
/// <param name="hWnd">窗体句柄</param>
/// <param name="x">新坐标起点x坐标</param>
/// <param name="y">先坐标末点y坐标</param>
/// <param name="nWidth">新宽度</param>
/// <param name="nHeight">新高度</param>
/// <param name="BRePaint">是否移动后重绘制窗体(如果选false会导致桌面窗体图像滞留)</param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "MoveWindow")]
public static extern bool MoveWindow(IntPtr hWnd, int x, int y, int nWidth, int nHeight, bool BRePaint);
[DllImport("user32.dll", EntryPoint = "ShowWindow", CharSet = CharSet.Auto)]
public static extern int ShowWindow(IntPtr hWnd, int code);
/// <summary>
/// 使指定窗体获得键盘输入焦点
/// </summary>
/// <param name="hWnd">窗体句柄</param>
/// <returns>若函数调用成功,则返回原先拥有键盘焦点的窗口句柄。若hWnd参数无效或窗口未与调用线程的消息队列相关,则返回值为NULL</returns>
[DllImport("user32.dll", EntryPoint = "SetFocus")]
public static extern IntPtr SetFocus(IntPtr hWnd);
[DllImport("user32.dll", EntryPoint = "GetFocus")]
public static extern IntPtr GetFocus();
[DllImport("user32.dll", EntryPoint = "GetCapture")]
public static extern IntPtr GetCapture();
/// <summary>
/// 移动鼠标到指定位置
/// </summary>
/// <param name="x">指定位置x坐标</param>
/// <param name="y">指定位置y坐标</param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "SetCursorPos")]
public static extern bool SetCursorPos(int x, int y);
/// <summary>
/// 鼠标事件
/// </summary>
/// <param name="dwFlags">事件名称</param>
/// <param name="dx">x位移</param>
/// <param name="dy">y位移</param>
/// <param name="dwData"></param>
/// <param name="dwExtraInfo"></param>
[DllImport("user32.dll", EntryPoint = "mouse_event")]
public extern static void mouse_event(int dwFlags, int dx, int dy, int dwData, IntPtr dwExtraInfo);
/// <summary>
/// 获取当前活跃窗口
/// </summary>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "GetActiveWindow")]
public static extern IntPtr GetActiveWindow();
[DllImport("user32.dll", EntryPoint = "GetForegroundWindow")]
public static extern IntPtr GetForegroundWindow();
/// <summary>
/// 获取当前窗体最近一次活跃的窗口 获得messagebox
/// </summary>
/// <param name="hWnd"></param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "GetLastActivePopup")]
public static extern IntPtr GetLastActivePopup(IntPtr hWnd);
/// <summary>
/// 获得窗口句柄的编号
/// </summary>
/// <param name="hWnd"></param>
/// <param name="nlndex"></param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "GetWindowLong")]
public static extern long GetWindowLong(IntPtr hWnd, int nlndex);
/// <summary>
/// 得到此控件的类名
/// </summary>
/// <param name="hWnd"></param>
/// <param name="classname">接收数据的要首先给出空间</param>
/// <param name="nlndex">所要取得的最大字符数,如果设置为0 则什么都没有</param>
/// <returns></returns>
[DllImport("user32.dll", EntryPoint = "GetClassName")]
public static extern int GetClassName(IntPtr hWnd, StringBuilder classname, int nlndex);
public const int SRCCOPY = 0x00CC0020; // BitBlt dwRop parameter
[DllImport("gdi32.dll")]
public static extern bool BitBlt(IntPtr hObject, int nXDest, int nYDest, int nWidth, int nHeight, IntPtr hObjectSource, int nXSrc, int nYSrc, int dwRop);
[DllImport("gdi32.dll")]
public static extern IntPtr CreateCompatibleBitmap(IntPtr hDC, int nWidth, int nHeight);
[DllImport("gdi32.dll")]
public static extern IntPtr CreateCompatibleDC(IntPtr hDC);
[DllImport("gdi32.dll")]
public static extern bool DeleteDC(IntPtr hDC);
[DllImport("gdi32.dll")]
public static extern bool DeleteObject(IntPtr hObject);
[DllImport("gdi32.dll")]
public static extern IntPtr SelectObject(IntPtr hDC, IntPtr hObject);
[DllImport("user32.dll")]
public static extern void keybd_event(byte bVk, byte bScan, int dwFlags, int dwExtralnfo);
/// <summary>
/// 获取操作系统分辨率
/// </summary>
/// <param name="nIndex"></param>
/// <returns></returns>
[DllImport("user32.dll")]
public static extern int GetSystemMetrics(int nIndex);
[DllImport("user32.dll")]
public static extern IntPtr GetDesktopWindow();
[DllImport("user32.dll")]
public static extern IntPtr GetWindowDC(IntPtr hWnd);
[DllImport("user32.dll")]
public static extern IntPtr GetWindowThreadProcessId(IntPtr hWnd, ref int lpdwProcessId);
[DllImport("user32.dll")]
public static extern IntPtr ReleaseDC(IntPtr hWnd, IntPtr hDC);
#endregion
#region 封装方法
/// <summary>
/// 窗口置前
/// </summary>
/// <param name="hWnd">窗口句柄</param>
public static void SetWindowPos(IntPtr hWnd)
{
SetWindowPos(hWnd, -1, 0, 0, 0, 0, 0x4000 | 0x0001 | 0x0002);
}
/// <summary>
/// 通过进程名获得主窗口句柄
/// </summary>
/// <param name="processName">进程名</param>
/// <returns>窗口句柄对象</returns>
public static IntPtr GetProcessMainFormHandle(string processName)
{
Process pro = null;
Process[] pros = Process.GetProcessesByName(processName);
if (pros.Length > 0)
{
pro = pros[0];
}
IntPtr m_WindowHandle = IntPtr.Zero;
m_WindowHandle = pro.MainWindowHandle;
return m_WindowHandle;
}
/// <summary>
/// 获得桌面的图像
/// </summary>
/// <returns></returns>
public static Bitmap CaptureScreen()
{
return CaptureWindow(GetDesktopWindow());
}
public static Bitmap windowFullScreen()
{
//建立屏幕Graphics
Graphics grpScreen = Graphics.FromHwnd(IntPtr.Zero);
//根据屏幕大小建立位图
Bitmap bitmap = new Bitmap(Screen.PrimaryScreen.Bounds.Width, Screen.PrimaryScreen.Bounds.Height, grpScreen);
//建立位图相关Graphics
Graphics grpBitmap = Graphics.FromImage(bitmap);
//建立屏幕上下文
IntPtr hdcScreen = grpScreen.GetHdc();
//建立位图上下文
IntPtr hdcBitmap = grpBitmap.GetHdc();
//将屏幕捕获保存在图位中
BitBlt(hdcBitmap, 0, 0, bitmap.Width, bitmap.Height, hdcScreen, 0, 0, 0x00CC0020);
//关闭位图句柄
grpBitmap.ReleaseHdc(hdcBitmap);
//关闭屏幕句柄
grpScreen.ReleaseHdc(hdcScreen);
//释放位图对像
grpBitmap.Dispose();
//释放屏幕对像
grpScreen.Dispose();
//返回捕获位图
return bitmap;
}
/// <summary>
/// 通过窗体句柄获取此窗体的图像
/// </summary>
/// <param name="handle"></param>
/// <returns></returns>
public static Bitmap CaptureWindow(IntPtr handle)
{
// get te hDC of the target window
IntPtr hdcSrc = GetWindowDC(handle);
// get the size
Rectangle windowRect = new Rectangle();
GetWindowRect(handle, ref windowRect);
int width = windowRect.Width - windowRect.X;
int height = windowRect.Height - windowRect.Y;
// create a device context we can copy to
IntPtr hdcDest = CreateCompatibleDC(hdcSrc);
// create a bitmap we can copy it to,
// using GetDeviceCaps to get the width/height
IntPtr hBitmap = CreateCompatibleBitmap(hdcSrc, width, height);
// select the bitmap object
IntPtr hOld = SelectObject(hdcDest, hBitmap);
// bitblt over
BitBlt(hdcDest, 0, 0, width, height, hdcSrc, 0, 0, SRCCOPY);
// restore selection
SelectObject(hdcDest, hOld);
// clean up
DeleteDC(hdcDest);
ReleaseDC(handle, hdcSrc);
// get a .NET image object for it
Image img = Image.FromHbitmap(hBitmap);
// free up the Bitmap object
DeleteObject(hBitmap);
return (Bitmap)img;
}
public static void SendKeyup(string key)
{
byte bkey = byte.Parse(key);
keybd_event(bkey, 0, APICode.KEYEVENTF_KEYUP, 0);
}
public static void SendKeydown(string key)
{
byte bkey = byte.Parse(key);
keybd_event(bkey, 0, APICode.KEYEVENTF_KEYDOWN, 0);
}
public static void MouseDown(string button)
{
switch (button)
{
case "left":
mouse_event(APICode.Mouse_LeftDown, 0, 0, 0, IntPtr.Zero);
break;
case "right":
mouse_event(APICode.Mouse_RightDown, 0, 0, 0, IntPtr.Zero);
break;
case "middle":
mouse_event(APICode.Mouse_MiddleDown, 0, 0, 0, IntPtr.Zero);
break;
}
}
public static void MouseUp(string button)
{
switch (button)
{
case "left":
mouse_event(APICode.Mouse_LeftUp, 0, 0, 0, IntPtr.Zero);
break;
case "right":
mouse_event(APICode.Mouse_RightUp, 0, 0, 0, IntPtr.Zero);
break;
case "middle":
mouse_event(APICode.Mouse_MiddleUp, 0, 0, 0, IntPtr.Zero);
break;
}
}
public static void MouseMove(int x, int y)
{
SetCursorPos(x, y);
}
/// <summary>
/// 获取系统宽度度
/// </summary>
/// <returns></returns>
public static int GetSystemX()
{
return GetSystemMetrics(APICode.SM_CXSCREEN);
}
/// <summary>
/// 获取系统高度
/// </summary>
/// <returns></returns>
public static int GetSystemY()
{
return GetSystemMetrics(APICode.SM_CYSCREEN);
}
#endregion
}
public class APICode
{
/// <summary>
/// WM_KEYDOWN 按下一个键
/// </summary>
public static int WM_KEYDOWN = 0x0100;
/// <summary>
/// 释放一个键
/// </summary>
public static int WM_KEYUP = 0x0101;
//按下某键,并已发出WM_KEYDOWN, WM_KEYUP消息
public static int WM_CHAR = 0x102;
//当用translatemessage函数翻译WM_KEYUP消息时发送此消息给拥有焦点的窗口
public static int WM_DEADCHAR = 0x103;
//当用户按住ALT键同时按下其它键时提交此消息给拥有焦点的窗口
public static int WM_SYSKEYDOWN = 0x104;
//当用户释放一个键同时ALT 键还按着时提交此消息给拥有焦点的窗口
public static int WM_SYSKEYUP = 0x105;
//当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后提交此消息给拥有焦点的窗口
public static int WM_SYSCHAR = 0x106;
//当WM_SYSKEYDOWN消息被TRANSLATEMESSAGE函数翻译后发送此消息给拥有焦点的窗口
public static int WM_SYSDEADCHAR = 0x107;
//在一个对话框程序被显示前发送此消息给它,通常用此消息初始化控件和执行其它任务
public static int WM_INITDIALOG = 0x110;
//当用户选择一条菜单命令项或当某个控件发送一条消息给它的父窗口,一个快捷键被翻译
public static int WM_COMMAND = 0x111;
//当用户选择窗口菜单的一条命令或//当用户选择最大化或最小化时那个窗口会收到此消息
public static int WM_SYSCOMMAND = 0x112;
//发生了定时器事件
public static int WM_TIMER = 0x113;
//当一个窗口标准水平滚动条产生一个滚动事件时发送此消息给那个窗口,也发送给拥有它的控件
public static int WM_HSCROLL = 0x114;
//当一个窗口标准垂直滚动条产生一个滚动事件时发送此消息给那个窗口也,发送给拥有它的控件
public static int WM_VSCROLL = 0x115;
//当一个菜单将要被激活时发送此消息,它发生在用户菜单条中的某项或按下某个菜单键,它允许程序在显示前更改菜单
public static int WM_INITMENU = 0x116;
//当一个下拉菜单或子菜单将要被激活时发送此消息,它允许程序在它显示前更改菜单,而不要改变全部
public static int WM_INITMENUPOPUP = 0x117;
//当用户选择一条菜单项时发送此消息给菜单的所有者(一般是窗口)
public static int WM_MENUSELECT = 0x11F;
//当菜单已被激活用户按下了某个键(不同于加速键),发送此消息给菜单的所有者
public static int WM_MENUCHAR = 0x120;
//当一个模态对话框或菜单进入空载状态时发送此消息给它的所有者,一个模态对话框或菜单进入空载状态就是在处理完一条或几条先前的消息后没有消息它的列队中等待
public static int WM_ENTERIDLE = 0x121;
//在windows绘制消息框前发送此消息给消息框的所有者窗口,通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置消息框的文本和背景颜色
public static int WM_CTLCOLORMSGBOX = 0x132;
//当一个编辑型控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置编辑框的文本和背景颜色
public static int WM_CTLCOLOREDIT = 0x133;
//当一个列表框控件将要被绘制前发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置列表框的文本和背景颜色
public static int WM_CTLCOLORLISTBOX = 0x134;
//当一个按钮控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置按纽的文本和背景颜色
public static int WM_CTLCOLORBTN = 0x135;
//当一个对话框控件将要被绘制前发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置对话框的文本背景颜色
public static int WM_CTLCOLORDLG = 0x136;
//当一个滚动条控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以通过使用给定的相关显示设备的句柄来设置滚动条的背景颜色
public static int WM_CTLCOLORSCROLLBAR = 0x137;
//当一个静态控件将要被绘制时发送此消息给它的父窗口通过响应这条消息,所有者窗口可以 通过使用给定的相关显示设备的句柄来设置静态控件的文本和背景颜色
public static int WM_CTLCOLORSTATIC = 0x138;
//当鼠标轮子转动时发送此消息个当前有焦点的控件
public static int WM_MOUSEWHEEL = 0x20A;
//双击鼠标中键
public static int WM_MBUTTONDBLCLK = 0x209;
//释放鼠标中键
public static int WM_MBUTTONUP = 0x208;
//移动鼠标时发生,同WM_MOUSEFIRST
public static int WM_MOUSEMOVE = 0x200;
//按下鼠标左键
public static int WM_LBUTTONDOWN = 0x201;
//释放鼠标左键
public static int WM_LBUTTONUP = 0x202;
//双击鼠标左键
public static int WM_LBUTTONDBLCLK = 0x203;
//按下鼠标右键
public static int WM_RBUTTONDOWN = 0x204;
//释放鼠标右键
public static int WM_RBUTTONUP = 0x205;
//双击鼠标右键
public static int WM_RBUTTONDBLCLK = 0x206;
//按下鼠标中键
public static int WM_MBUTTONDOWN = 0x207;
public static int WM_USER = 0x0400;
public static int MK_LBUTTON = 0x0001;
public static int MK_RBUTTON = 0x0002;
public static int MK_SHIFT = 0x0004;
public static int MK_CONTROL = 0x0008;
public static int MK_MBUTTON = 0x0010;
public static int MK_XBUTTON1 = 0x0020;
public static int MK_XBUTTON2 = 0x0040;
//创建一个窗口
public static int WM_CREATE = 0x01;
//当一个窗口被破坏时发送
public static int WM_DESTROY = 0x02;
//移动一个窗口
public static int WM_MOVE = 0x03;
//改变一个窗口的大小
public static int WM_SIZE = 0x05;
//一个窗口被激活或失去激活状态
public static int WM_ACTIVATE = 0x06;
//一个窗口获得焦点
public static int WM_SETFOCUS = 0x07;
//一个窗口失去焦点
public static int WM_KILLFOCUS = 0x08;
//一个窗口改变成Enable状态
public static int WM_ENABLE = 0x0A;
//设置窗口是否能重画
public static int WM_SETREDRAW = 0x0B;
//应用程序发送此消息来设置一个窗口的文本
public static int WM_SETTEXT = 0x0C;
//应用程序发送此消息来复制对应窗口的文本到缓冲区
public static int WM_GETTEXT = 0x0D;
//得到与一个窗口有关的文本的长度(不包含空字符)
public static int WM_GETTEXTLENGTH = 0x0E;
//要求一个窗口重画自己
public static int WM_PAINT = 0x0F;
//当一个窗口或应用程序要关闭时发送一个信号
public static int WM_CLOSE = 0x10;
//当用户选择结束对话框或程序自己调用ExitWindows函数
public static int WM_QUERYENDSESSION = 0x11;
//用来结束程序运行
public static int WM_QUIT = 0x12;
//当用户窗口恢复以前的大小位置时,把此消息发送给某个图标
public static int WM_QUERYOPEN = 0x13;
//当窗口背景必须被擦除时(例在窗口改变大小时)
public static int WM_ERASEBKGND = 0x14;
//当系统颜色改变时,发送此消息给所有顶级窗口
public static int WM_SYSCOLORCHANGE = 0x15;
//当系统进程发出WM_QUERYENDSESSION消息后,此消息发送给应用程序,通知它对话是否结束
public static int WM_ENDSESSION = 0x16;
//当隐藏或显示窗口是发送此消息给这个窗口
public static int WM_SHOWWINDOW = 0x18;
//发此消息给应用程序哪个窗口是激活的,哪个是非激活的
public static int WM_ACTIVATEAPP = 0x1C;
//当系统的字体资源库变化时发送此消息给所有顶级窗口
public static int WM_FONTCHANGE = 0x1D;
//当系统的时间变化时发送此消息给所有顶级窗口
public static int WM_TIMECHANGE = 0x1E;
//发送此消息来取消某种正在进行的摸态(操作)
public static int WM_CANCELMODE = 0x1F;
//如果鼠标引起光标在某个窗口中移动且鼠标输入没有被捕获时,就发消息给某个窗口
public static int WM_SETCURSOR = 0x20;
//当光标在某个非激活的窗口中而用户正按着鼠标的某个键发送此消息给//当前窗口
public static int WM_MOUSEACTIVATE = 0x21;
//发送此消息给MDI子窗口//当用户点击此窗口的标题栏,或//当窗口被激活,移动,改变大小
public static int WM_CHILDACTIVATE = 0x22;
//此消息由基于计算机的训练程序发送,通过WH_JOURNALPALYBACK的hook程序分离出用户输入消息
public static int WM_QUEUESYNC = 0x23;
//此消息发送给窗口当它将要改变大小或位置
public static int WM_GETMINMAXINFO = 0x24;
//发送给最小化窗口当它图标将要被重画
public static int WM_PAINTICON = 0x26;
//此消息发送给某个最小化窗口,仅//当它在画图标前它的背景必须被重画
public static int WM_ICONERASEBKGND = 0x27;
//发送此消息给一个对话框程序去更改焦点位置
public static int WM_NEXTDLGCTL = 0x28;
//每当打印管理列队增加或减少一条作业时发出此消息
public static int WM_SPOOLERSTATUS = 0x2A;
//当button,combobox,listbox,menu的可视外观改变时发送
public static int WM_DRAWITEM = 0x2B;
//当button, combo box, list box, list view control, or menu item 被创建时
public static int WM_MEASUREITEM = 0x2C;
//此消息有一个LBS_WANTKEYBOARDINPUT风格的发出给它的所有者来响应WM_KEYDOWN消息
public static int WM_VKEYTOITEM = 0x2E;
//此消息由一个LBS_WANTKEYBOARDINPUT风格的列表框发送给他的所有者来响应WM_CHAR消息
public static int WM_CHARTOITEM = 0x2F;
//当绘制文本时程序发送此消息得到控件要用的颜色
public static int WM_SETFONT = 0x30;
//应用程序发送此消息得到当前控件绘制文本的字体
public static int WM_GETFONT = 0x31;
//应用程序发送此消息让一个窗口与一个热键相关连
public static int WM_SETHOTKEY = 0x32;
//应用程序发送此消息来判断热键与某个窗口是否有关联
public static int WM_GETHOTKEY = 0x33;
//此消息发送给最小化窗口,当此窗口将要被拖放而它的类中没有定义图标,应用程序能返回一个图标或光标的句柄,当用户拖放图标时系统显示这个图标或光标
public static int WM_QUERYDRAGICON = 0x37;
//发送此消息来判定combobox或listbox新增加的项的相对位置
public static int WM_COMPAREITEM = 0x39;
//显示内存已经很少了
public static int WM_COMPACTING = 0x41;
//发送此消息给那个窗口的大小和位置将要被改变时,来调用setwindowpos函数或其它窗口管理函数
public static int WM_WINDOWPOSCHANGING = 0x46;
//发送此消息给那个窗口的大小和位置已经被改变时,来调用setwindowpos函数或其它窗口管理函数
public static int WM_WINDOWPOSCHANGED = 0x47;
//当系统将要进入暂停状态时发送此消息
public static int WM_POWER = 0x48;
//当一个应用程序传递数据给另一个应用程序时发送此消息
public static int WM_COPYDATA = 0x4A;
//当某个用户取消程序日志激活状态,提交此消息给程序
public static int WM_CANCELJOURNA = 0x4B;
//当某个控件的某个事件已经发生或这个控件需要得到一些信息时,发送此消息给它的父窗口
public static int WM_NOTIFY = 0x4E;
//当用户选择某种输入语言,或输入语言的热键改变
public static int WM_INPUTLANGCHANGEREQUEST = 0x50;
//当平台现场已经被改变后发送此消息给受影响的最顶级窗口
public static int WM_INPUTLANGCHANGE = 0x51;
//当程序已经初始化windows帮助例程时发送此消息给应用程序
public static int WM_TCARD = 0x52;
//此消息显示用户按下了F1,如果某个菜单是激活的,就发送此消息个此窗口关联的菜单,否则就发送给有焦点的窗口,如果//当前都没有焦点,就把此消息发送给//当前激活的窗口
public static int WM_HELP = 0x53;
//当用户已经登入或退出后发送此消息给所有的窗口,//当用户登入或退出时系统更新用户的具体设置信息,在用户更新设置时系统马上发送此消息
public static int WM_USERCHANGED = 0x54;
//公用控件,自定义控件和他们的父窗口通过此消息来判断控件是使用ANSI还是UNICODE结构
public static int WM_NOTIFYFORMAT = 0x55;
//当用户某个窗口中点击了一下右键就发送此消息给这个窗口
//public static int WM_CONTEXTMENU = ??;
//当调用SETWINDOWLONG函数将要改变一个或多个 窗口的风格时发送此消息给那个窗口
public static int WM_STYLECHANGING = 0x7C;
//当调用SETWINDOWLONG函数一个或多个 窗口的风格后发送此消息给那个窗口
public static int WM_STYLECHANGED = 0x7D;
//当显示器的分辨率改变后发送此消息给所有的窗口
public static int WM_DISPLAYCHANGE = 0x7E;
//此消息发送给某个窗口来返回与某个窗口有关连的大图标或小图标的句柄
public static int WM_GETICON = 0x7F;
//程序发送此消息让一个新的大图标或小图标与某个窗口关联
public static int WM_SETICON = 0x80;
//当某个窗口第一次被创建时,此消息在WM_CREATE消息发送前发送
public static int WM_NCCREATE = 0x81;
//此消息通知某个窗口,非客户区正在销毁
public static int WM_NCDESTROY = 0x82;
//当某个窗口的客户区域必须被核算时发送此消息
public static int WM_NCCALCSIZE = 0x83;
//移动鼠标,按住或释放鼠标时发生
public static int WM_NCHITTEST = 0x84;
//程序发送此消息给某个窗口当它(窗口)的框架必须被绘制时
public static int WM_NCPAINT = 0x85;
//此消息发送给某个窗口仅当它的非客户区需要被改变来显示是激活还是非激活状态
public static int WM_NCACTIVATE = 0x86;
//发送此消息给某个与对话框程序关联的控件,widdows控制方位键和TAB键使输入进入此控件通过应
public static int WM_GETDLGCODE = 0x87;
//当光标在一个窗口的非客户区内移动时发送此消息给这个窗口 非客户区为:窗体的标题栏及窗 的边框体
public static int WM_NCMOUSEMOVE = 0xA0;
//当光标在一个窗口的非客户区同时按下鼠标左键时提交此消息
public static int WM_NCLBUTTONDOWN = 0xA1;
//当用户释放鼠标左键同时光标某个窗口在非客户区十发送此消息
public static int WM_NCLBUTTONUP = 0xA2;
//当用户双击鼠标左键同时光标某个窗口在非客户区十发送此消息
public static int WM_NCLBUTTONDBLCLK = 0xA3;
//当用户按下鼠标右键同时光标又在窗口的非客户区时发送此消息
public static int WM_NCRBUTTONDOWN = 0xA4;
//当用户释放鼠标右键同时光标又在窗口的非客户区时发送此消息
public static int WM_NCRBUTTONUP = 0xA5;
//当用户双击鼠标右键同时光标某个窗口在非客户区十发送此消息
public static int WM_NCRBUTTONDBLCLK = 0xA6;
//当用户按下鼠标中键同时光标又在窗口的非客户区时发送此消息
public static int WM_NCMBUTTONDOWN = 0xA7;
//当用户释放鼠标中键同时光标又在窗口的非客户区时发送此消息
public static int WM_NCMBUTTONUP = 0xA8;
//当用户双击鼠标中键同时光标又在窗口的非客户区时发送此消息
public static int WM_NCMBUTTONDBLCLK = 0xA9;
public static int SW_HIDE = 0;
public static int SW_SHOWNORMAL = 1;
public static int Mouse_Move = 0x0001;
public static int Mouse_LeftDown = 0x0002;
public static int Mouse_LeftUp = 0x0004;
public static int Mouse_RightDown = 0x0008;
public static int Mouse_RightUp = 0x0010;
public static int Mouse_MiddleDown = 0x0020;
public static int Mouse_MiddleUp = 0x0040;
public static int Mouse_Wheel = 0x0800;
public static int Mouse_Absolute = 0x8000;
public static int KEYEVENTF_EXTENDEDKEY = 0x1;
public static int KEYEVENTF_KEYUP = 0x2;
public static int KEYEVENTF_KEYDOWN = 0x00;
/// <summary>
/// 获取系统宽度
/// </summary>
public const int SM_CXSCREEN = 0;
/// <summary>
/// 获取系统高度
/// </summary>
public const int SM_CYSCREEN = 1;
public static int SW_SHOWMINIMIZED = 2;
public static int SW_SHOWMAXIMIZED = 3;
public static int SW_MAXIMIZE = 3;
public static int SW_SHOWNOACTIVATE = 4;
public static int SW_SHOW = 5;
public static int SW_MINIMIZE = 6;
public static int SW_SHOWMINNOACTIVE = 7;
public static int SW_SHOWNA = 8;
public static int SW_RESTORE = 9;
}
}
转自:http://blog.sina.com.cn/s/blog_469dcb490100mq5u.html
C# Windows Api的一些方法 封装 以及 常用参数的更多相关文章
- C#调用windows API的一些方法
使用C#调用windows API(从其它地方总结来的,以备查询) C#调用windows API也可以叫做C#如何直接调用非托管代码,通常有2种方法: 1. 直接调用从 DLL 导出的函数. 2. ...
- c# 判断窗体是否永在最前(TopMost),调用windows API
许多程序都可以把自身的窗体设为最前显示状态,这个可以参考博客c#让窗体永在最前 调用windows api 将窗体设为topmost.那么如何判断桌面上的一个窗体是否为最前显示状态呢,不光是自己的程序 ...
- 从普通函数到对象方法 ------Windows窗口过程的面向对象封装
原文地址:http://blog.csdn.net/linzhengqun/article/details/1451088 从普通函数到对象方法 ------Windows窗口过程的面向对象封装 开始 ...
- VC Windows API获得桌面所有窗口句柄的方法
VC Windows API应用之GetDesktopWindow ——获得桌面所有窗口句柄的方法 Windows API Windows 这个多作业系统除了协调应用程序的执行.分配内存.管理资源…之 ...
- Delphi Windows API判断文件共享锁定状态(OpenFile和CreateFile两种方法)
一.概述 锁是操作系统为实现数据共享而提供的一种安全机制,它使得不同的应用程序,不同的计算机之间可以安全有效地共享和交换数据.要保证安全有效地操作共享数据,必须在相应的操作前判断锁的类型,然后才能确定 ...
- Windows CE Notification API的使用方法
1 引言 以Windows CE 为操作系统的掌上电脑(如PocketPC或HPC),除具备PC的功能外,还具备很强的自身控制能力.Windows CE API超越微软其他操作系统的 API ...
- C#中调用Windows API的要点 .
介绍 API(Application Programming Interface),我想大家不会陌生,它是我们Windows编程的常客,虽然基于.Net平台的C#有了强大的类库,但是,我们还是不能否认 ...
- 关于Windows API、CRT和STL二三事
1.本文编写目的 本文是为了帮助一些人弄清一些关于Windows API, C运行时程序库(CRT), 和标准C++库(STL)的基本概念.有很多人甚至是有经验的程序员在这些概念上是含糊不清的甚 ...
- C++开发与Windows API
Windows API 向 C++ 开发人员提出了一项挑战. 组成 API 的众多库大都表现为 C 语言风格的函数和句柄或是 COM 风格的接口. 这些用起来都不太方便,需要进行一定的封装或间接操作. ...
随机推荐
- ACM成长之路
前几天在网上看到,转过来时刻督促一下自己. ACM队不是为了一场比赛而存在的,为的是队员的整体提高. 大学期间,ACM队队员必须要学好的课程有: l C/C++两种语言 l 高等数学 l 线性代数 l ...
- Django入门--自定义过滤器与标签
---恢复内容开始--- 为了让Django找到自定义的模板过滤器和模板标签,需要进行文件路径配置,配置方式分为APP目录下配置和项目路径下配置两种方式: 1.在APP目录下配置:针对某个应用特定的自 ...
- PHP学习总结(3)——PHP入门篇之PHP的echo语句
Echo语句 echo是PHP中的输出语句,可以把字符串输出(字符串用双引号括起来). 如下代码: <?php echo "Hello world!";?> 注意ech ...
- UVA10200 Prime Time
/* UVA10200 Prime Time https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8& ...
- MySQL 存储
1.存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户 ...
- Android面试过程描写叙述
1.之前所写项目的介绍 2.android一些常见问题的问答 3.关于android平时非常少用到但实则非常重要的问题描写叙述 技术分析 1自我感觉面试中比較好的方面: 1.熟悉掌握之前所写项目 2. ...
- Mysql第四天 数据库设计
不考虑主备.集群等方案,基于业务上的设计主要是表结构及表间关系的设计. 而关于表中字段主要是依据业务来进行定义,我们能够指定的大概有这么几项: 存储引擎 一般用InnoDB,特殊需求特殊选用 字符集和 ...
- JavaScript 获取小数任一小数点后的位数的小数
用Javascript取float型小数点后两位,例22.127456取成22.13,怎样做? 1.这样的方法最不推荐: function get(){ var s = 22.127456 + &qu ...
- 全屏滚动实现:fullPage.js和fullPage
fullPage.js和fullPage都能实现全屏滚动,二者差别是:fullPage.js需依赖于JQuery库,而fullPage不须要依赖不论什么一个js库.能够单独使用. 一.fullPage ...
- iOS_6_ToolBar+xib+红楼梦
终于效果图 BeyondViewController.h // // BeyondViewController.h // 6_ToolBar // // Created by beyond on 14 ...