Public overview - Microsoft Learn
Quick Accent (formerly known as Power Accent) is a PowerToys module that allows users to quickly insert accented characters by holding a key and pressing an activation key (like the Space key or arrow keys). For example, holding 'a' might display options like 'à', 'á', 'â', etc. This tool enhances productivity by streamlining the input of special characters without the need to memorize keyboard shortcuts.
The Quick Accent module consists of four main components:
poweraccent/
├── PowerAccent.Core/ # Core component containing Language Sets
├── PowerAccent.UI/ # The character selector UI
├── PowerAccentKeyboardService/ # Keyboard Hook
└── PowerAccentModuleInterface/ # DLL interface
The Module Interface, implemented in PowerAccentModuleInterface/dllmain.cpp, is responsible for:
- Handling communication between PowerToys Runner and the PowerAccent process
- Managing module lifecycle (enable/disable/settings)
- Launching and terminating the PowerToys.PowerAccent.exe process
The Core component contains:
- Main accent character logic
- Keyboard input detection
- Character mappings for different languages
- Management of language sets and special characters (currency, math symbols, etc.)
- Usage statistics for frequently used characters
The UI component is responsible for:
- Displaying the toolbar with accent options
- Handling user selection of accented characters
- Managing the visual positioning of the toolbar
This component:
- Implements keyboard hooks to detect key presses
- Manages the trigger mechanism for displaying the accent toolbar
- Handles keyboard input processing
The Quick Accent is activated when:
- A user presses and holds a character key (e.g., 'a')
- User presses the trigger key
- After a brief delay (around 300ms per setting), the accent toolbar appears
- The user can select an accented variant using the trigger key
- Upon releasing the keys, the selected accented character is inserted
The module includes multiple language-specific character sets and special character sets:
- Various language sets for different alphabets and writing systems
- Special character sets (currency symbols, mathematical notations, etc.)
- These sets are defined in the core component and can be extended
- The module has a specific timing mechanism for activation that users have become accustomed to. Initially, this was considered a bug (where the toolbar would still appear even after quickly tapping and releasing keys), but it has been maintained as expected behavior since users rely on it.
- Multiple rapid key presses can trigger multiple background tasks.
- Potential refinements to the activation timing mechanism
- Additional language and special character sets
- Improved UI positioning in different application contexts
To debug the Quick Accent module via runner approach, follow these steps:
- Get familiar with the overall Debugging Process for PowerToys.
- Build the entire PowerToys solution in Visual Studio
- Navigate to the PowerAccent folder in Solution Explorer
- Open the file you want to debug and set breakpoints at the relevant locations
- Find the runner project in the root of the solution
- Right-click on the runner project and select "Set as Startup Project"
- Start debugging by pressing
F5or clicking the "Start" button - When the PowerToys Runner launches, enable the Quick Accent module in the UI
- Use the Visual Studio Debug menu or press
Ctrl+Alt+Pto open "Reattach to Process" - Find and select "PowerToys.PowerAccent.exe" in the process list
- Trigger the action in Quick Accent that should hit your breakpoint
- Verify that the debugger breaks at your breakpoint and you can inspect variables and step through code
This process allows you to debug the Quick Accent module while it's running as part of the full PowerToys application.
To directly debug the Quick Accent UI component:
- Get familiar with the overall Debugging Process for PowerToys.
- Build the entire PowerToys solution in Visual Studio
- Navigate to the PowerAccent folder in Solution Explorer
- Open the file you want to debug and set breakpoints at the relevant locations
- Right-click on the PowerAccent.UI project and select "Set as Startup Project"
- Start debugging by pressing
F5or clicking the "Start" button - Verify that the debugger breaks at your breakpoint and you can inspect variables and step through code
Known issue: You may encounter approximately 78 errors during the start of debugging.
Solution: If you encounter errors, right-click on the PowerAccent folder in Solution Explorer and select "Rebuild". After rebuilding, start debugging again.