其实说白了就是欺骗,欺骗谁了?呵呵  ,当然是欺骗windows,本来是移动标题栏可以拖动窗体,那么我们现在是拖动客户区来移动,当我们拖动标题栏的时候windows产生一个WM_NCHITTEST消息,这个消息确定鼠标点击的哪个位置,这个消息返回一个值,从而确定是“客户区”还是“非客户区”,当返回的值是HTCAPTION,说明这时拖动的是标题栏

那么我们现在就来欺骗,当用户删除拖动非标题栏的时候直接返回一个HTCAPTION状态就可以 ,看代码

在对话框中重载消息WM_NCHITTEST ,添加如下代码

 CRect rc;
 GetClientRect(&rc);//得到客户区的大小
 ClientToScreen(&rc);//坐标转换
 return rc.PtInRect(pt) ? HTCAPTION : //当用户鼠标的点击位置在客户区的时候直接返回HTCAPTION

当然了上面的方法只是适合对话框,那我们有的时候拖动的却是视图,那怎么设计呢!首先大家明白这样一个道理,Windows在发送WM_NCHITTEST消息时,是将它发送到鼠标光标下的框架/视图最顶层非透明窗口,由于视图首先获得WM_NCHITTEST 消息。所以只要在视图的WM_NCHITTEST消息处理例程中返回HTTRANSPARENT,直接在视图的WM_NCHITTEST消息中添加如下代码

 return HTTRANSPARENT; //返回这个状态标志

上面的方法看了网上的资料总结的,当然了还有更简单的,只要在OnLButtonDown事件中添加如下一句代码也可以实现

PostMessage(WM_NCLBUTTONDOWN,HTCAPTION,MAKELPARAM(point.x,point.y));

这里注意,在视图窗口中添加可能不起作用,这段代码只能适合对话框类型

作者 要饭的

相关文章:

  • 2021-07-31
  • 2021-07-18
  • 2022-02-21
  • 2021-11-01
  • 2022-12-23
  • 2021-09-28
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-11-23
  • 2022-02-27
  • 2022-12-23
  • 2021-09-27
相关资源
相似解决方案