SendMessage() 如何发送WM_NCHITTEST

qq_33553286 2018-09-17 03:18:16
如何发送WM_NCHITTEST消息使其迷惑windows, 就是模拟鼠标在客户区内的感觉, 实际上鼠标并没有移动到客户区!
求教育! sendmessage方式!
...全文
2259 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_43230388 2018-09-18
  • 打赏
  • 举报
回复
就这样的啦?
「已注销」 2018-09-18
  • 打赏
  • 举报
回复
对这消息一点都不理解。何为 Hit Test?命中检测也!Windows 靠给窗口发送这个消息来探测当前鼠标位置处于非客户区的哪个位置。通常操作系统发这个消息给一个窗口用以测试这个区域是否非客户去的哪一部分,依据不同的返回值,鼠标会有一些不同的呈现或者同样的操作出现不同的行为。比如标题栏可以拖动窗口,客户区做不到。或者到窗口边框位置时,光标变为调整窗口大小的样式等等。一般来说,你发这个消息目的也是和操作系统一样,检测当前光标所在位置属于哪个区域。默认情况下,这个消息由操作系统来处理。但有时,有些人会自己处理这个消息,在适时的情况下返回错误的值以便迷惑操作系统。比如在任何情况下都返回 HTCAPTION,那么操作系统检测该窗口的任意区域均为标题栏,那么就可以在客户区通过鼠标左键实现窗口拖动功能。当然,你既然自己返回了错误值,也就是修改了系统的判断逻辑,那么不免有的时候就会出现一些副作用,一些原本在客户区有效而非客户区无效的鼠标键盘操作就必须另行处理。比如这个文章中说到的:
http://www.cnblogs.com/GnagWang/archive/2010/09/12/1824394.html
xiaoxiangqing 2018-09-18
  • 打赏
  • 举报
回复
windows消息比较复杂
「已注销」 2018-09-18
  • 打赏
  • 举报
回复
谢谢大家 晚点结账给分
Sech 2018-09-18
  • 打赏
  • 举报
回复
谢谢大佬的帮助
「已注销」 2018-09-17
  • 打赏
  • 举报
回复
引用 4 楼 swwllx 的回复:
https://blog.csdn.net/xuanyin235/article/details/77971146
虽然看不懂不过还是谢谢了
「已注销」 2018-09-17
  • 打赏
  • 举报
回复
引用 1 楼 jianwen0529 的回复:
你是要做什么? WM_NCHITTEST是非客户区的消息啊 模拟鼠标在客户区的动作发送WM_LBUTTONDOWN(左键按下,其他动作使用相对应的消息,F12跳转到头文件查看) 模拟鼠标在非客户区动作发送WM_NCLBUTTONDOWN(左键按下,其他动作同上查看) WPARAM参数可以有以下,代表动作的区域

/*
 * WM_NCHITTEST and MOUSEHOOKSTRUCT Mouse Position Codes
 */
#define HTERROR             (-2)
#define HTTRANSPARENT       (-1)
#define HTNOWHERE           0
#define HTCLIENT            1
#define HTCAPTION           2
#define HTSYSMENU           3
#define HTGROWBOX           4
#define HTSIZE              HTGROWBOX
#define HTMENU              5
#define HTHSCROLL           6
#define HTVSCROLL           7
#define HTMINBUTTON         8
#define HTMAXBUTTON         9
#define HTLEFT              10
#define HTRIGHT             11
#define HTTOP               12
#define HTTOPLEFT           13
#define HTTOPRIGHT          14
#define HTBOTTOM            15
#define HTBOTTOMLEFT        16
#define HTBOTTOMRIGHT       17
#define HTBORDER            18
#define HTREDUCE            HTMINBUTTON
#define HTZOOM              HTMAXBUTTON
#define HTSIZEFIRST         HTLEFT
#define HTSIZELAST          HTBOTTOMRIGHT
#if(WINVER >= 0x0400)
#define HTOBJECT            19
#define HTCLOSE             20
#define HTHELP              21
#endif /* WINVER >= 0x0400 */
LPARAM参数包含鼠标所在的坐标值MAKELPARAM(point.x, point.y)
小弟我正在研究一个东西, sysTreeView32树形控件,模拟点击发现不管用后, 鼠标发送点击消息过去, 他还要检测一下鼠标是否在客户区, 我就把鼠标设置过去, 最后成功点开了. 我就在想用sendmessage发个消息过去欺骗它. 按你说的我发了一遍消息并不管用
三岁、就很帅 2018-09-17
  • 打赏
  • 举报
回复
https://blog.csdn.net/xuanyin235/article/details/77971146
三岁、就很帅 2018-09-17
  • 打赏
  • 举报
回复
发送自定义消息呗
三岁、就很帅 2018-09-17
  • 打赏
  • 举报
回复
https://blog.csdn.net/qihailong123456/article/details/6777112
幻夢之葉 2018-09-17
  • 打赏
  • 举报
回复
你是要做什么?
WM_NCHITTEST是非客户区的消息啊

模拟鼠标在客户区的动作发送WM_LBUTTONDOWN(左键按下,其他动作使用相对应的消息,F12跳转到头文件查看)
模拟鼠标在非客户区动作发送WM_NCLBUTTONDOWN(左键按下,其他动作同上查看)

WPARAM参数可以有以下,代表动作的区域

/*
* WM_NCHITTEST and MOUSEHOOKSTRUCT Mouse Position Codes
*/
#define HTERROR (-2)
#define HTTRANSPARENT (-1)
#define HTNOWHERE 0
#define HTCLIENT 1
#define HTCAPTION 2
#define HTSYSMENU 3
#define HTGROWBOX 4
#define HTSIZE HTGROWBOX
#define HTMENU 5
#define HTHSCROLL 6
#define HTVSCROLL 7
#define HTMINBUTTON 8
#define HTMAXBUTTON 9
#define HTLEFT 10
#define HTRIGHT 11
#define HTTOP 12
#define HTTOPLEFT 13
#define HTTOPRIGHT 14
#define HTBOTTOM 15
#define HTBOTTOMLEFT 16
#define HTBOTTOMRIGHT 17
#define HTBORDER 18
#define HTREDUCE HTMINBUTTON
#define HTZOOM HTMAXBUTTON
#define HTSIZEFIRST HTLEFT
#define HTSIZELAST HTBOTTOMRIGHT
#if(WINVER >= 0x0400)
#define HTOBJECT 19
#define HTCLOSE 20
#define HTHELP 21
#endif /* WINVER >= 0x0400 */

LPARAM参数包含鼠标所在的坐标值MAKELPARAM(point.x, point.y)
自定义窗体的最大化、最小化和关闭按钮, C#移动无标题栏窗体的三种代码: C#移动无标题栏窗体的三种代码:第一种采用,需注意窗体上的控件是否把窗体覆盖了。。。MouseDown、MouseMove、MouseUp事件应该是鼠标所处位置最顶层的控件的事件 在窗体的类中声明两个变量 private Point mouseOffset; //记录鼠标指针的坐标 private bool isMouseDown = false; //记录鼠标按键是否按下 创建该窗体 MouseDown、MouseMove、MouseUp事件的相应处理程序 private void Form1_MouseDown(object sender, System.Windows.Forms.MouseEventArgs e) { int xOffset; int yOffset; if (e.Button == MouseButtons.Left) { xOffset = -e.X ; yOffset = -e.Y ; mouseOffset = new Point(xOffset, yOffset); isMouseDown = true; } } private void Form1_MouseMove(object sender, System.Windows.Forms.MouseEventArgs e) { if (isMouseDown) { Point mousePos = Control.MousePosition; mousePos.Offset(mouseOffset.X, mouseOffset.Y); Location = mousePos; } } private void Form1_MouseUp(object sender, System.Windows.Forms.MouseEventArgs e) { // 修改鼠标状态isMouseDown的值 // 确保只有鼠标左键按下并移动时,才移动窗体 if (e.Button == MouseButtons.Left) { isMouseDown = false; } } 第二种调用API 未验证 using System.Runtime.InteropServices; [DllImport("user32.dll")] public static extern bool ReleaseCapture(); [DllImport("user32.dll")] public static extern bool SendMessage(IntPtr hwnd, int wMsg, int wParam, int lParam); public const int WM_SYSCOMMAND = 0x0112; public const int SC_MOVE = 0xF010; public const int HTCAPTION = 0x0002; private void Form1_MouseDown(object sender, MouseEventArgs e) { ReleaseCapture(); SendMessage(this.Handle, WM_SYSCOMMAND, SC_MOVE + HTCAPTION, 0); } 第三种未验证 private bool isMouseDown = false; private Point FormLocation; //form的location private Point mouseOffset; //鼠标的按下位置 [DllImport("user32.dll")] public static extern bool ReleaseCapture(); [DllImport("user32.dll")] public static extern bool SendMessage(IntPtr hwnd, int wMsg, int wParam, int lParam); private const int WM_SYSCOMMAND = 0x0112;//点击窗口左上角那个图标时的系统信息 private const int SC_MOVE = 0xF010;//移动信息 private const int HTCAPTION = 0x0002;//表示鼠标在窗口标题栏时的系统信息 private const int WM_NCHITTEST = 0x84;//鼠标在窗体客户区(除了标题栏和边框以外的部分)时发送的消息 private const int HTCLIENT = 0x1;//表示鼠标在窗口客户区的系统消息 private const int SC_MAXIMIZE = 0xF030;//最大化信息 private const int SC_MINIMIZE = 0xF020;//最小化信息 protected override void WndProc(ref Message m) { switch (m.Msg) { case WM_SYSCOMMAND: if (m.WParam == (IntPtr)SC_MAXIMIZE) { m.WParam = (IntPtr)SC_MINIMIZE; } break; case WM_NCHITTEST: //如果鼠标移动或单击 base.WndProc(ref m);//调用基类的窗口过程——WndProc方法处理这个消息 if (m.Result == (IntPtr)HTCLIENT)//如果返回的是HTCLIENT { m.Result = (IntPtr)HTCAPTION;//把它改为HTCAPTION return;//直接返回退出方法 } break; } base.WndProc(ref m);//如果不是鼠标移动或单击消息就调用基类的窗口过程进行处理 } private void Form1_Load(object sender, EventArgs e) { } ------------------------------- 如何在窗体标题栏左边的控制菜单加入自己的菜单啊? 我们一般在窗口标题栏点右键 或 按Alt+空格 可以弹出那个菜单。 ------解决方案-------------------- using System.Runtime.InteropServices; [DllImport( "user32.dll ")] public static extern IntPtr GetSystemMenu(IntPtr hWnd, bool bRevert); [DllImport( "user32.dll ")] public static extern bool InsertMenu(IntPtr hMenu, uint uPosition, uint uFlags, uint uIDNewItem, string lpNewItem); public const int MF_BYCOMMAND = 0; public const int MF_STRING = 0; public const int MF_BYPOSITION = 0x400; public const int MF_SEPARATOR = 0x800; private const uint SC_ABOUT = 0x0001; public const int WM_SYSCOMMAND = 0x0112; private void Form1_Load(object sender, EventArgs e) { IntPtr vMenuHandle = GetSystemMenu(Handle, false); InsertMenu(vMenuHandle, 255, MF_STRING, SC_ABOUT, "About... "); } protected override void WndProc(ref Message m) { switch (m.Msg) { case WM_SYSCOMMAND: if ((uint)m.WParam == SC_ABOUT) { MessageBox.Show( "Zswang 路过! "); } break; } base.WndProc(ref m); }

15,979

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 界面
社区管理员
  • 界面
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧