我正在尝试创建一个小应用程序,可以检测鼠标光标何时移动到屏幕边缘,并将其移动到相反的边缘,以创建连续的桌面效果(如果有意义的话)。
以下是来自他人的一些代码(鼠标钩子部分),我通过添加SetCursorPos将鼠标移动到固定位置进行了修改。当我运行它时,SetCursorPos返回true,这意味着调用成功,但鼠标没有移动。我在某个地方读到过关于后期Windows版本中安全限制阻止此类操作的内容,这很有道理,但该来源对此的真实性不清楚。有人知道为什么会出现这种情况吗?
谢谢,以下是代码:
以下是来自他人的一些代码(鼠标钩子部分),我通过添加SetCursorPos将鼠标移动到固定位置进行了修改。当我运行它时,SetCursorPos返回true,这意味着调用成功,但鼠标没有移动。我在某个地方读到过关于后期Windows版本中安全限制阻止此类操作的内容,这很有道理,但该来源对此的真实性不清楚。有人知道为什么会出现这种情况吗?
谢谢,以下是代码:
#define _WIN32_WINNT 0x0400
#pragma comment( lib, "user32.lib" )
#include <windows.h>
#include <stdio.h>
HHOOK hMouseHook;
__declspec(dllexport) LRESULT CALLBACK KeyboardEvent (int nCode, WPARAM wParam, LPARAM lParam)
{
MOUSEHOOKSTRUCT * pMouseStruct = (MOUSEHOOKSTRUCT *)lParam;
if (pMouseStruct != NULL)
{
if (pMouseStruct->pt.x < -1900)
{
BOOL r = SetCursorPos(
500,
500
);
printf("Trigger %d. Response %d", pMouseStruct->pt.x, r);
}
}
return CallNextHookEx(hMouseHook, nCode, wParam, lParam);
}
void MessageLoop()
{
MSG message;
while (GetMessage(&message,NULL,0,0)) {
TranslateMessage( &message );
DispatchMessage( &message );
}
}
DWORD WINAPI MyMouseLogger(LPVOID lpParm)
{
HINSTANCE hInstance = GetModuleHandle(NULL);
if (!hInstance) hInstance = LoadLibrary((LPCSTR) lpParm);
if (!hInstance) return 1;
hMouseHook = SetWindowsHookEx (
WH_MOUSE_LL,
(HOOKPROC) KeyboardEvent,
hInstance,
NULL
);
MessageLoop();
UnhookWindowsHookEx(hMouseHook);
return 0;
}
int main(int argc, char** argv)
{
HANDLE hThread;
DWORD dwThread;
hThread = CreateThread(NULL,NULL,(LPTHREAD_START_ROUTINE)
MyMouseLogger, (LPVOID) argv[0], NULL, &dwThread);
if (hThread)
return WaitForSingleObject(hThread,INFINITE);
else return 1;
}