WM_XBUTTONDOWN消息

当用户按下第一个或第二个 X 按钮时,光标位于窗口的工作区时发布。 如果未捕获鼠标,消息将发布到光标下的窗口。 否则,消息将发布到捕获鼠标的窗口。

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

#define WM_XBUTTONDOWN                  0x020B

参数

wParam

低序单词指示各种虚拟密钥是否关闭。 它可以是以下一个或多个值。

含义
MK_CONTROL
0x0008
Ctrl 键关闭。
MK_LBUTTON
0x0001
鼠标左键向下键。
MK_MBUTTON
0x0010
鼠标中间按钮已关闭。
MK_RBUTTON
0x0002
鼠标右键已关闭。
MK_SHIFT
0x0004
SHIFT 键关闭。
MK_XBUTTON1
0x0020
第一个 X 按钮关闭。
MK_XBUTTON2
0x0040
第二个 X 按钮已关闭。

高阶单词指示单击了哪个按钮。 可以是下列值之一。

含义
XBUTTON1
0x0001
单击第一个 X 按钮。
XBUTTON2
0x0002
单击第二个 X 按钮。

lParam

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

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

返回值

如果应用程序处理此消息,它应返回 TRUE。 有关处理返回值的详细信息,请参阅“备注”部分。

注解

使用以下代码获取 wParam 参数中的信息:

fwKeys = GET_KEYSTATE_WPARAM (wParam); 
fwButton = GET_XBUTTON_WPARAM (wParam);

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

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 将坐标视为无符号数量。

WM_LBUTTONDOWNWM_MBUTTONDOWNWM_RBUTTONDOWN 消息不同,应用程序在处理消息时应从此消息返回 TRUE 。 这样做允许软件在早于 2000 Windows Windows 系统上模拟此消息,以确定窗口过程是处理消息还是调用 DefWindowProc 来处理它。

要求

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

另请参阅

引用

GET_KEYSTATE_WPARAM

GET_X_LPARAM

GET_XBUTTON_WPARAM

GET_Y_LPARAM

GetCapture

SetCapture

WM_XBUTTONDBLCLK

WM_XBUTTONUP

概念性

鼠标输入

其他资源

MAKEPOINTS