Skip to content

enaix/smartwheel-core

Repository files navigation

smartwheel-core logo

A powerful keyboard knob controller with GUI

smartwheel-core render

Why do I need it?

The main problem with keyboard encoders and standalone dials is that there aren't many features out of the box, but they can be much, much more powerful than they are right now. Have you seen those techy gadgets from Hollywood blockbusters that hackers use (like Q's fancy joystick from latest 007)? Smartwheel gives you the same functionality, but adapted for day-to-day use.

Smartwheel is written in Python/PyQt6, so it could be easily modded with custom plugins. There aren't many right now, but this project is in constant development - there will be more soon.

smartwheel-core ui

Features

Universal keyboards/dials support

Smartwheel will work with any knob - no support from the vendor required

A wide range of addons

There will be a wide range of plugins: from Krita/PS integrations to small quality-of-life imporvements

Theming

Smartwheel is fully customizable (you can even create any keybinds if you want)

Installation

You may install the prebuilt stable version from the releases.

Development build

Make sure that Python 3 is installed

Stable version

pip3 install smartwheel-core

From Github

git clone https://github.com/enaix/smartwheel-core.git

cd smartwheel-core

pip3 install .

Compilation

Nuitka now supports only Python <= 3.11

./build.sh, .\build.bat or ./build_macos.sh

To create macos dmg file run ./package_macos_dmg.sh

We need your help!

I've started working on this project a while ago, but it turned out that it's too big: it won't be possible to finish it without your help. However, it's much easier to implement features one-by-one: you only need basic Python3 (and sometimes PyQt6) knowledge. If you believe in this project and want to contribute, please DM me. Even small fixes, ideas or suggestions are very important.

Discord: server link

Documentation

Docs are available at readthedocs: https://smartwheel-core.readthedocs.io/en/latest/

Release 1.0.0

  • Stable version (Linux)
  • Documentation (in progress)
  • Examples (in progress)
  • Initial encoders support (Linux)
  • Refactor api
    • Move to PyQt6
    • Add colorable icons
    • Add modules background processes
    • Add proper API package
    • Rewrite actionengine with pulses & acceleration
    • Rewrite serial input with new api
    • Add key combos
    • Finish folders support
  • Settings menu (in progress)
    • Basic stuff
    • Custom handlers support (Almost)
    • Saving
    • Theme presets
    • Add color picker
    • Actions editor
    • Sections editor
    • Add unified input editor (new input api)
    • Better overlays editor (?)
    • Modules import (.zip) (?)
  • Wheel hiding
    • Hide after timeout
    • Hide after losing window focus
  • Packaging
    • Configure setup.py
    • Add update feature
    • Hire core doctor!
  • Windows support
    • (Platform) Replace AF_UNIX socket with network socket
    • Add proper media fetching
  • Mac support
    • Add CI builds
    • Fix keypresses simulation
    • Add permission requests

Features progress

  • Base structure (Plugins manager)
  • Action engine
    • Keyboard bindings
    • Serial encoder integration (Partial)
    • UX Features (acceleration)
    • Keyboard knobs support (Almost)
  • Settings editor (Partial)
  • Custom plugins (from JSON)
  • Folders support (Partial)
  • Wheel UI
  • Addons
    • Media
    • Color picker
    • Scroll
    • Files (Initial)
    • Rotate
    • Timeline
    • MIDI device (with multiple encoders)
    • Other ...
  • Krita integration (Partial)
    • Color
    • Canvas rotate/scale
    • Brush
    • ...
  • Photoshop integration (?)

DIY knob

If you don't have a standalone dial, you may 3D print one!

Gallery

Short video (sorry for the poor quality): smartwheel.mp4

Update: added UI overlays smartwheel2.mp4

Resources

Ionicons icon set https://github.com/ionic-team/ionicons