Skip to content

petoncle/mousemaster

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1,412 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

mousemaster

Join Discord Chat

  • Keyboard driven mouseless mouse control and advanced keyboard customization
  • Heavily inspired by warpd, mouseable and kanata

DemoOverviewInstallationUsageFeaturesContributing

Demo

Hints Demo

mousemaster-demo.mp4

Hint Styling Showcase

UI Hints Demo

Grid Demo

mousemaster-grid.mp4

Mouse Movements Demo

mousemaster-mouse-movements1.mp4

Overview

mousemaster lets you control your mouse from the keyboard and remap your keys.

  • Continuous mouse movement: Move the cursor with keyboard keys (IJKL by default), click, scroll, and drag
  • Hint navigation: Cover the screen with a grid of labeled hints, type a label to jump the cursor there
  • UI hint navigation: Label buttons, links, and text fields in the active window
  • Grid navigation: Divide the screen into a grid that you progressively refine to narrow down to a specific area
  • Key remapping: Define combos to remap keys, send key sequences, or type text

Installation

  1. Download mousemaster.exe (a portable executable) from the Release page, or build it from source.
  2. In the same Release page, choose and download one of the existing configuration files:
  3. Place the executable and the configuration file of your choice in the same directory.
  4. Rename the configuration file to mousemaster.properties.
  5. Run mousemaster.exe: make sure to run it as administrator if you want the mousemaster overlay to be displayed on top of everything else.
  6. Feel free to open a GitHub Issue or join the Discord if you need help creating your own configuration. If you have ideas for a better configuration that you would like to share, I'd love to hear from you.

Usage

Default Configuration (neo-mousekeys-ijkl)

The recommended configuration uses the following key bindings:

  • Activate: Press leftalt + e or leftalt + capslock
  • Deactivate: Press q or p
  • Mouse movement: Use i (up), j (left), k (down), l (right)
  • Mouse buttons: ; (left), rightshift (middle), ' (right)
  • Grid mode: Press g
  • Hint mode: Press f
  • UI Hint mode: Press leftalt + f
  • Screen selection: Press c

neo-mousekeys-ijkl layout

For a complete reference, see the neo-mousekeys-ijkl documentation.

Features

  1. Combos and key remapping: Define combos (key sequences, chords, timed holds, taps, tap-dances, and more) to trigger commands or remap keys. See the combo reference.
  2. Continuous mouse movement: Move the cursor, click, scroll, and drag, all from the keyboard.
  3. Hint navigation: Cover the screen with a grid of labeled hints, type a label to jump the cursor there.
  4. UI hint navigation: Labels buttons, links, and text fields in the active window.
  5. Grid navigation: Divide the screen into 2x2 sections, shrink with each key press to reach a precise position.
  6. Zoom.
  7. App-specific modes: Auto-switch modes based on the focused app.
  8. Cursor indicator: Custom shape, color, outline, shadow, text label, changes per mouse state.
  9. Position history: Save cursor positions, jump back to them later.
  10. Live configuration: All configuration lives in a single file that is automatically reloaded when saved.

mousemaster provides low-level primitives (modes, combos, commands, macros, key aliases) that you compose to build the exact behavior you want. See the configuration reference.

Contributing

Contributions to mousemaster are welcome!

  • Share a configuration: If you have ideas for a new or improved configuration that you would like to share, open an issue or join the Discord.

  • Cross-platform support: mousemaster currently supports Windows only. That said, most of the overlay has been reimplemented to be cross-platform. The remaining work is keyboard/mouse input handling and sending inputs on macOS and Linux.

    If you're interested in helping extend mousemaster to these platforms, your contributions are very welcome. Please open an issue or join the Discord to get involved.

If you enjoy mousemaster, consider making a donation or stop by the Discord to show your support!