Skip to main content

A Windows virtual desktop switcher with keyboard shortcuts

Project description

Dodo Desktop Switcher

A lightweight Windows system tray application that adds convenient keyboard shortcuts for Windows 10/11 virtual desktops.

The Problem

Windows 10 and 11 have excellent built-in virtual desktop support, but the default keyboard shortcuts are awkward:

  • Ctrl+Win+Left/Right - Hard to remember which direction is which desktop
  • No direct jumping - You must cycle through desktops one by one to reach desktop 5
  • Awkward window moving - Moving windows between desktops requires multiple steps
  • No quick "return to previous" - Can't easily toggle between two workspaces

If you're trying to organize your work across multiple virtual desktops, these limitations make the feature frustrating to use.

The Solution

Dodo provides intuitive keyboard shortcuts that make virtual desktops actually usable:

  • Alt+1 through Alt+9 - Jump directly to desktops 1-9
  • Alt+0 - Jump to desktop 10
  • Alt+- - Return to your previous desktop (like Alt+Tab but for desktops)
  • Alt+Shift+1 through Alt+Shift+0 - Move the active window to a specific desktop
  • Alt+Shift+` - Pin/unpin the active window to all desktops

Dodo automatically ensures you have 10 virtual desktops available and shows a brief on-screen indicator when you switch desktops.

Installation

pip install dodo-desktop-switcher

Auto-start with Windows

To have Dodo start automatically when you log in:

dodo --install

This creates a shortcut in your Windows Startup folder. Dodo will run silently in your system tray.

To remove from startup:

dodo --uninstall

To check installation status:

dodo --status

Usage

After installation, simply run:

dodo

Dodo will appear in your system tray. The keyboard shortcuts are immediately active.

Right-click the system tray icon to:

  • View all available shortcuts
  • Manually switch desktops via menu
  • Exit the application

Requirements

  • Windows 10 or Windows 11
  • Python 3.12 or later
  • Virtual desktops must be enabled (they are by default)

How It Works

Dodo doesn't create or manage virtual desktops itself - Windows does all the heavy lifting. Dodo simply:

  1. Uses the pyvda library to interface with Windows' built-in Virtual Desktop API
  2. Registers global hotkeys using pywin32
  3. Provides a system tray interface using wxPython

This means Dodo is lightweight, reliable, and works seamlessly with Windows' native virtual desktop features.

Uninstallation

dodo --uninstall  # Remove from startup
pip uninstall dodo-desktop-switcher

Troubleshooting

Hotkeys don't work:

  • Make sure Dodo is running (check system tray)
  • Check if another application is using the same keyboard shortcuts
  • Try restarting Dodo

"Failed to initialize Virtual Desktop Manager":

  • Virtual desktops must be enabled in Windows
  • Try creating a virtual desktop manually first (Win+Tab, then "New Desktop")
  • Restart Windows and try again

Application doesn't start:

  • Make sure you're running Windows 10 or 11
  • Check that all dependencies installed correctly: pip install --upgrade dodo-desktop-switcher

License

MIT License - see LICENSE file for details.

Author

Created by Ram Rachum (ram@rachum.com)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

dodo_desktop_switcher-0.1.1.tar.gz (11.9 kB view details)

Uploaded Source

File details

Details for the file dodo_desktop_switcher-0.1.1.tar.gz.

File metadata

  • Download URL: dodo_desktop_switcher-0.1.1.tar.gz
  • Upload date:
  • Size: 11.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.13.1

File hashes

Hashes for dodo_desktop_switcher-0.1.1.tar.gz
Algorithm Hash digest
SHA256 62594712ff82c7e296e6e4f88eb14ea7262dea0e27061e5d020dda97ec4827ac
MD5 37b8ce9e2f37fb2a8a4bc832fd3b5215
BLAKE2b-256 aa96c3a50b885f844d6d2723e135ef838b013a200ebfad7a640be876f5610574

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page