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>
This commit is contained in:
sakariya 2020-01-31 16:10:31 -08:00 committed by GitHub
parent b4f81a0c2a
commit b00ce8789f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
18 changed files with 267 additions and 0 deletions

View File

@ -0,0 +1,266 @@
![alt text][PowerToys_Logo]
- **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 <kbd>Ctrl</kbd>+<kbd>Z</kbd> 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, <kbd>cmd</kbd> + <kbd>C</kbd>, requires your thumb whereas on Windows, <kbd>Ctrl</kbd> + <kbd>C</kbd>, its your pinky. Even within identical applications there are shortcut disparities. Going to the address bar in Google Chrome on a Mac is <kbd>cmd</kbd> + <kbd>L</kbd>, on a PC, that would map to <kbd>Alt</kbd> + <kbd>D</kbd>.
**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 3<sup>rd</sup> 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 <kbd>![Windows Key][winlogo]</kbd> + <kbd>L</kbd>. You used to have to hit <kbd>Ctrl</kbd> + <kbd>Alt</kbd> + <kbd>Del</kbd> 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](https://github.com/microsoft/PowerToys/issues/6) 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 3<sup>rd</sup> party solutions. 28% of survey respondents used 3<sup>rd</sup> party tools, and 60% of those who did used either AutoHotKey or SharpKeys.
*Various 3<sup>rd</sup> party solutions:*
The following are the most popular 3<sup>rd</sup> party apps across
different operating systems:
- AutoHotkey
- SharpKeys
- Karabiner (MacOS)
| | AutoHotKey | SharpKeys | Karabiner |
|--------------------------------|--------------------|--------------------|-------------------|
|Does the application have a UI? | ![alt text][cross] | ![alt text][check] |![alt text][check] |
|OS-Level Shortcuts</p> | ![alt text][check] | ![alt text][cross] |![alt text][check] |
|App-Level Shortcuts</p> | ![alt text][check] | ![alt text][cross] |![alt text][check] |
|Multi-keyboard support</p> | ![alt text][check] | ![alt text][cross] |![alt text][check] |
|Profiles for different uses</p> | ![alt text][cross] | ![alt text][check] |![alt text][check] |
**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][sharpkey_landing]
Figure 1. SharpKeys: Landing Screen
![alt text][sharpkey_setting]
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][ahk_documentation]
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][karabiner_landing]
Figure 4. Karabiner: Landing Screen
![alt text][karabiner_complex]
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 3<sup>rd</sup> 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 3<sup>rd</sup> 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 3<sup>rd</sup> 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 <kbd>![Windows Key][winlogo]</kbd> + <kbd>G</kbd> lock the computer. | P1 |
| 3 | App level keyboard shortcuts. Example: Going to the address bar in Chrome on a MacOS is <kbd>cmd</kbd>+<kbd>L</kbd>, on a PC, that would map to <kbd>Alt</kbd> + <kbd>D</kbd>. | 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 <kbd>![Windows Key][winlogo]</kbd> + <kbd>G</kbd> locks the computer the Shortcut Guide needs to list this as the method to lock a computer, not <kbd>![Windows Key][winlogo]</kbd> + <kbd>L</kbd>. | 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: <kbd>![Windows Key][winlogo]</kbd> + <kbd>C</kbd> | P0 |
| 2 | OS-level shortcuts have priority over apps that come with shortcuts. Example: <kbd>Alt</kbd> + <kbd>Enter</kbd> 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 <kbd>![Windows Key][winlogo]</kbd> + <kbd>D</kbd> to <kbd>![Windows Key][winlogo]</kbd> + <kbd>L</kbd> 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 <kbd>Alt</kbd> and Right <kbd>Alt</kbd> | 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: <kbd>![Windows Key][winlogo]</kbd> + <kbd>D</kbd>
#### 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 3<sup>rd</sup> 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 <kbd>Fn</kbd> keys (i.e <kbd>F1</kbd>-<kbd>F12</kbd>) 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: <kbd>*Key A*</kbd> -> <kbd>Key B</kbd>, <kbd>Key B</kbd> -> <kbd>Key C</kbd>, <kbd>Key C</kbd> -> <kbd>*Key A*</kbd> | 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][ui_main]
### 4.2 Main UI Settings Cont'd
![alt text][ui_main2]
### 4.3 Remapping Keys Settings
![alt text][ui_remap1]
### 4.4 Keyboard Selection
![alt text][ui_remap2]
### 4.5 Detecting Key Presses
![alt text][ui_remap3]
### 4.6 Edit Shortcuts Settings
![alt text][ui_editshortcuts1]
### 4.6 Detecting Shortcut Key Presses
![alt text][ui_editshortcuts2]
[cross]: ./images/keymanager/icon-cross.png "Does not do"
[check]: ./images/keymanager/icon-check.png "Feature"
[karabiner_landing]: ./images/keymanager/karabiner_landingpage.png "Karabiner landing page"
[karabiner_complex]: ./images/keymanager/karabiner_complexmodifications.png "Karabiner complex settings"
[ahk_documentation]: ./images/keymanager/autohotkey_landingpage.png "AutoHotKey landing page"
[sharpkey_landing]: ./images/keymanager/sharpkeys_landingpage.png "SharpKeys landing page"
[sharpkey_setting]: ./images/keymanager/sharpkeys_selectkey.png "SharpKeys detecting key settings"
[PowerToys_Logo]: ./images/keymanager/PowerToys_Logo.png "PowerToys Logo"
[ui_Main]: ./images/keymanager/UI_mainsettings.png "Settings Landing page "
[ui_main2]: ./images/keymanager/UI_mainsettings2.png "Settings Landing page continued"
[ui_remap1]: ./images/keymanager/UI_remapsettings.png "Remapping Keys"
[ui_remap2]: ./images/keymanager/UI_remapsettings2.png "Drop down "
[ui_remap3]: ./images/keymanager/UI_remapsettings3.png "Remapping key pop up"
[ui_editshortcuts1]: ./images/keymanager/UI_editshortcut.png "Edit Shortcuts Settings"
[ui_editshortcuts2]: ./images/keymanager/UI_editshortcut2.png "Edit Shortcuts key pop up"
[winlogo]: ./images/keymanager/winkey.png

Binary file not shown.

After

Width:  |  Height:  |  Size: 31 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 89 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 107 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 84 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 82 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 46 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 74 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 228 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 213 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 125 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 41 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 107 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 858 B

View File

@ -16,4 +16,5 @@ This folder is where specs for PowerToys will be stored.
- [FancyZones](PowerToys-fancyzones.md) - [FancyZones](PowerToys-fancyzones.md)
- [PowerRename](PowerRename.md) - [PowerRename](PowerRename.md)
- [Keyboard Manager](KeyboardManager.md)
- Windows key shortcut guide - Windows key shortcut guide