TinyHotKey 2.0.0
dotnet add package TinyHotKey --version 2.0.0
NuGet\Install-Package TinyHotKey -Version 2.0.0
<PackageReference Include="TinyHotKey" Version="2.0.0" />
paket add TinyHotKey --version 2.0.0
#r "nuget: TinyHotKey, 2.0.0"
// Install TinyHotKey as a Cake Addin #addin nuget:?package=TinyHotKey&version=2.0.0 // Install TinyHotKey as a Cake Tool #tool nuget:?package=TinyHotKey&version=2.0.0
TinyHotKey
TinyHotKey is a Windows HotKey handler with no dependency on Windows Forms or WPF that only listen
to specified key combinations. It uses RegisterHotKey
from the Win32 API directly on a dedicated
thread using a hidden window, avoiding global hooks.
Simple example
using var tinyHotKey = new TinyHotKeyInstance();
using var registration = tinyHotKey.RegisterHotKey(Modifier.Control | Modifier.Alt, Key.D, () =>
{
Console.WriteLine("Ctrl+Alt+D detected");
return Task.CompletedTask;
});
Example using dependency injection
// Add TinyHotKey to your DI container with logging support
services.AddTinyHotKey();
// In a service with a dependency on ITinyHotKey
using var registration = tinyHotKey.RegisterHotKey(Modifier.Control | Modifier.Alt, Key.D, () =>
{
Console.WriteLine("Ctrl+Alt+D detected");
return Task.CompletedTask;
});
Why TinyHotKey?
Unlike other projects TinyHotKey has no dependency on Windows Form or WPF and does not use global hooks, which makes it possible to avoid keylogger-like behavior and also support trimming and AOT.
It is possible to use TinyHotKey in alternate UI frameworks such as Avalonia or even in console applications.
How it works
The Windows hotkey mechanism works by detecting keyboard combinations and posting messages to a Window. TinyHotKey creates a hidden Window on a dedicated thread using Win32 calls, handling all hotkey interactions and invoking callbacks on a new task off the "UI" thread. This approach allows it to work in any kind of application running on Windows without relying on Windows Forms or WPF which are not trimming or AOT compatible.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 is compatible. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 is compatible. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
-
net8.0
-
net9.0
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.