WM_MOUSEHOVER消息

当光标将鼠标悬停在窗口的工作区上,在调用 TrackMouseEvent之前指定的时间段内发布到窗口。

窗口通过其 WindowProc 函数接收此消息。

#define WM_MOUSEHOVER                   0x02A1

参数

wParam

指示各种虚拟密钥是否已关闭。 此参数可以是以下一个或多个值。

价值 意义
MK_CONTROL
0x0008
CTRL 键处于低位。
MK_LBUTTON
0x0001
鼠标左键被压低。
MK_MBUTTON
0x0010
鼠标中间按钮很沮丧。
MK_RBUTTON
0x0002
鼠标右键被压低。
MK_SHIFT
0x0004
SHIFT 键很沮丧。
MK_XBUTTON1
0x0020
XBUTTON1已关闭。
MK_XBUTTON2
0x0040
XBUTTON2已关闭。

lParam

低序单词指定光标的 x 坐标。 坐标相对于工作区的左上角。

高序单词指定游标的 y 坐标。 坐标相对于工作区的左上角。

返回值

如果应用程序处理此消息,它应返回零。

言论

生成 WM_MOUSEHOVER 时,悬停跟踪将停止。 如果应用程序需要进一步跟踪鼠标悬停行为,应用程序必须再次调用 TrackMouseEvent

使用以下代码获取水平和垂直位置:

xPos = GET_X_LPARAM(lParam); 
yPos = GET_Y_LPARAM(lParam); 

如上所述,x 坐标处于返回值的短 ;y 坐标采用高阶 (两者都表示 有符号 值,因为它们可以在具有多个监视器的系统上采用负值)。 如果将返回值赋给变量,则可以使用 MAKEPOINTS 宏从返回值获取 POINTS 结构。 还可以使用 GET_X_LPARAMGET_Y_LPARAM 宏提取 x 坐标或 y 坐标。

重要

请勿使用 LOWORDHIWORD 宏提取游标位置的 x 坐标和 y 坐标,因为这些宏在具有多个监视器的系统上返回不正确的结果。 具有多个监视器的系统可以具有负 x 和 y 坐标,LOWORDHIWORD 将坐标视为无符号数量。

要求

要求 价值
支持的最低客户端
Windows 2000 Professional [仅限桌面应用]
支持的最低服务器
Windows 2000 Server [仅限桌面应用]
页眉
Winuser.h (包括 Windowsx.h)

另请参阅

参考

GET_X_LPARAM

GET_Y_LPARAM

GetCapture

SetCapture

TrackMouseEvent

TRACKMOUSEEVENT

概念

鼠标输入

其他资源

MAKEPOINTS