mirror of
https://github.com/microsoft/PowerToys.git
synced 2025-06-08 01:52:52 +08:00

* basic logic working * Added a literal for ignore flag which cna be shared by all the files * Added a condition that the other modifier keys should not be pressed * Added comments to describe each scenario * sometimes when multiple modified keys were involved the shift+tab key press was also being invoked, so added an additional check in the IsValid function * use variable for vk_tab * remove new line before initializing dwextraInfo * move flag check if the filterKeyboardevent function * use windows.system.virtualkey.shift instead of defining a constant for the shift key code * removed latest settings to use internal settings instead. Removed the validity check while still within the hotkey other than if it's tab or shift+tab * add a function to send input to the system instead of duplicating the send input code * remove VKSHIFT declaration * display all shortcuts/keys except tab and shift+tab * remove header that is no longer needed
75 lines
2.3 KiB
C++
75 lines
2.3 KiB
C++
#include "pch.h"
|
|
#include "KeyboardHook.h"
|
|
#include <exception>
|
|
#include <msclr\marshal.h>
|
|
#include <msclr\marshal_cppstd.h>
|
|
#include <common/debug_control.h>
|
|
#include <common/common.h>
|
|
|
|
using namespace interop;
|
|
using namespace System::Runtime::InteropServices;
|
|
using namespace System;
|
|
using namespace System::Diagnostics;
|
|
|
|
KeyboardHook::KeyboardHook(
|
|
KeyboardEventCallback ^ keyboardEventCallback,
|
|
IsActiveCallback ^ isActiveCallback,
|
|
FilterKeyboardEvent ^ filterKeyboardEvent)
|
|
{
|
|
this->keyboardEventCallback = keyboardEventCallback;
|
|
this->isActiveCallback = isActiveCallback;
|
|
this->filterKeyboardEvent = filterKeyboardEvent;
|
|
}
|
|
|
|
KeyboardHook::~KeyboardHook()
|
|
{
|
|
// Unregister low level hook procedure
|
|
UnhookWindowsHookEx(hookHandle);
|
|
}
|
|
|
|
void KeyboardHook::Start()
|
|
{
|
|
hookProc = gcnew HookProcDelegate(this, &KeyboardHook::HookProc);
|
|
Process ^ curProcess = Process::GetCurrentProcess();
|
|
ProcessModule ^ curModule = curProcess->MainModule;
|
|
#if defined(DISABLE_LOWLEVEL_HOOKS_WHEN_DEBUGGED)
|
|
const bool hookDisabled = IsDebuggerPresent();
|
|
#else
|
|
const bool hookDisabled = false;
|
|
#endif
|
|
if (!hookDisabled)
|
|
{
|
|
// register low level hook procedure
|
|
hookHandle = SetWindowsHookEx(
|
|
WH_KEYBOARD_LL,
|
|
(HOOKPROC)(void*)Marshal::GetFunctionPointerForDelegate(hookProc),
|
|
0,
|
|
0);
|
|
if (hookHandle == nullptr)
|
|
{
|
|
DWORD errorCode = GetLastError();
|
|
show_last_error_message(L"SetWindowsHookEx", errorCode, L"PowerToys - Interop");
|
|
}
|
|
}
|
|
}
|
|
|
|
LRESULT __clrcall KeyboardHook::HookProc(int nCode, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
if (nCode == HC_ACTION && isActiveCallback->Invoke())
|
|
{
|
|
KeyboardEvent ^ ev = gcnew KeyboardEvent();
|
|
ev->message = wParam;
|
|
ev->key = reinterpret_cast<KBDLLHOOKSTRUCT*>(lParam)->vkCode;
|
|
ev->dwExtraInfo = reinterpret_cast<KBDLLHOOKSTRUCT*>(lParam)->dwExtraInfo;
|
|
|
|
// Ignore the keyboard hook if the FilterkeyboardEvent returns false.
|
|
if ((filterKeyboardEvent != nullptr && !filterKeyboardEvent->Invoke(ev)))
|
|
{
|
|
return CallNextHookEx(hookHandle, nCode, wParam, lParam);
|
|
}
|
|
|
|
keyboardEventCallback->Invoke(ev);
|
|
return 1;
|
|
}
|
|
return CallNextHookEx(hookHandle, nCode, wParam, lParam);
|
|
} |