windows程序设计 第5版:
如果您还记得我们如何通过拦截WM_SYSKEYDOWN消息来停用所有的系统键盘功能,那么您可能会想我们可否通过拦截鼠标消息完成类似的事情。完全可以!只要您在窗口消息处理程序中包含以下几条叙述:
case WM_NCHITTEST:
return (LRESULT) HTNOWHERE ;
就可以有效地禁用您窗口中的所有显示区域和非显示区域鼠标消息。这样一来,当鼠标在您的窗口(包括系统菜单图标、缩放按钮以及关闭按钮)中时,鼠标按键将会失效。
我试过了,完全没效果!怎么回事?实际代码如下:
#include <windows.h>
LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
PSTR szCmdLine, int iCmdShow)
{
static TCHAR szAppName[] = TEXT("Program");
HWND hwnd;
MSG msg;
WNDCLASS wndclass;
wndclass.style = CS_HREDRAW | CS_VREDRAW;
wndclass.lpfnWndProc = WndProc;
wndclass.cbClsExtra = 0;
wndclass.cbWndExtra = 0;
wndclass.hInstance = hInstance;
wndclass.hIcon = LoadIcon(NULL, IDI_APPLICATION);
wndclass.hCursor = LoadCursor(NULL, IDC_ARROW);
wndclass.hbrBackground = (HBRUSH)GetStockObject(WHITE_BRUSH);
wndclass.lpszMenuName = NULL;
wndclass.lpszClassName = szAppName;
RegisterClass(&wndclass);
hwnd = CreateWindow(szAppName, TEXT("Program"),
WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, CW_USEDEFAULT,
CW_USEDEFAULT, CW_USEDEFAULT,
NULL, NULL, hInstance, NULL);
ShowWindow(hwnd, iCmdShow);
UpdateWindow(hwnd);
while (GetMessage(&msg, NULL, 0, 0))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
return msg.wParam;
}
LRESULT CALLBACK WndProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
switch (message)
{
case WM_NCHITTEST:
return (LRESULT)HTNOWHERE;
}
return DefWindowProc(hwnd, message, wParam, lParam);
}
https://.com/q/1010000004421166
楼主应该先看一下这个 HTNOWHERE
代表的是什么含义..
VS2010
的命令行下: 使用 cl test.cpp user32.lib gdi32.lib
编译楼主的代码:
运行编译后的exe文件, 把鼠标放在 窗口的 边框上, 你看你的窗体会响应你放在边框时的消息吗?
你能拖动改变窗口的大小吗?
然后注释这两行代码:
case WM_NCHITTEST:
return (LRESULT)HTNOWHERE;
再次编译 运行, 鼠标再放在 窗口的边框上, 你看这时候, 鼠标是什么样子, 窗口的大小是否可以改变?
========================
刚在网上找了一个这个教程:
很明显楼主没有认真看书:
出现这样的问题应该有很多情况的,比如你的操作系统版本等!
MFC的问题都来这里。。。我一直以为这里是web开发的天下呢。。
楼主我觉得你去csdn效果应该好一些