wayvr-org / wayvr
Your way to enjoy VR on Linux. Run apps inside VR & access your Wayland/X11 screens from Monado/WiVRn/SteamVR.
View on GitHubAI Architecture Analysis
This repository is indexed by RepoMind. By analyzing wayvr-org/wayvr in our AI interface, you can instantly generate complete architecture diagrams, visualize control flows, and perform automated security audits across the entire codebase.
Our Agentic Context Augmented Generation (Agentic CAG) engine loads full source files into context on-demand, avoiding the fragmentation of traditional RAG systems. Ask questions about the architecture, dependencies, or specific features to see it in action.
Repository Overview (README excerpt)
Crawler viewWayVR (previously WlxOverlay-S) A lightweight OpenXR/OpenVR overlay for Wayland and X11 desktops. WayVR lets you access your desktop screens while in VR, and even launch apps directly in VR. In comparison to similar overlays, WayVR aims to run alongside VR games and experiences while having as little performance impact as possible. The UI appearance and rendering techniques are kept as simple and efficient as possible, while still allowing a high degree of customizability. Join the Linux VR Community We are available on either **Discord** or **Matrix space**: Questions/issues specific to WayVR will be handled in the chat room. Feel free to ask anything. Setup Installation There are multiple ways to install WayVR: • AppImage: Download from Releases • AUR package: wayvr or wayvr-git • Nix package: wayvr or unstable package from nixpkgs-xr • Building from source. General Setup • Start Monado, WiVRn or SteamVR. • Run the overlay **Note:** If you are using Monado or WiVRn, no additional setup steps are required for Flatpak Steam compatibility—most people use WayVR seamlessly with Monado/WiVRn. SteamVR via Steam Flatpak For users specifically running **SteamVR via Steam Flatpak**, follow these steps: • Grab the latest AppImage from Releases. • • • Move the newly created folder to a location accessible by the Steam Flatpak. • • Restart Steam. • Start SteamVR. • First Start **When the screen share pop-up appears, check your notifications or the terminal and select the screens in the order it requests.** In case screens were selected in the wrong order: • Go to Settings and press and then • Pay attention to your notifications, which tell you in which order to pick the screens. • If notifications don't show, try starting WayVR from the terminal and look for instructions in there. **WiVRn users**: Select WayVR from the drop-down. If there's no such entry, select and browse to your WayVR executable or AppImage. **Envision users**: Go to the Plugins menu and select the WayVR plugin. This will download and run the AppImage version of the overlay. To run a standalone installation (for instance, from the AUR), create a bash script containing and then set this bash script as a custom Envision plugin. This will show a home environment with headset passthrough enabled by default or a customizable background! **SteamVR users**: WayVR will register itself for auto-start, so there is no need to start it every time. Disclaimer: SteamVR will sometimes disregard this and not start WayVR anyway. **Please continue reading the guide below.** Getting Started Working Set The working set consists of all currently selected overlays: screens, mirrors, keyboard, etc. The working set appears in front of the headset when shown, and can be re-centered by hiding and showing again. Show and hide the working set using: • Non-vive controller: double-tap B or Y on the left controller. • Vive controller: double-tap the menu button on the left controller (for SteamVR, the binding must be bound) See the bindings section on how to grab, move and resize overlay windows. Pointer Modes AKA Laser Colors Much of the functionality in WayVR depends on what color of laser is used to interact with a UI element. \ Using the default settings, there are 3 modes: • Regular Mode: Blue laser • Right-click Mode: Orange laser • Middle-click Mode: Purple laser Please see the bindings section below on how to activate these modes. The guide here uses the colors for ease of getting started. The watch Check your left wrist for the watch. The watch is the primary tool for controlling the app. The top of the watch shows device batteries, and the bottom shows your overlay controls. Enter edit mode (the leftmost button at the bottom) to edit your overlay sets. While in edit mode, the watch can also be grabbed and passed between your hands. After grabbing, the watch will automatically attach to the hand that's opposite from the one that held it. In edit mode, try hovering over other overlays to see their advanced options! The screens Hovering a pointer over a screen will move the mouse. If more than one pointer is hovering over a screen, the pointer that was last used to click will take precedence. The click type depends on the laser color: • Blue laser: Left click • Orange laser: Right click • Purple laser: Middle click • Stick up/down: Scroll wheel The keyboard Typing • Use the BLUE laser when typing regularly. • While using the ORANGE laser, all keystrokes will have SHIFT applied. • Purple laser is customizable via the settings, no modifier by default. **Modifier Keys are sticky**. They will remain pressed until eiter: • a non-modifier key is pressed • the modifier is toggled off by clicking again • the keyboard is hidden (including via show-hide) Default Bindings Changing Bindings SteamVR: Simply change the bindings from the SteamVR bindings section. If WayVR doesn't show up on the list, select any other title and then press back on the top left. (SteamVR is weird like that sometimes) OpenXR (Monado/WiVRn): See Wiki: OpenXR Bindings If your controllers are not supported, please reach out. \ We would like to work with you and include additional bindings. Customization See these relevant wiki pages: • For all available config options, check Wiki: Configuration • Looking to customize look & feel, or add functionality? See Wiki: Customization • Looking to change the OpenXR background? See Wiki: OpenXR Skybox Troubleshooting When an error is detected, we often print tips for fixing it into the log file. Logs will be at for most distros. Check here for tips. Known Issues Mouse is not where it should be If the mouse is moving on a completely different screen, the screens were likely selected in the wrong order: • Go to Settings and press and then • Pay attention to your notifications, which tell you in which order to pick the screens. • If notifications don't show, try starting WayVR from the terminal and…