-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Driver Documentation
This is an overview of the steps to write a new OpenVR driver. In the examples, the driver is simply called "mydriver".
It is advisable to use the built-in SteamVR drivers as references. For example, the Oculus driver is maintained by Valve and demonstrates nearly all of the below features (excluding driver registration). The built-in drivers can be found in your Steam install directory in the sub-path 'Steam\steamapps\common\SteamVR\drivers'.
- Put all the files for your driver under a directory. Let's say that directory is "/mydriver"
- Add a new DLL to "mydriver/bin/win64/driver_mydriver.dll" (For Linux use the appropriate platform directory and the appropriate shared library extension.)
- Implement the driver factory function in that DLL.
-
Add an implementation ofThis was removed in OpenVR version 1.0.6.vr::IClientTrackedDeviceProvider
to the DLL and return it from the factory. This provider will be phased out in the next SDK udpate, but for now you need it. - Add an implementation of
vr::IServerTrackedDeviceProvider
and have that return implementations ofvr::ITrackedDeviceServerDriver
for each tracked device. - Add a driver manifest file to "/mydriver"
- Add and remove your driver to SteamVR's config file using vrpathreg.
For drivers with status icons, you can add icons files to 'mydriver/resources/icons'. These metadata to map hardware status to the appropriate icon belongs in 'mydriver/resources/driver.vrresources'.
For drivers with custom artwork in the input binding UI, add SVG files to the same folder, 'mydriver/resources/icons'.
For drivers with localized strings, add localization for all languages to 'mydriver/resources/localization/localization.json'. This will affect the strings that are displayed in the UI related to your hardware, for example, in the input binding UI. Generally, you only need to provide translations for the names of your hardware and input paths. If localization is working for some, but not all of your devices, then you may need to explicitly tell OpenVR to use a certain resource namespace. To do this, add a line to the input profile for the device that is not working, "resource_root" : "", where the is replaced with the driver's name as written in the .vrdrivermanifest.
For devices with buttons, triggers, joysticks, and other kinds of input controls, please refer to the vr::IVRDriverInput
API.
For devices that wish to provide animation data through the Skeletal Input system, please refer to the Skeletal Input Driver documentation.
The source code for a sample driver is available here. The sample implements these interfaces and includes an example HMD/controller.
Other driver documentation: