Хук WW_MOUSE_LL не вызывается - PullRequest
       28

Хук WW_MOUSE_LL не вызывается

0 голосов
/ 06 августа 2011

Я сейчас создаю AFKChecker для моего приложения.Проблема в том, что низкоуровневый хук мыши не вызывается.Я проверил, возвращает ли он 0, что нет.Таким образом, клавиатура работает, но не мышь.Я гуглил, но до сих пор не нашел решения своей проблемы.

using System;
using System.Diagnostics;
using System.Runtime.InteropServices;

namespace AFKChecker
{
    public static class ActivityChecker
    {
        public static Int64 LastKeypress = 0;
        public static int AFKTime = 300;

        private const int WH_KEYBOARD_LL = 13;
        public const int WH_MOUSE_LL = 14;
        private static HookProc _keyproc = HookCallback;
        private static IntPtr _keyhookID = IntPtr.Zero;
        private static HookProc _mouseproc = HookCallback;
        private static IntPtr _mousehookID = IntPtr.Zero;

        public static void AddHook()
        {
            LastKeypress = Tools.UnixTime();
            _keyhookID = SetKeyboardHook(_keyproc);
            _mousehookID = SetKeyboardHook(_mouseproc);
        }

        private static IntPtr HookCallback(
        int nCode, IntPtr wParam, IntPtr lParam)
        {
            LastKeypress = Tools.UnixTime();
            return CallNextHookEx(_keyhookID, nCode, wParam, lParam);
        }

        public static void RemoveHook()
        {
            UnhookWindowsHookEx(_keyhookID);
            UnhookWindowsHookEx(_mousehookID);
        }

        public static Boolean IsAFK()
        {
            return (LastKeypress + AFKTime > Tools.UnixTime());
        }

        private static IntPtr SetKeyboardHook(HookProc proc)
        {
            using (Process curProcess = Process.GetCurrentProcess())
            using (ProcessModule curModule = curProcess.MainModule)
            {
                return SetWindowsHookEx(WH_KEYBOARD_LL, proc,
                    GetModuleHandle(curModule.ModuleName), 0);
            }
        }

        private static IntPtr SetMouseHook(HookProc proc)
        {
            using (Process curProcess = Process.GetCurrentProcess())
            using (ProcessModule curModule = curProcess.MainModule)
            {
                return SetWindowsHookEx(WH_MOUSE_LL, proc,
                    GetModuleHandle(curModule.ModuleName), 0);
            }
        }

        private delegate IntPtr HookProc(
            int nCode, IntPtr wParam, IntPtr lParam);

        [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
        private static extern IntPtr SetWindowsHookEx(int idHook,
            HookProc lpfn, IntPtr hMod, uint dwThreadId);

        [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
        [return: MarshalAs(UnmanagedType.Bool)]
        private static extern bool UnhookWindowsHookEx(IntPtr hhk);

        [DllImport("user32.dll", CharSet = CharSet.Auto, SetLastError = true)]
        private static extern IntPtr CallNextHookEx(IntPtr hhk, int nCode,
            IntPtr wParam, IntPtr lParam);

        [DllImport("kernel32.dll", CharSet = CharSet.Auto, SetLastError = true)]
        private static extern IntPtr GetModuleHandle(string lpModuleName);
    }
}

С уважением

Ответы [ 2 ]

2 голосов
/ 06 августа 2011

Установка мыши / клавиатуры, просто чтобы найти время простоя пользователя, кажется мне концептуально неправильным.Это должно быть последним средством, только если Windows не предлагает лучшего API.

A быстрый поиск показывает API GetLastInputInfo , который разработан для этой цели.И статья codeproject, описывающая, как это сделать в C #: Получение простоя пользователя с помощью C #

1 голос
/ 06 августа 2011

Похоже, вы не звоните SetMouseHook, перепроверьте свою функцию AddHook():

    public static void AddHook()
    {
        LastKeypress = Tools.UnixTime();
        _keyhookID = SetKeyboardHook(_keyproc);
        _mousehookID = SetKeyboardHook(_mouseproc); // SetMouseHook() here?
    }
...