返回介绍

Function GUICtrlRecvMsg

发布于 2020-03-05 18:21:30 字数 2267 浏览 989 评论 0 收藏 0

GUICtrlRecvMsg

获取控件消息。向指定控件发送消息并获取返回的 lParam 的值。

GUICtrlRecvMsg ( 控件ID , msg [, wParam [, lParam类型]] )

参数

控件ID控件标识符(控件ID),可由 GUICtrlCreate... 函数的返回值获得。
msg要发送到控件的消息类型,在 Windows 的控件文档中有定义。
wParam[可选参数] 要发送到控件的第一个整型参数。
lParam类型[可选参数] 定义将返回的 lParam 的类型:0(默认)表示 wParam 和 lParam,1 表示 lParam 字符串,2 表示 lParam RECT 结构体。

返回值

成功:返回 SendMessage(Windows API) 的返回值。
失败:返回值为0。

注意

本函数允许我们使用 SendMessage(API 函数) 来把某些特殊的 Windows 消息直接发送到控件上。它可以用来启用某些特殊的控件功能,而这些功能往往是简单的 GUICtrlRead() 和 GUICtrlSet...() 函数无法实现的。

若在调用本函数时未指定 wParam 和 lParam类型 这两个参数则函数将返回一个含有两个元素的数组 (LPwParam, LPlParam)。

若指定了返回值为 RECT 则以含有四个元素的数组的形式返回(左侧, 上方, 右侧, 下方)。

相关

GUICtrlSendMsg, GUICtrlSet..., GUIGetMsg, GUICtrlRead

示例


#include <GUIConstants.au3>

GUICreate("我的 GUI") ; 创建一个居中显示的窗口

$nEdit = GUICtrlCreateEdit ("line 0", 10,10)
GUICtrlCreateButton ("确定", 20,200,50)

GUISetState ()

for $n=1 to 5
GUICtrlSetData ($nEdit, @CRLF & "line "& $n)
next

$EM_GETSEL = 0x00B0

; 运行脚本直到窗口被关闭
Do
$msg = GUIGetMsg()
if $msg >0 then
$a=GUICtrlRecvMsg($nEdit, $EM_GETSEL)
GUICtrlSetState($nEdit,$GUI_FOCUS) ; 设置焦点到编辑框控件

; 显示由控件返回的 wParam 和 lParam 值
MsgBox(0,"当前选择",StringFormat("start=%d end=%d", $a[0], $a[1]))
endif
Until $msg = $GUI_EVENT_CLOSE


如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文