Skip to content
forked from soffes/HotKey

Simple global shortcuts in macOS

License

Notifications You must be signed in to change notification settings

mattDavo/HotKey

 
 

Repository files navigation

HotKey

Build Status Swift Version Carthage compatible

Simple global shortcuts in macOS. HotKey wraps the Carbon APIs for dealing with global hot keys to make it easy to use in Swift.

HotKey, along with Color, were created for use in Contrast, a macOS app for checking designs for accessible color combinations.

Fork Information

Modifications:

  • Added Codable conformance to KeyCombo
  • Added named parameter to KeyCombo's modifiers setter.

Installation

Carthage

For installation with Carthage, simply add the following to your Cartfile:

github "mattDavo/HotKey"

Swift Package Manager

For installation with Swift Package Manager, simply add the following to your Package.swift:

.package(url: "https://github.com/mattDavo/HotKey", from: "0.1.2")

Usage

Simply initialize a HotKey with a key and modifiers:

// Setup hot key for ⌥⌘R
let hotKey = HotKey(key: .r, modifiers: [.command, .option])

This is a convenice initializer that creates a KeyCombo for you. You can also initialize with a Carbon key code and Carbon modifier flags if you’re feeling old school.

Now you can set the keyDownHandler and get callbacks for when your hot key is pressed:

hotKey.keyDownHandler = {
  print("Pressed at \(Date())")
}

You can also implement hotKey.keyUpHandler if you’d like.

You don’t need to think about when handlers are registered and unregistered. This all happens automatically based on the HotKey object’s lifecycle.

Thanks

HotKey was heavily inspired by PTHotKey.

About

Simple global shortcuts in macOS

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Swift 98.0%
  • Ruby 1.4%
  • Objective-C 0.6%