系统相关
首页 > 系统相关> > Windows API 合成鼠标键盘事件接口

Windows API 合成鼠标键盘事件接口

作者:互联网

mouse_event

mouse_event是一个计算机函数,功能是综合鼠标移动和按钮点击。如果鼠标被移动,用设置MOUSEEVENTF_MOVE来表明,dX和dy保留移动的信息。给出的信息是绝对或相对整数值。

VOID mouse_event(
  DWORD     dwFlags,     // motion and click options
  DWORD     dx,          // horizontal position or change
  DWORD     dy,          // vertical position or change
  DWORD     dwData,      // wheel movement
  ULONG_PTR dwExtraInfo  // application-defined information
);

参数

名称 说明
MOUSEEVENTF_ABSOLUTE dX和dY参数含有规范化的绝对坐标。如果不设置,这些参数含有相对数据:相对于上次位置的改动位置。此标志可设置,也可不设置,不管鼠标的类型或与系统相连的类似于鼠标的设备的类型如何。要得到关于相对鼠标动作的信息,参见下面备注部分。
MOUSEEVENTF_MOVE 这表示鼠标移动
MOUSEEVENTF_LEFTDOWN 这表示鼠标左键按下
MOUSEEVENTF_LEFTUP 这表示鼠标左键松开
MOUSEEVENTF_RIGHTDOWN 这表示鼠标右键按下
MOUSEEVENTF_RIGHTUP 这表示鼠标右键松开
MOUSEEVENTF_MIDDLEDOWN 这表示鼠标中键按下
MOUSEEVENTF_MIDDLEUP 这表示鼠标中键松开
MOUSEEVENTF_WHEEL 这表示鼠标轮被滚动,如果鼠标有一个滚轮。滚动的数量由dwData给出。

返回值

此函数无返回值

其他信息

如果鼠标被移动,用设置MOUSEEVENTF_MOVE来表明,dX和dy保留移动的信息。给出的信息是绝对或相对整数值。
如果指定了MOUSEEVENTF_ABSOLUTE值,则dX和dy含有标准化的绝对坐标,其值在0到65535之间。事件程序将此坐标映射到显示表面。坐标(0,0)映射到显示表面的左上角,(65535,65535)映射到右下角。
如果没指定MOUSEEVENTF_ABSOLUTE,dX和dy表示相对于上次鼠标事件产生的位置(即上次报告的位置)的移动。正值表示鼠标向右(或下)移动;负值表示鼠标向左(或上)移动。
鼠标的相对移动服从鼠标速度和加速度等级的设置,一个最终用户用鼠标控制面板应用程序来设置这些值,应用程序用函数SystemParameterslnfo来取得和设置这些值。
在应用加速时系统对指定相对鼠标移动提供了两个测试。如果指定的沿X轴y轴的距离比第一个鼠标阈值大,并且鼠标的加速等级非零,则操作系统将距离加倍。如果指定的沿X轴或y轴的距离比第二个鼠标阈值大,并且鼠标的加速等级为2,则操作系统将从第一个阈测试得来的距离加倍。这样就允许操作系统将指定鼠标沿X轴或y轴的相对位移加到4倍。
一旦应用了加速,系统用期望的鼠标速度换算合成的值。鼠标速度的范围是从1(最慢)到20(最快),并代表基于鼠标移动的距离指示符移动的数量。缺省值是10,表示对鼠标的移动设有附加的修改。
函数mouse_event需要用的应用程序用来合成鼠标事件。也被应用程序用来取得鼠标位置和鼠标按键状态之外的鼠标信息。例如,如果输入板制造商想将基于画笔的信息传给自己的应用程序,可以写一个直接与输入板硬件通信的动态键接库(DLL),获得附加的信息,并保存到一个队列中。DLL然后调用 mouse_event,用标准按键和x/y位置数据,并在参数dwExtralnfo设置排列的附加信息的指针或索引。当应用程序需要附加信息时,调用 DLL(连同存贮在dwEXtralnfo中的指针或索引),则DLL返回附加信息。
Windows CE:Windows CE不支持参数 dwFlags取MOUSE EVENTF WHEEL常数。
速查: Windows NT: 3.1及以上版本; Windows:95及以上版本;Windows CE:不支持;头文件:winuser.h;输入库:user32.lib。
vb要自己定义常量。
鼠标事件常数

dephi 中的使用方法
mouse_event(按下鼠标(函数在上面),按下的位置xy,鼠标中间转轮0~120,程序的句柄,附加的消息,返回值(成功返回1));

keybd_event

keybd_event是函数功能:该函数合成一次击键事件。系统可使用这种合成的击键事件来产生WM_KEYUP或WM_KEYDOWN消息。

函数说明

函数功能

该函数合成一次击键事件。系统可使用这种合成的击键事件来产生WM_KEYUP或WM_KEYDOWN消息,键盘驱动程序的中断处理程序调用keybd_event函数。在Windows NT中该函数己被使用SendInput来替代它完成操作。

函数原型

VOID keybd_event(BYTE bVk,BYTE bScan,DWORD dwFlags,DWORD dwExtralnfo);

参数:

返回值

该函数无返回值。
#include<winuser.h>
#include<windows.h>
 
int main()
{
    Sleep(3000);
    keybd_event(16,0,0,0);//按下Shift键
    keybd_event('A',0,0,0);//按下a键
    keybd_event('A',0,KEYEVENTF_KEYUP,0);//松开a键
    keybd_event(16,0,KEYEVENTF_KEYUP,0);//松开Shift键
    //构成组合键---->按下Shift的同时按下a,形成A
    return 0;
}

系统使用说明

备注:尽管keybd_event传递一个与OEM相关的硬件扫描码给系统,但应用程序不能用此扫描码。系统在内部将扫描码转换成虚拟键码,并且在传送给应用程序前清除键码的UP/down位。应用程序可以摸拟PRINTSCREEN键的按下来获得一个屏幕快照,并把它存放到剪切板中。若要做到这一点,则要将keybd_event的bVk参数置为VK_SNAPSHOT,bScan参数置为0(用以获得全屏快照)或hScan置为1(仅获得活动窗口的快照)。Windows CE:WindowsCE支持dwFlags参数附加的标志位。即使用KEYEVENTF_SILENT标志模拟击键,而不产生敲击的声音。Windows CE不支持KEYEVENTF_EXTENDEDKEY标志。

适用版本

速查:Windows NT:3.1及以上版本;Windows:95及以上版本 ;Windows CE:1.0及以上版本;头文件:winuser.h;库文件:user32.lib。

标签:MOUSEEVENTF,鼠标,Windows,API,keybd,移动,event
来源: https://www.cnblogs.com/leehsiang/p/16366249.html