/openxr-steamvr-passthrough

OpenXR API Layer for SteamVR camera passthrough

Primary LanguageC++MIT LicenseMIT

OpenXR SteamVR Passthrough API Layer

This OpenXR API layer adds camera passthrough support to the SteamVR OpenXR runtime. It allows OpenXR applications that use the OpenXR passthrough feature to enable it when using the SteamVR runtime.

The SteamVR runtime itself does not currently support any OpenXR passthrough features, but provides access to the camera video feeds and projection data through the proprietary OpenVR interface. This layer acts as a compositor in-between the application and runtime, retrieves the passthrough data from OpenVR, and renders it on the frames submitted by the application before passing them on to the runtime.

Please report any issues! Any comments and suggestions are also appreciated.

DISCLAIMER

This is an experimental release. Please be careful when using the passthrough.

This software is distributed as-is, without any warranties or conditions of any kind. Use at your own risk!

Using the 3D stereo mode may induce heavy flickering on the display. Exercise caution if you are photosensitive.

Features

  • Supports both application selectable environment blend modes in the OpenXR core specification: Alpha Blended and Additive.
  • Configuration menu available in the SteamVR dashboard.
  • User adjustable color parameters and opacity.
  • Override mode for applying passthrough to applications that do not support it. The passthrough view can be blended using chroma keying.
  • The floor projection height can be shifted up to get correct projection on an horizontal surface such as a desk.
  • EXPERIMENTAL: Supports 3D stereo reconstruction to estimate projection depth, using OpenCV. Includes support for Weighted Least Squares disparity filtering, and Fast Bilateral Solver filtering.
  • EXPERIMENTAL: Supports custom fisheye lens rectification instead of using the OpenVR pre-rectified output.

Limitations

  • Only the SteamVR runtime is supported.
  • Only headsets that provide the passthrough camera feed to SteamVR are supported. If the SteamVR Room View does not work, this will not work.
  • OpenVR applications are not supported.
  • Only applications that use the core specification passthrough by submitting frames with environmentBlendMode set are supported.
  • Applications using the Meta XR_FB_passthrough extension are not currently supported.
  • The default passthrough view only supports a fixed depth reconstruction, while clamping the projection depth to the floor plane of the playspace. This works the same as the the SteamVR 2D Room View mode.
  • The depth reconstruction from the 3D Room View is not supported. It is not currently accessible to developers.
  • The passthrough view has higher latency than the SteamVR compositor.
  • OpenGL applications are not currently supported.
  • The DirectX12 renderer isn't using shared textures for the camera frames. This limits performance.
  • The 3D reconstruction modes do not project the images correctly yet.
  • The 3D stereo reconstruction mode is not supported with Vulkan.

Supported Headsets

  • Valve Index - Supported
  • HTC Vive - Untested, driver only provides correct pose data in 60 Hz mode.
  • HTC Vive Pro - Untested
  • HTC Vive Pro 2 - Untested
  • Other HTC headsets - Unknown
  • Varjo XR headsets - Unknown
  • Windows Mixed Reality headsets - Unsupported, no passthrough support in driver
  • Oculus/Meta headsets - Unsupported, no passthrough support in driver

The SteamVR settings UI will misconfigure the original HTC Vive camera if the frame rate is not set the right way. To correctly set it, click the right end of the slider instead of dragging it. The USB drivers may need to be reset if the camera is incorrectly configured.

Installation

  1. Download and install the Visual Studio C++ Redistributable (64 bit)
  2. Download the API layer release from the GitHub Releases page, and extract the files to the location you want to keep them in.
  3. Run the passthrough-setup.exe utility, and select the Install option to install the API layer. Note that if you want to move the files, you will need to run the utility again.
  4. If you want to disable or uninstall the API layer, run the passthrough-setup.exe utility and select the Uninstall option.

Usage

Starting an OpenXR application will automatically start the API layer. If the application natively supports passthrough, the API layer will by default notify the application that additional environment blend modes are available. If the application does not support the OpenXR passthrough features, it is still possible to enable limited passthrough modes (see below).

While an application is running, the SteamVR dashboard will have an additional button in the bottom left, pressing it will open the settings overlay.

Settings menu

The options under the OpenXR Core allow setting what passthrough modes are available for the application to use, as well as what mode it should prefer. Some applications may automatically switch to the preferred mode even though they don't support passthrough.

The options under Overrides allow forcing the passthrough mode regardless of whether the application has support for passthrough. Note that the Alpha Blend mode will show nothing unless the application submits alpha channels to the compositor.

The Additive mode will blend the passthrough on top of the view.

The Opaque mode will replace the application view with the passthrough.

The Masked mode allows setting a chroma key color that gets replaced with the passthrough view, as well as range for how similar colors get replaced, and a smoothness of the transition.

The settings can also be edited from %APPDATA%\OpenXR SteamVR Passthrough\config.ini

Building from source

The following are required:

  • Visual Studio 2022
  • The MSVC build tools, and the Windows 10 SDK (installed via the Visual Studio Installer as "Desktop development with C++").
  • Python 3 interpreter (installed via the Visual Studio Installer or externally available in your PATH).
  • OpenXR SDK Source (Included as Git submodule)
  • OpenXR SDK (Included as Git submodule)
  • OpenVR (Included as Git submodule)
  • LodePNG (Included as Git submodule)
  • SimpleINI (Included as Git submodule)
  • Dear ImGui (Included as Git submodule)
  • Vulkan SDK (Uses the VULKAN_SDK environment variable)
  • OpenCV 4.7.0 (The project is setup for static linking by default - requires custom source build)
  • OpenCV-Contrib (The ximgproc module needs to be built along with OpenCV for WLS and FBS filtering support.)

Todo

  • Add partial support for the XR_FB_passthrough extension
  • OpenGL support
  • Add edge shader modes
  • Add shared camera textures to DirectX 12 if possible (may only be possible by rendering with DirectX11 with 11On12)
  • Controller and hand depth projection + masking on 3D mode
  • Improvements to 3D reconstruction

Possible improvements

  • XR_HTC_passthrough extension support (no headsets or applications use this yet)
  • Linux support (does passthrough work on Linux?)
  • Passthrough override support for OpenVR apps (better as independent application)
  • Depth buffer based blending

Notes

Based on OpenXR-Layer-Template