0

DLL 内のコード:

extern "C" __declspec(dllexport) bool install()
{

    hHookcbt = SetWindowsHookEx(WH_CBT, (HOOKPROC)CBTProc, hinst, 0);
    hook = SetWindowsHookEx(WH_MOUSE, (HOOKPROC)MouseProc, hinst, 0);
    khook = SetWindowsHookEx(WH_KEYBOARD, (HOOKPROC)KeyboardProc, hinst, 0);
    return TRUE;
}
LRESULT CALLBACK MouseProc(int nCode, WPARAM wParam, LPARAM lParam)
{
    if (nCode < 0)
    {
        return CallNextHookEx(hook, nCode, wParam, lParam);
    }

    //char c = MapVirtualKey(wParam,MAPVK_VK_TO_CHAR);

    switch (wParam)
    {
    case WM_LBUTTONUP:
        SendMessage(whandle, 9, wParam, lParam);
    break;
    case WM_RBUTTONUP:
        SendMessage(whandle, 0, wParam, lParam);
        break;
    default:
        break;
    }


    return CallNextHookEx(NULL, nCode, wParam, lParam);
}

EXE 内のコード: マウス構造を使用して、マウスでクリックされたウィンドウのウィンドウ ハンドルを取得すると、メモ帳、付箋などのすべての既定のアプリケーションで動作しますが、Firefox、タスク マネージャーなどでは動作しません。

// SETTING THIS WINDOW HANDLE TO THE DLL
        swh = (SetWindowHandle)GetProcAddress(hinst, "setwindowhandle");
        if (!swh(hWnd))
        {
            printf("\nDLL FAILED TO ADDED THIS WINDOW HANDLE");
        }
        else{
            printf("\nDLL ADDED THIS WINDOW HANDLE");
        }
case 9:

        mhs = (MOUSEHOOKSTRUCT*)lParam;
        cout <<endl<< "x=" << mhs->pt.x<<" y="<<mhs->pt.y;
        SelWinH = mhs->hwnd;

        cout << endl << "Selected window process id=" << GetProcessId(SelWinH);
        tid = GetWindowThreadProcessId(mhs->hwnd, &pid);
        cout << endl << "tid =" << tid << "   " << "pid = " << pid;
        cout << endl << "---------------------------------------------------------------------------------";

        break;

ここで、SelWinH は、マウスで選択されたウィンドウの WHND を格納します。しかし、Firefox ブラウザをクリックしても応答しませんでした。

4

1 に答える 1

-1

GetForegroundWindow()マウスのクリック後に呼び出すのはどうですか? クリックしたウィンドウへのハンドルを返します。

于 2015-07-09T22:22:41.583 に答える