PowerToys/doc/specs/KeyboardManager.md
sakariya b00ce8789f
Adding KeyManager spec (#1112)
* Adding KeyManager spec

* adding req changes

* req changes

* changed wording

* md edits

* edit md

* Update doc/specs/KeyboardManager.md

Co-Authored-By: Jeroen van Warmerdam <jeronevw@hotmail.com>

* further edits

* Update KeyboardManager.md

* Update KeyboardManager.md

Co-authored-by: Jeroen van Warmerdam <jeronevw@hotmail.com>
2020-01-31 16:10:30 -08:00

25 KiB
Raw Blame History

alt text

  • What is it: Users can remap their keys
  • Authors: Sakariya Ahmed
  • Spec Status: Draft

1. Overview

1.1 Key definitions

Here are a few definitions of words found throughout this document to ensure clarity:

  • Key Remapping: Refers to the act of changing the output of a keystroke on your keyboard. An example is remapping the “Tab” key to “Delete”.
  • Shortcuts or Key shortcuts: A combination of 2 or more keystrokes that results in a user-defined action. An example is Ctrl+Z un-doing an action in Microsoft Word
  • KSM: Acronym for Keyboard Shortcut Manager
  • Keystroke: A single press of a key
  • Exotic key: These are keys that are unique and dont exist on many keyboards. Example: Calculator or search button.

1.2 Press Release

Powertoys has just released a new utility called “Keyboard Shortcut Manager”! This keyboard manager enables customers to customize their computer on a keyboard level. With it, all the keys on your keyboard are dynamic and can be remapped to provide different outputs.

Ever switched computers and the shortcut to search your computer was different? Or change the keys you press an app you use often? This utility is perfect if youre always looking to be more efficient on your computer or are a long-time user of a different OS and want to bring your keypresses and shortcuts with you!

1.3 Elevator Pitch

A keyboard is an extremely powerful and primary method of interacting with your operating system, and historically Windows has lacked the configurability to make this power extend to you, the user. With this new addition to Powertoys you gain access to the keyboards potential with the ability to remap keys and create user-defined keyboard shortcuts.

1.4 Tweet

"Ever wish you could change some shortcuts and edit keyboard buttons? Or switch computers and your keyboard was slightly different? PowerToys is here to solve all your keyboard woes with a Keyboard Shortcut Manager! Customize your experience by remapping keys or creating new shortcuts!"

1.5 Narrative / Scenario

User Problem 1 - Mac/Linux “switch” users: A user who has recently made the switch to Windows and is having trouble adjusting to the keyboard differences. Simple tasks like locking the computer, copy / paste, and switching browsers now require thinking and the lack of muscle memory makes the user feels clumsy at times. For example, copying an object on MacOS, cmd + C, requires your thumb whereas on Windows, Ctrl + C, its your pinky. Even within identical applications there are shortcut disparities. Going to the address bar in Google Chrome on a Mac is cmd + L, on a PC, that would map to Alt + D.

Outcome: A successful KSM manager would increase comfortability and users wouldnt feel like they lost functionality or convenience with switching to Windows 10. In effect, it would help decrease churn and avoid a negative experience for a new user, which is crucial moment for public sentiment on Windows.

User Problem 2 Users want customizability to make them faster: Developers, or power users, who use their keyboard a lot are constantly looking to save themselves time and make their processes more convenient. This community has largely relied on 3rd party tools or has left their keys alone but voiced frustration with the lack of a native tool to remap keys. An example of a power shortcut that made its way into Windows is Windows Key + L. You used to have to hit Ctrl + Alt + Del then click “Lock”.

Outcome: A successful KSM manager would unlock functionality and convenience for many power users, increasing their everyday efficiency. Keyboard changes are highly visible and successfully extending control would greatly boost satisfaction to continue to cement Windows as the ideal platform for a developer.

1.6 Customers

We have two primary customers:

  • Developers/PowerUsers of Windows10 that want a built-in and lightweight solution to remap their own hotkeys which will increase their efficiency in completing tasks.
  • Former Linux and MacOS users who now use Windows and would like to utilize their former keyboard shortcuts to get rid of the learning period and ease the transition to using a new device.

1.7 Problem Statement and Supporting Customer Insights

Windows 10 is available on a multitude of devices and as such, various keyboard inputs are utilized to access the UI. The Keyboard and eyboard Shortcuts are an integral way of teracting with Windows and users have had difficulty accessing them when they have non-standard keyboards or knowledge of shortcuts from a different OS.

Comfortability/Ease of use, especially for new users, can be crucial as their first few interactions can cause frustration and result in a higher churn towards competitors. For developers and some seasoned users, where using their keyboard is a large part their job, ability to remap keystrokes and engage executables can lead to massive gains in time. In fact, this was the second most popular topic measured through thumbs up and the most commented issue in the PowerToys Github.

1.8 Solutions or Expectations

To make-up for the lack of a built-in solutions users that have come across this issue only once often rely on learning the basic windows shortcuts and forgoing additional productivity. For users where this has become an ongoing concern, the vast majority who switch to the Powertoy will come with certain expectations as they have come to rely on a multitude of 3rd party solutions. 28% of survey respondents used 3rd party tools, and 60% of those who did used either AutoHotKey or SharpKeys.

Various 3rd party solutions:

The following are the most popular 3rd party apps across different operating systems:

  • AutoHotkey
  • SharpKeys
  • Karabiner (MacOS)
AutoHotKey SharpKeys Karabiner
Does the application have a UI? alt text alt text alt text
OS-Level Shortcuts

alt text alt text alt text
App-Level Shortcuts

alt text alt text alt text
Multi-keyboard support

alt text alt text alt text
Profiles for different uses

alt text alt text alt text

Sharpkeys is an open source application created for Windows that allows the user to remap keys through their computers registry. It was created to make the process of accessing the registry and reprogramming keys more convenient for advanced users and accessible for casual users. The Sharpkeys GUI (Figure 1) allows users to keep track of remapped keys and import/export key configurations. When users try to remap a key, they can do it through pressing the key on their keyboard or selecting the key from a drop-drown menu. Both are exhaustive for North American users and the SharpKeys community is currently working to expanding their support for even more international keyboards. Sharpkeys requires a restart but doesnt require elevated permissions or to run in the background. It does not support the remapping of key combinations or shortcuts. Additionally, it is unable to remap keys that cannot be remapped from Windows registry access: Fn, Windows, Calculator, etc.

alt text Figure 1. SharpKeys: Landing Screen

alt text Figure 2. Sharpkeys: Key Remapping Input

AutoHotKey is a scripting language that runs on Windows and while it focuses on and was first created to remap keys and create shortcuts, it is capable of a lot more. Using AHK requires spending time reading their extensive documentation (Figure 3) to become adept at writing scripts. There is no GUI or interface that comes with AHK and it is all interpreted through a text editor. With AHK users can create both OS-level and app-specific shortcuts, however there is no simple way to share/save key configurations among multiple users. AHK has a very strong community that has been able to create tools that fill in many of the languages functionality gaps.

alt text Figure 3. AutoHotKey Documentation

Karabiner is a MacOS solution for users to remap their keys. Karabiners interface (Figure 4) is intuitive and accessible to both beginner and advanced users. It is capable of what it calls “simple modifications, which are just remapping a single key to another key. Karabiner has support for multiple keyboards and the user can target a specific device or all devices for any remapping. Complex modifications (Figure 5) are defined by Karabiner as creating/editing shortcuts that consist of multiple key presses or mapping a shortcut to a single key. These complex modifications can be imported from Karabiners website where the community has created a vast array of key configurations. If you cannot find a suitable configuration, a user can create their own by using the terminal to open Karabiners JSON file. After learning the syntax from the reference manual, this JSON file can be edited to automatically add new user-defined rules.

alt text Figure 4. Karabiner: Landing Screen

alt text Figure 6. Karabiner: Complex Modifications

1.9 Survey Results

A brief survey was sent to the Windows Developer community during the planning stage of this utility. The consumer research was then used to inform this functional spec and test the preliminary hypothesis. Heres a summary of the survey results

  • Question: Do you currently use any third-party tools to remap keys and/or create shortcuts?

    • Nearly 30% of survey respondents used 3rd party tools. This indicates that there is not only a real demand for the utility and many users currently remap their keys.
  • Question: Which third party tools do you use to remap keys and create shortcuts?

    • The most popular 3rd party tool was AutoHotKey, followed by SharpKeys. Karabiner was not mentioned as this was sent to Windows developers but it was still highlighted in the competitive research due to its popularity among Mac users.
  • Question: If you could improve the way that you manage your remap keys and create shortcuts using the third-party tools, what would you change?

    • Over 50% of survey respondents asked for either native integration into Windows and / or a pleasant UI experience instead of scripting. This confirmed the decision to ensure users can engage with all of the utilitys functionality through a UI.
  • Question: What features would you most like in in a keyboard shortcut manager besides remapping keys?

    • ~70% of users requested shortcuts, either app-level or OS level, with OS shortcuts being the most demanded. This helped us prioritize the different features we planned in the functional spec.
  • Question: If remapping your keyboard required a restart, would you still use this PowerToy?

    • Before design, we were intimately aware that this could be a pain point for many users. Over 60% of respondents answered 'Yes', providing confidence that a restart, if necessary, is possible.

1.10 Goals / Non-Goals

Goals

  • The KSM can be used to configure keypresses on Windows 10 with any built-in / external keyboard
  • The KSM provides an intuitive and lightweight UI experience (53% of survey respondents who use 3rd party tools wanted integration into Windows and/or a UI)
  • The KSM will be able to remap keys
  • The KSM will be able to edit OS-level shortcuts
  • The KSM will work with all keyboards, regardless of locale (Example: Japanese keyboard)

Stretch Goals

  • The KSM will be able to edit app-level shortcuts

Non-Goals

  • Require a reboot only when absolutely necessary (42% of survey respondents would not use this PowerToy if reboot was required)

2. Requirements

2.1 Functional Requirements Overview

No. Requirement Pri
1 Remap any button on keyboard to any other button on keyboard P0
2 OS-Level key shortcuts. Example: Making Windows Key + G lock the computer. P1
3 App level keyboard shortcuts. Example: Going to the address bar in Chrome on a MacOS is cmd+L, on a PC, that would map to Alt + D. P2
4 Settings page that easily configures all supported scenarios. P1
5 The Powertoys Shortcut Guide needs to be aware of keyboard remaps. Example: If Windows Key + G locks the computer the Shortcut Guide needs to list this as the method to lock a computer, not Windows Key + L. P1
6 A Mac ready profile that is prepopulated with commonly used remappings and adjustments. P1
6 A Linux ready profile that is prepopulated with commonly used remappings and adjustments. P1
7 Multiple keyboard support. Example: Surface Laptop and Surface keyboard have different layout and a remap maybe needed. P1
8 The KSM needs to meet accessibility requirements. P1
9 The KSM needs to meet localization requirements. P1

2.2 Functional Requirements for remapping of keys

No. Requirement Pri
1 Remapping of keys is done through a user interface. User is able to select the key to remap and the corresponding key to remap it to. P1
2 Support for global and key-board specific shortcuts. Example: See Karabiner P2
3 Function Key remap P3
4 Remapping of keys can be done through a JSON file P3

2.3 Functional Requirements for OS-Level shortcuts

No. Requirement Pri
1 Can disable any existing OS-level shortcuts. Example: Windows Key + C P0
2 OS-level shortcuts have priority over apps that come with shortcuts. Example: Alt + Enter will trigger OS action, not excel-specific action when in Excel P1
3 Winkey shortcuts have priority over app-specific shortcuts P2

2.4 Functional Requirements for App-Level shortcuts (stretch goal)

No. Requirement Pri
1 A list of available apps on computer with friendly names P2
2 Assign app-level shortcuts through settings UI P2
3 Able to set global shortcut exceptions to certain apps P3

2.5 Functional Requirements for Settings

No. Requirement Pri
1 Recognize key presses. P0
2 Clearly show what keys cannot be remapped P1
3 Option to reset to default P1
4 Save, load, and export KSM settings so they can be loaded onto a different computer P1
5 Warn users if any Winkey shortcuts have been orphaned. Example: Mapping Windows Key + D to Windows Key + L in one-direction, ergo no longer providing the user a method to lock their PC. P1
6 Display all remapping and shortcut changes that have been made P1
7 Settings are capable of dark mode P2
8 Warn users when multiple keys have the same function. Example: Left Alt and Right Alt P2
9 I am presented with a list of all the current OS-level key mapping and shortcuts in use P3
10 Users can quickly swap profiles for different workloads. Example: See #2 P3

2.6 Functional Requirements Open Questions / Concerns

2.6.1 Circular reference

  • When two or more keys are remapped to each other the logic needs to ensure there is never a loop and clear indication regarding priority order of operations.

2.6.2 WinKey Priority and Access

  • Should certain shortcuts be restricted to the user? Example: Windows Key + D

2.6.3 Multiple Keyboards Shortcut support

  • Currently, there exists no plan to incorporate the creation of shortcuts for specific keyboards. Is this an expected use case?

2.6.4 SharpKey / AHK Partnership

  • SharpKey has weak copy-left license (Ms-PL Microsoft Public License) and we need to evaluate whether any of its codebase is useful. AutoHotKeys scripting model could help us but we need to validate if its possible / if it's a good idea. 52% of survey respondents who used 3rd party tools used AHK and 68% used either AHK or Sharpkeys.

2.6.5 Elevated Permissions

  • Is consistently running elevated (aka run as admin) required for the Keyboard Shortcut Manager?

2.6.6 F-Key / Fn key ignore

  • Can we have a setting that makes Fn keys (i.e F1-F12) always act like function keys?

3. Measure Requirements

No. Requirement Implication Pri
1 # of keys being remapped per user and which keys Insight into use and whether certain keys are persistent across community* P1
2 # of OS-level shortcuts created vs # of App-level shortcuts Understand how users are using shortcuts P1
3 # of times the same user loads different key configurations. Should multi-profile use be prioritized P1
4 # of times built-in shortcuts are disabled Recommended defaults for developers P1
5 # of times built-in shortcuts are remapped Recommended defaults for developers P1
6 Specificity and frequency of exotic keys being remapped. Whether the KSM is missing keys and if some keys not useful P1
7 # of visits to the KSM editor/settings in a given time period Continuous visits could imply lack of clarity with UX or bug in app P1
8 Frequency of keys being mapped to each other (swapped). Example: Key A -> Key B, Key B -> Key C, Key C -> Key A Whether auto/hot swapping needs to be prioritized P1
9 Amount of people that have remapped turned on / off Information on whether KSM is being utilized P1
10 Maximum number of keyboards someone has attached to their keyboard in a 28-day period Validates whether to prioritize additional keyboard support P1

4. UI Mockup

See below for screenshots of the UI mockups:

Please understand that these are preliminary*

4.1 Main UI Settings

alt text

4.2 Main UI Settings Cont'd

alt text

4.3 Remapping Keys Settings

alt text

4.4 Keyboard Selection

alt text

4.5 Detecting Key Presses

alt text

4.6 Edit Shortcuts Settings

alt text

4.6 Detecting Shortcut Key Presses

alt text