See the Tips for using OpenComposite section for solutions to common issues. Thanks to mbucchia for providing this FAQ.
Feel free to comment on the spreadsheet for us to modify its information.
Table of Contents
[TOC]
OpenComposite OpenXR (previously known as OpenOVR - OpenVR for OculusVR - but renamed due to confusion with OpenVR) is an implementation of SteamVR's API - OpenVR, forwarding calls directly to the OpenXR runtime. Think of it as a backwards version of ReVive, for the OpenXR compatible headsets.
This allows you to play SteamVR-based games on an OpenXR compatible headset as though they were native titles, without the use of SteamVR!
Why would you want to do this? There are several good reasons:
- Some users have trouble running SteamVR on their machines
- While more work needs to be done on OpenComposite's side for this, it can potentially get slightly better performance due to several design decisions, due to not having to support the Vive
- OpenXR is less susceptible to the stuttering that has plagued SteamVR
- Again a problem for some people but not others, SteamVR can take some time to start up
- SteamVR is several gigabytes in side - that might be a problem for some people
It currently implements most interfaces, and can play many SteamVR games. However, there are many more games that use versions of interfaces that I have yet to implement - this will result in a popup followed by a crash. If you find a game that does this, please let me know (see below).
There are several things missing though:
- Hand controller models are not present. Some games (eg, Skyrim) will use their own models in this case. For other games, you might not see a controller model at all. Most games use their own hand models though, rather than displaying a model of your controller.
- The virtual keyboard does not yet.
** Some Oculus headsets seem to be incompatible with OpenXR initialising with Vulkan for some games. If you have issues with AC or other games try putting initUsingVulkan=false in the opencomposite.ini (see Configuration section for details.)
OpenComposite can either be installed system-wide (all SteamVR-based games will use it automatically) or per-game (replace a DLL file for each game, this usually must be done each time said game is updated).
(Note that these instructions are intended for Windows, Linux users can scroll down to the Linux specific section)
Download the OpenComposite Launcher. Unzip it to a folder of your choosing,
and run OpenComposite.exe
. Click 'Switch to OpenComposite', and wait while the DLLs are downloaded. Games will now run via OpenComposite
rather than SteamVR.
To update OpenComposite, run OpenComposite.exe
again. The text at the bottom of the window will indicate if an update is available, and
if so an update button will appear. Click it and OpenComposite will be updated.
Download the DLLs: 32-bit 64-bit
These come from AppVeyor - whenever I push some new code, it will be compiled and uploaded to those links automatically.
Find your game's openvr_api.dll
file, and replace it (though I highly recommend keeping a copy of the old file if you want to
switch back) with one of the DLLs available above. Be sure to get the matching platform - if the game is a 32-bit game you need
the 32-bit DLL, even though you're probably running a 64-bit computer. Simple solution: if one doesn't work, try the other.
Some time in the near future I plan to release a system-wide install - run an EXE and all your games will open via OpenComposite, and you'll be able to switch back by starting SteamVR. This will make updating much easier.
If you have any questions, feel free to jump on our Discord server:
Linux builds are available from GitLab CI. 32-bit 64-bit
There is no switcher for Linux yet. As the vast majority of VR games are Windows-only and hence running through Proton, you'll have to essentially do a system wide install, but there is an environment variable available that allows you to set it up per game. (Using the Windows DLLs for a per-game install instead may work, but is untested.)
After downloading and extracting the zip, you should get an OpenComposite folder. Here are some steps you'll have to follow to set it up:
- Get the runtime in place. This can be accomplished through one of the following methods:
- Set the VR_OVERRIDE variable to the OpenComposite directory (in Steam launch options:
VR_OVERRIDE=/path/to/OpenComposite %command%
) - Edit the OpenVR config file - typically located at
~/.config/openvr/openvrpaths.vrpath
- and in the "runtime" section, put the path to the OpenComposite directory. Note that Steam likes to overwrite this file so you may need to set it to read only. - For the elusive native Linux title, you can copy the
vrclient.so
over the game'slibopenvr_api.so
- Set the VR_OVERRIDE variable to the OpenComposite directory (in Steam launch options:
- For games utilizing the Steam Runtime (most of them): you will need to work around the Steam Runtime. Here are some general tips for working around, as setups can differ:
- Any files located in your home directory will exist with no problems in the runtime. There is nothing to take into consideration with these paths, they will work fine.
- Any path located under
/usr
can be found under/run/host/usr
in the runtime. For example, if you installed Monado system wide, the runtime json would be located at/run/host/usr/share/openxr/1/openxr_monado.json
. - Any other paths can be added using the
PRESSURE_VESSEL_FILESYSTEMS_RW
environment variable.
As an example, here is what your Steam launch options might look like if you downloaded OpenComposite to your home directory, used the VR_OVERRIDE environment variable, and installed Monado system wide:
VR_OVERRIDE=~/OpenComposite XR_RUNTIME_JSON=/run/host/usr/share/openxr/1/openxr_monado.json PRESSURE_VESSEL_FILESYSTEMS_RW=$XDG_RUNTIME_DIR/monado_comp_ipc %command%
Note that $XDG_RUNTIME_DIR/monado_comp_ipc
is a socket used by Monado and required to be present for it to properly detect that Monado is running.
You can read more about the PRESSURE_VESSEL_FILESYSTEM_RW
variable and other environment variables utilized by the Steam Runtime here.
On startup, OpenComposite searches for a file named opencomposite.ini
, first next to the openvr_api.dll
file, and if it can't find
that, then it looks in the working directory (usually in the same folder as the EXE). If no file is found, that's fine and all
the default values are used.
This is it's configuration file, where you can specify a number of options. These are listed in name=value
format, and you
can define a comment by starting a line with ;
or a #
. Note the option names are case sensitive. If you specify an invalid
option, the game will immediately crash on startup. Any whitespace between the name, equals sign, and value is ignored, as is whitespace
on the end of the line. Ensure your lines do not being with whitespace however.
The available options are:
renderCustomHands
- boolean, defaultenabled
.- Should OpenComposite render custom hands. Disable this if you really dislike the hand models, and some games (like Skyrim) come with backup models that will be used instead.
handColour
- colour, default#4c4c4c
.- The colour of the hands OpenComposite draws, as they currently lack proper textures.
supersampleRatio
- float, default1.0
.- The supersample ratio in use - this is similar to what you would enter into SteamVR, a value of
145%
in SteamVR is a value of1.45
here. A value of80%
in SteamVR is0.8
here, and so on. Higher numbers improve graphics, at a major performance cost.
- The supersample ratio in use - this is similar to what you would enter into SteamVR, a value of
haptics
- boolean, defaultenabled
.- Should haptic feedback to the controllers be enabled.
admitUnknownProps
- boolean, defaultdisabled
.- If asked for a tracked device property it does not understand, should OpenComposite ignore it.
logGetTrackedProperty
- boolean, defaultdisabled
.- Print logging information when the app requests information about tracked devices, such as the HMD or the Touch controllers. On some games, this causes a log entry to be generated every frame, which isn't great for performance and clutters up the log. This is potentially useful for troubleshooting, and was enabled by default before the config option existed. In general, unless you've been told to enable this (or you know what you're doing while troubleshooting) you don't need to enable this.
stopOnSoftAbort
- boolean, defaultdisabled
.- Crashes the game whenever OpenComposite reaches a soft abort. Currently games can cause OpenComposite to hit a soft abort for a lot of trivial reasons, so you probably shouldn't enable this.
dx10Mode
- booelan, defaultdisabled
.- Use DX10 instead of DX11 for games submitting DirectX textures.
enableHiddenMeshFix
- boolean, defaultenabled
.- Alter the coordinates of the hidden area mesh mask to fit within the view's projection. The hidden area mesh mask defines a region to which the game will not draw and is used to mask off areas of the display that you typically cannot see in the headset. If you see odd black regions around the view then try disabling this fix.
invertUsingShaders
- boolean, defaultdisabled
.- Invert the image for display using shaders rather than replying on XR runtime and inverted FOV values. Some games render the image inverted and rely on the runtime to display correctly. In OpenXR some runtimes don't do the inversion correctly. If so enable this option for OpenComposite to do the inversion when copying the image using shaders. This might have a minor cost in performance.
initUsingVulkan
- boolean, defaulttrue
.- If available the temporary graphics adapter at start up will use Vulkan by default. This may be incompatible with some games. This will mostly affect Oculus headsets.
hiddenMeshVerticalScale
- float, default1.0
.- The scaling factor used for the hidden area mesh if supported by the application. The hidden area mesh is a region that the game doesn't render to. If you set this lower e.g.
0.8
then less will be drawn at the very top and very bottom of the image improving performance. Suggested range is0.5
to1.0
.
- The scaling factor used for the hidden area mesh if supported by the application. The hidden area mesh is a region that the game doesn't render to. If you set this lower e.g.
logAllOpenVRCalls
- boolean, defaultfalse
- Log every OpenVR call a game makes. Similar to
logGetTrackedProperty
, this clutters logs and should not be enabled unless necessary.
- Log every OpenVR call a game makes. Similar to
The possible types are as follows:
- boolean - one of
on
,true
,enabled
to enable the setting, oroff
,false
ordisabled
to do the opposite. These are not case-sensitive, soEnabled
ortRUe
work fine. - colour - same as the format used in HTML/CSS, it's a
#
followed by six hex characters. Mozilla has a tool to help with this. Again, it's case-insensitive. - float - a floating point (decimal) number, eg
123.456
.
Example files:
- Running SkyrimVR with yellow hands, and haptic feedback disabled:
handColour=#ffff00
haptics = off
If you find an issue, missing interface, crash etc then please let me know about it. (Opening a GitLab issue is the preferred way of doing this and you'll automatically get an email when it's fixed (if you let me know via a different method I'll probably make an issue and send you the link to help keep track of them).
If you do not or cannot create or use a GitLab account for whatever reason, you can join the Discord server and report the issue in #bugs.
In any case, please include the contents your opencomposite.log
file which contains potentially
invaluable debugging information. This log file can be found here:
Windows - %localappdata%\OpenComposite\logs (Copy and paste that into explorer) Linux - $XDG_STATE_HOME/OpenComposite/logs (If XDG_STATE_HOME is not defined then check ~/.local/state/OpenComposite/logs)
If those locations do not exist this may be due to some odd security restrictions, check the exe folder for opencomposite.log
Please also say what caused the crash - did it crash on startup, or maybe after clicking load on the main menu, for example?
Download the Source Code from GitLab - it's under the GPLv3 licence.
This project is built with CMake and follows a standard build process, so tools like CLion can be used to build it.
The resulting library will be placed at build/bin/linux64/vrclient.so
on Linux, build/bin/vrclient_x64.dll
on Windows.
If you are building with the intent of contributing upstream, you should build with the cmake flag -DERROR_ON_WARNING=ON
,
as the CI is also using this flag, which turns on treating warnings as errors.
If you want to use Vulkan support (enabled by default, remove SUPPORT_VK
from the preprocessor definitions to compile without it), then
download a slimmed down copy of the Vulkan SDK with only .lib
files and the headers,
and extract it to your libs
directory (you can copy in the full SDK if you want, but it's far larger and probably better to install it
by itself).
This is how the resulting file structure should look:
OpenOVR: (or whatever folder you cloned/downloaded the repo into)
libs:
vulkan:
Include:
Lib:
Lib32:
LICENSE.txt
SDK_LICENSE.rtf
Vulkan.ico
openxr-sdk:
... etc
OpenComposite will search for Vulkan installed via your package manager. Cloning the Vulkan SDK is not necessary. If not using an IDE with CMake support, a set of commands to successfully compile might look like this after navigating to the source directory:
mkdir build
cd build
cmake ..
cmake --build .
The build directory will be set up in a way that you can simply set VR_OVERRIDE
to its path.
OpenComposite relies fairly heavily on scripts that generate code, and this has vastly simplified things - I expect the repo would contain roughly three to four times more code otherwise.
There are two main scripts at work:
- A script to take various OpenVR header files, and split them into one header file for each version of each interface. This allows the project to reference many versions of the same interface.
- A script to generate the interface stubs - in LibOVR, there is one implementation of each interface,
which are the base interfaces (eg
BaseSystem
,BaseCompositor
, etc). There are then autogenerated 'stub' classes, which implement a binary-compatible version of one version of that interface (egGVRSystem_017
,GVRSystem_015
,GVRCompositor_022
), along with C-likeFnTable
s for them (which allow compatibility with other languages, very notably C#).
These scripts are automatically run when buildling the project. If you have added or removed OpenVR headers this will cause CMake to rebuild
the project, otherwise it will only rebuild a couple of files which is very quick.
You can read more about why these scripts exist and how they work in the doc/
folder of this repository.
OpenComposite itself is Free Software under the GPLv3:
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
GPL Full Text. This also can be found in
the LICENCE.txt
file supplied with the source code.
The OpenXR SDK is included as a git submodule. It's under the Apache 2 licence, the full text of
which can be found under libs/openxr-sdk/LICENSE
.
This program (and it's source code) includes several versions of the
OpenVR headers. These are under the
MIT Licence. This also can be
found in the LICENSE_OPENVR.txt
file supplied with the source code.
Copyright (c) 2015, Valve Corporation
All rights reserved.
This program uses the inih INI parsing library by Ben Hoyt. This is available under
the MIT licence, a copy of which can be found in the LICENSE_INIH
file of this repository.
This program uses a part of Psiha's and Microblink's build CMake utilities
library. This is available under the two-clause BSD licence, a copy of which can be found in the LICENCE_BUILD_UTIL.txt
file of this repository.
This programme uses Scott Tsai's DebugBreak library when built on Linux. It's full
text can be found in LICENCE_DEBUG_BREAK.txt
.