Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Kierek/WiVRn

 
 

Repository files navigation

WiVRn

License: GPL v3 CI Format

WiVRn wirelessly connects a standalone VR headset to a Linux computer. You can then play PCVR games on the headset while processing is done on the computer.

It supports a wide range of headsets such as Quest 1 / 2 / Pro / 3 / 3S, Pico Neo 4, HTC Vive Focus 3, HTC Vive XR elite and most other Android based headsets.

Getting started

Server and dashboard

We recommend using the flatpak package from Flathub:

Flathub

Alternatively, packages are available:

Headset app

Follow the wizard in the dashboard to install the client app on the headset: it will either lead you to the Meta Store or download the correct APK.

⚠️ You will need to have a compatible version: if the headset fails to connect to your computer, see troubleshooting.

Usage

Running

Prerequisites

Avahi must be running:

systemctl enable --now avahi-daemon

If a firewall is installed, open port 5353/UDP for avahi. Open ports 9757/UDP+TCP for WiVRn itself.

Running

  • On your computer, run "WiVRn server" application, or wivrn-dashboard from the command line, it will show the connection wizard the first time you launch it.
  • On your headset, run WiVRn from the App Library. If you are using a Quest and you have installed it from an APK instead of the Meta Store, it will be in the "unknown sources" section.
  • You should now see your computer in the list: click connect, the screen will show "Connection ready. Start a VR application on your computer's name".

You can now start an OpenXR application on your computer. For Steam games, you will also need to set the launch options to be able to use WiVRn:

  • Right-click on the game you want to play in VR in Steam and click "Properties".
  • In the "General" tab, set the launch options to the value given in the dashboard.

You can set an application to be started automatically when you connect your headset in the dashboard settings or manually

OpenVR and Steam games

The flatpak also includes OpenComposite, used to translate the OpenVR API used by SteamVR to OpenXR used by WiVRn, see SteamVR for details.

If using Wine/Proton, it will probe for OpenVR at startup, so even for OpenXR applications, OpenComposite is required.

When you start the server through flatpak, it will automatically configure the current OpenVR to use OpenComposite.

Steam Flatpak

If you're using the Steam Flatpak, you'll need to grant read only access to the following paths:

flatpak override --user \
  --filesystem=xdg-run/wivrn:ro \
  --filesystem=xdg-data/flatpak/app/io.github.wivrn.wivrn:ro \
  --filesystem=xdg-config/openxr:ro \
  --filesystem=xdg-config/openvr:ro \
  com.valvesoftware.Steam

Then create a symlink for the OpenXR configuration file (the directory ~/.var/app/com.valvesoftware.Steam/.config/openxr will need to be created if it doesn't already exist):

ln -s ~/.config/openxr/1 ~/.var/app/com.valvesoftware.Steam/.config/openxr/1

Audio

When the headset is connected, WiVRn will create a virtual output device named WiVRn. It is not selected as default and you should either assign the application to the device when it is running, or mark it as default. To do so you can use pavucontrol or your desktop environment's configuration panel. Please note that in pavucontrol it will appear as a virtual device.

For microphone, you first have to enable it on the settings tabs on the headset (and give permission when prompted). It will then appear as a virtual input device named WiVRn(microphone) and also needs to be assigned like for output device.

Building

See building for building the dashboard, server (PC), and client (headset)

Configuration

Configuration can be done from the dashboard.

See configuration for editing the configuration manually.

Troubleshooting

My computer is not seen by the headset

If the server list is empty in the headset app:

  • Make sure your computer is connected on the same network as your headset
  • Check that avahi is running with systemctl status avahi-daemon, if it is not, enable it with systemctl enable --now avahi-daemon
  • If you have a firewall, check that port 5353 (UDP) is open

My headset does not connect to my computer

  • If you have a firewall, check that port 9757 (UDP and TCP) is open
  • The server and client must be compatible:

How do I use a wired connection?

  • Make sure the WiVRn Server is installed and running on your computer
  • Make sure you have the WiVRn app installed on your headset
  • After starting the "WiVRn Server" on your computer and ensuring your device is connected to your PC via cable, run the following in your terminal (Note: using adb on some devices may require developer mode to be enabled):
    •  adb reverse tcp:9757 tcp:9757
       adb shell am start -a android.intent.action.VIEW -d "wivrn+tcp://localhost" org.meumeu.wivrn
    • Depending on your install type, you may need to replace org.meumeu.wivrn (Meta Store install) with:
      • org.meumeu.wivrn.github for releases on Github
      • org.meumeu.wivrn.github.nighly for Github nightlies (wirvn-apk repository)
      • org.meumeu.wivrn.github.testing for Github CI builds
      • org.meumeu.wivrn.local for developer builds
  • You can now continue the pairing process as documented in the running section.

How do I see server logs when using the dashboard?

journalctl -f --no-hostname -u io.github.wivrn.wivrn.desktop

Contributing

Translations

See translating for procedure.

Credits

WiVRn uses the following software:

About

An OpenXR streaming application to a standalone headset

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 88.1%
  • QML 4.2%
  • CMake 3.0%
  • Python 1.4%
  • C 1.0%
  • GLSL 0.8%
  • Other 1.5%