-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathindex.html
More file actions
372 lines (343 loc) · 24.3 KB
/
index.html
File metadata and controls
372 lines (343 loc) · 24.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no" />
<meta name="description" content="" />
<meta name="author" content="" />
<title>WiVRn - Wireless Virtual Reality streaming for Linux</title>
<link rel="icon" type="image/x-icon" href="assets/favicon.ico" />
<!-- Font Awesome icons (free version)-->
<script src="https://use.fontawesome.com/releases/v6.3.0/js/all.js" crossorigin="anonymous"></script>
<!-- Google fonts-->
<link href="https://fonts.googleapis.com/css?family=Varela+Round" rel="stylesheet" />
<link href="https://fonts.googleapis.com/css?family=Nunito:200,200i,300,300i,400,400i,600,600i,700,700i,800,800i,900,900i" rel="stylesheet" />
<!-- Core theme CSS (includes Bootstrap)-->
<link href="css/styles.css" rel="stylesheet" />
<script>
function select_tab(id)
{
var someTabTriggerEl = document.querySelector(id)
var tab = new bootstrap.Tab(someTabTriggerEl)
tab.show()
}
function select_carousel(id, slide_nr)
{
const myCarouselElement = document.querySelector(id)
const carousel = new bootstrap.Carousel(myCarouselElement)
carousel.to(slide_nr)
}
</script>
</head>
<body id="page-top">
<!-- Navigation-->
<nav class="navbar navbar-expand-lg navbar-light fixed-top" id="mainNav">
<div class="container px-4 px-lg-5">
<a class="navbar-brand" href="#page-top">WiVRn</a>
<button class="navbar-toggler navbar-toggler-right" type="button" data-bs-toggle="collapse" data-bs-target="#navbarResponsive" aria-controls="navbarResponsive" aria-expanded="false" aria-label="Toggle navigation">
Menu
<i class="fas fa-bars"></i>
</button>
<div class="collapse navbar-collapse" id="navbarResponsive">
<ul class="navbar-nav ms-auto">
<li class="nav-item"><a class="nav-link" href="#get-started">Get started</a></li>
<li class="nav-item"><a class="nav-link" href="#privacy">Privacy</a></li>
<li class="nav-item"><a class="nav-link" href="#faq">FAQ</a></li>
<li class="nav-item"><a class="nav-link" href="#contact">Contact</a></li>
</ul>
</div>
</div>
</nav>
<!-- Masthead-->
<header class="masthead">
<div class="container px-4 px-lg-5 d-flex h-100 align-items-center justify-content-center">
<div class="d-flex justify-content-center">
<div class="text-center">
<h1 class="mx-auto my-0">WiVRn</h1>
<img src="assets/img/wivrn.svg"/>
<h2 class="text-white-50 mx-auto mt-2 mb-5">Access your PC VR applications from a standalone headset</h2>
<a class="btn btn-primary" href="#about">About</a>
</div>
</div>
</div>
</header>
<!-- About-->
<div id="about">
<!-- <div class="container px-4 px-lg-5">
<div class="row gx-4 gx-lg-5 justify-content-center">
<div class="col-lg-8">
<h2 class="text-white mb-4">About WiVRn</h2>
</div>
</div>
</div>-->
<!-- Getting started -->
<section class="get-started-section bg-light" id="get-started">
<div class="container px-4 px-lg-5">
<div class="row gx-4 gx-lg-5 justify-content-center">
<div class="col-lg-8">
<h2 class="text-black mb-4">Get started</h2>
<div class="row gx-0 my-5 justify-content-center">
<h4>Install the dashboard on your computer</h4>
<ul class="nav nav-tabs" id="myTab" role="tablist">
<li class="nav-item" role="presentation">
<button class="nav-link active" id="flatpak-tab" data-bs-toggle="tab" data-bs-target="#flatpak" type="button" role="tab" aria-controls="flatpak" aria-selected="true">Flatpak</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="archlinux-tab" data-bs-toggle="tab" data-bs-target="#archlinux" type="button" role="tab" aria-controls="archlinux" aria-selected="true">Arch Linux</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="source-tab" data-bs-toggle="tab" data-bs-target="#fedora" type="button" role="tab" aria-controls="source" aria-selected="false">Fedora</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="gentoo-tab" data-bs-toggle="tab" data-bs-target="#gentoo" type="button" role="tab" aria-controls="gentoo" aria-selected="false">Gentoo</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="source-tab" data-bs-toggle="tab" data-bs-target="#source" type="button" role="tab" aria-controls="source" aria-selected="false">From source</button>
</li>
</ul>
<div class="tab-content" id="myTabContent">
<div class="tab-pane fade show active" id="flatpak" role="tabpanel" aria-labelledby="flatpak-tab">
<p>The dashboard is available on Flathub:</p>
<a href="https://flathub.org/apps/io.github.wivrn.wivrn"><img width="240" alt="Get it on Flathub" src="https://flathub.org/api/badge?locale=en" class="mx-2 my-2"/></a>
</div>
<div class="tab-pane fade" id="archlinux" role="tabpanel" aria-labelledby="archlinux-tab">
<p>A <a href="https://aur.archlinux.org/packages/wivrn-dashboard">wivrn-dashboard</a> package is available on AUR:</p>
<code>yay -S wivrn-dashboard</code>
<p/>
<p>In order to run OpenVR or any Steam game, a compatibility library such as opencomposite or xrizer is also needed:</p>
<code>yay -S xrizer-git</code>
</div>
<div class="tab-pane fade" id="fedora" role="tabpanel" aria-labelledby="fedora-tab">
<p>A <a href="https://packages.fedoraproject.org/pkgs/wivrn/wivrn/">wivrn</a> package is available in Fedora:</p>
<code>sudo dnf install wivrn</code>
<p/>
<p>Note that patented codecs (H.264 and H.265) are not available by default on Fedora, you will have to install them from rpmfusion if you need to use such codecs.</p>
</div>
<div class="tab-pane fade" id="gentoo" role="tabpanel" aria-labelledby="gentoo-tab">
<p>A <a href="https://gitweb.gentoo.org/repo/proj/guru.git/tree/media-libs/wivrn">media-libs/wivrn</a> package is available on Guru.</p>
<p>In order to run OpenVR or any Steam game, <a href="https://gitweb.gentoo.org/repo/proj/guru.git/tree/media-libs/xrizer">media-libs/xrizer</a> or <a href="https://gitweb.gentoo.org/repo/proj/guru.git/tree/media-libs/opencomposite">media-libs/opencomposite</a> is also required.</p>
</div>
<div class="tab-pane fade" id="source" role="tabpanel" aria-labelledby="source-tab">
Instructions for building the WiVRn dashboard from source are available on the <a href="https://github.com/WiVRn/WiVRn/blob/master/docs/building.md#server-pc">GitHub repository</a>.
</div>
</div>
</div>
<div class="row gx-0 my-5 justify-content-center">
<h4>Install the client on your headset</h4>
<ul class="nav nav-tabs" id="myTab2" role="tablist">
<li class="nav-item" role="presentation">
<button class="nav-link active" id="metastore-tab" data-bs-toggle="tab" data-bs-target="#metastore" type="button" role="tab" aria-controls="adb" aria-selected="true">Meta Store</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="wizard-tab" data-bs-toggle="tab" data-bs-target="#wizard" type="button" role="tab" aria-controls="wizard" aria-selected="true">Connection Wizard</button>
</li>
<li class="nav-item" role="presentation">
<button class="nav-link" id="source2-tab" data-bs-toggle="tab" data-bs-target="#source2" type="button" role="tab" aria-controls="source2" aria-selected="false">From source</button>
</li>
</ul>
<div class="tab-content" id="myTabContent2">
<div class="tab-pane fade show active" id="metastore" role="tabpanel" aria-labelledby="metastore-tab">
<p>WiVRn is available on the <a href="https://www.meta.com/experiences/7959676140827574/">Meta Store</a> for Quest 2 / 3 / Pro. For other headsets, including the Quest 1, you will have to sideload it by following the <a href="" onclick="select_tab('#wizard-tab'); return false">connection wizard</a> in the dashboard<!-- or manually with <a href="" onclick="select_tab('#wizard-tab'); return false">adb</a>-->.</p>
</div>
<div class="tab-pane fade" id="wizard" role="tabpanel" aria-labelledby="wizard-tab">
<p>When you start the dashboard the first time, the connection wizard will help you install the client on your headset.</p>
<p>You can run it later by clicking the "Wizard" button in the dashboard.</p>
</div>
<!-- <div class="tab-pane fade" id="adb" role="tabpanel" aria-labelledby="adb-tab">
Your headset needs to be configured in developer mode.<br/>
Download the <a href="https://github.com/WiVRn/WiVRn/releases/latest/download/WiVRn-standard-release.apk">latest WiVRn client</a> from GitHub.<br/>
Install the APK with <code>adb install WiVRn-standard-release.apk</code>
</div>-->
<div class="tab-pane fade" id="source2" role="tabpanel" aria-labelledby="source2-tab">
Instructions for building the WiVRn headset app from source are available on the <a href="https://github.com/WiVRn/WiVRn/blob/master/docs/building.md#client-headset">GitHub repository</a>.
</div>
</div>
</div>
<div class="row gx-0 my-5 justify-content-center">
<h4>Connect your headset to your computer</h4>
<div>
<ol>
<li>Start the WiVRn dashboard on your PC<br/><!--TODO: image--></li>
<li>Start the WiVRn client on your headset
<p>On a Quest, if you did not install it from the Meta Store, it will be in the <a href="" onclick="select_carousel('#getting-started-slides', 4); return false">"Unknown Sources"</a> section.</p>
<!--<br/>TODO: image--></li>
<li>Connect to your PC from your headset<br/><!--TODO: image--></li>
<li>Start a VR application from your PC</li>
</ol>
</div>
</div>
<div class="row gx-0 justify-content-center">
<div id="getting-started-slides" class="carousel slide">
<div class="carousel-indicators">
<button type="button" data-bs-target="#getting-started-slides" data-bs-slide-to="0" class="active" aria-current="true" aria-label="Slide 1"></button>
<button type="button" data-bs-target="#getting-started-slides" data-bs-slide-to="1" aria-label="Slide 2"></button>
<button type="button" data-bs-target="#getting-started-slides" data-bs-slide-to="2" aria-label="Slide 3"></button>
<button type="button" data-bs-target="#getting-started-slides" data-bs-slide-to="3" aria-label="Slide 4"></button>
<button type="button" data-bs-target="#getting-started-slides" data-bs-slide-to="4" aria-label="Slide 5"></button>
<button type="button" data-bs-target="#getting-started-slides" data-bs-slide-to="5" aria-label="Slide 6"></button>
</div>
<div class="carousel-inner">
<div class="carousel-item active">
<img src="screenshots/dashboard-2.png" class="d-block w-100">
<div class="carousel-caption d-none d-md-block">
<p>WiVRn main screen</p>
</div>
</div>
<div class="carousel-item">
<img src="screenshots/dashboard-1.png" class="d-block w-100">
<div class="carousel-caption d-none d-md-block">
<p>Use the connection wizard to download the client app</p>
</div>
</div>
<div class="carousel-item">
<img src="screenshots/dashboard-3.png" class="d-block w-100">
<div class="carousel-caption d-none d-md-block">
<p>WiVRn settings screen</p>
</div>
</div>
<div class="carousel-item">
<img src="screenshots/vr-applist.png" class="d-block w-100">
<div class="carousel-caption d-none d-md-block">
<p>The client app might be in "unknown sources" when it is not installed through the store</p>
</div>
</div>
<div class="carousel-item">
<img src="screenshots/vr-serverlist.png" class="d-block w-100">
<div class="carousel-caption d-none d-md-block">
<p>WiVRn headset main screen</p>
</div>
</div>
<div class="carousel-item">
<img src="screenshots/vr-connected.png" class="d-block w-100">
<div class="carousel-caption d-none d-md-block">
<p>WiVRn headset connection screen</p>
</div>
</div>
</div>
<button class="carousel-control-prev" type="button" data-bs-target="#getting-started-slides" data-bs-slide="prev">
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
<span class="visually-hidden">Previous</span>
</button>
<button class="carousel-control-next" type="button" data-bs-target="#getting-started-slides" data-bs-slide="next">
<span class="carousel-control-next-icon" aria-hidden="true"></span>
<span class="visually-hidden">Next</span>
</button>
</div>
</div>
</div>
</div>
</div>
<!-- <div class="container px-4 px-lg-5"> -->
<!-- <div class="row gx-0 mb-4 mb-lg-5 align-items-center"> -->
<!-- </div> -->
<!-- </div> -->
</section>
<!-- Privacy -->
<section class="privacy-section bg-light" id="privacy">
<div class="container px-4 px-lg-5">
<div class="row gx-4 gx-lg-5 justify-content-center">
<div class="col-lg-8">
<h2 class="text-black mb-4">Privacy</h2>
<div class="row gx-0 my-5 justify-content-center">
<div>
WiVRn does not collect any user data.
</div>
</div>
</div>
</div>
</div>
</section>
<!-- FAQ -->
<section class="faq-section bg-light" id="faq">
<div class="container px-4 px-lg-5">
<div class="row gx-4 gx-lg-5 justify-content-center">
<div class="col-lg-8">
<h2 class="text-black mb-4">FAQ</h2>
<h4>My computer is not seen by the headset</h4>
<div>
<p>If the server list is empty in the headset app:</p>
<ul>
<li>Make sure your computer is connected on the same network as your headset.</li>
<li>Check that <strong>avahi</strong> is running with <pre>systemctl status avahi-daemon</pre>. If it is not, enable it with <pre>systemctl enable --now avahi-daemon</pre>.</li>
<li>If you have a firewall, check that port <strong>5353</strong>(UDP) is open.</li>
</ul>
</div>
<br/>
<h4>My headset does not connect to my computer</h4>
<div>
<ul>
<li>If you have a firewall, check that port 9757 (UDP and TCP) is open</li>
<li>The server and client must be the same version</li>
</ul>
</div>
<h4>I don't have any sound</h4>
<div>
<ul>
<li>When the headset is connected, an audio device is created but not set as default. It can be set as default in your desktop's sound parameters.</li>
<li>For microphone, you also have to enable it on headset as it requires a permission on the device. Simply click the microphone icon at the top of the main screen.</li>
</ul>
</div>
<h4>Steam games don't launch on the headset</h4>
<div>
<ul>
<li>Make sure that an OpenVR compatibility such as OpenComposite or xrizer is installed. The flatpak version includes both.</li>
<li>Copy the launch arguments listed in the dashboard in the Steam launch parameters for the game. If no launch parameters are shown in the WiVRn dashboard, then they are not needed.</li>
<li>When using flatpak Steam, additional permissions must be given for OpenXR files, see details in <a href="https://github.com/WiVRn/WiVRn?tab=readme-ov-file#steam-flatpak">readme</a></li>
</ul>
</div>
</div>
</div>
</div>
</section>
<!-- Contact-->
<section class="contact-section bg-black" id="contact">
<div class="container px-4 px-lg-5">
<div class="row gx-4 gx-lg-5" style="justify-content: center">
<div class="col-md-3 mb-3 mb-md-0">
<div class="card py-4 h-100">
<div class="card-body text-center">
<i class="fa-brands fa-github text-primary mb-2"></i>
<h4 class="text-uppercase m-0">Source code</h4>
<hr class="my-4 mx-auto" />
<div class="small text-black-50"><a href="https://github.com/WiVRn">GitHub</a></div>
</div>
</div>
</div>
<div class="col-md-3 mb-3 mb-md-0">
<div class="card py-4 h-100">
<div class="card-body text-center">
<i class="fa-brands fa-discord text-primary mb-2"></i>
<h4 class="text-uppercase m-0">Social</h4>
<hr class="my-4 mx-auto" />
<div class="small text-black-50"><a href="https://discord.gg/EHAYe3tTYa">Discord</a></div>
</div>
</div>
</div>
<div class="col-md-3 mb-3 mb-md-0">
<div class="card py-4 h-100">
<div class="card-body text-center">
<i class="fa-solid fa-hand-holding-dollar text-primary mb-2"></i>
<h4 class="text-uppercase m-0">Donate</h4>
<hr class="my-4 mx-auto" />
<div class="small text-black-50"><a href="https://opencollective.com/wivrn">Open Collective</a></div>
</div>
</div>
</div>
</div>
<div class="social d-flex justify-content-center">
</div>
</div>
</section>
<!-- Footer-->
<footer class="footer bg-black small text-center text-white-50"><div class="container px-4 px-lg-5"><!-- TODO Copyright © Your Website 2023--></div></footer>
<!-- Bootstrap core JS-->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.3/dist/js/bootstrap.bundle.min.js"></script>
<!-- Core theme JS-->
<script src="js/scripts.js"></script>
<!-- * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *-->
<!-- * * SB Forms JS * *-->
<!-- * * Activate your form at https://startbootstrap.com/solution/contact-forms * *-->
<!-- * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *-->
<script src="https://cdn.startbootstrap.com/sb-forms-latest.js"></script>
</body>
</html>