libgoatvr
changeset 25:bb85be761b50
started the documentation
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Sun, 08 Mar 2015 05:30:02 +0200 (2015-03-08) |
parents | d659cbedde1d |
children | 23a654109494 23a654109494 |
files | README doc/1-init.rst doc/Makefile doc/index.rst |
diffstat | 4 files changed, 93 insertions(+), 2 deletions(-) [+] |
line diff
1.1 --- a/README Wed Jan 14 08:03:27 2015 +0200 1.2 +++ b/README Sun Mar 08 05:30:02 2015 +0200 1.3 @@ -6,10 +6,10 @@ 1.4 Libgoatvr is a simplified abstraction library for dealing with VR headsets. It 1.5 is designed to expose a single common API to access VR HMDs through any of the 1.6 supported backend modules, such as the Oculus SDK or OpenHMD, even allowing the 1.7 -application to switch between them seamlessly at runtime. 1.8 +application to switch between them at runtime. 1.9 1.10 Currently implemented VR modules: 1.11 - - Oculus SDK 0.4.1 1.12 + - Oculus SDK 0.4.4 1.13 - OpenHMD (not done) 1.14 - null 1.15
2.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 2.2 +++ b/doc/1-init.rst Sun Mar 08 05:30:02 2015 +0200 2.3 @@ -0,0 +1,57 @@ 2.4 +Initialization 2.5 +-------------- 2.6 + 2.7 +Before calling any other function you need to initialize the VR library by 2.8 +calling ``vr_init``. Similarly, ``vr_shutdown`` frees up all resources held by 2.9 +the library. 2.10 + 2.11 +Libgoatvr has a number of backend modules for interfacing with VR headsets, and 2.12 +there might be multiple modules compiled with your version of libgoatvr. If you 2.13 +don't want to rely on the built-in defaults, you might want to enumerate and 2.14 +select which module to use. 2.15 + 2.16 +The following example initializes the library, and prints the list of available 2.17 +VR modules: 2.18 + 2.19 +.. code:: c 2.20 + 2.21 + #include <stdio.h> 2.22 + #include <goatvr.h> 2.23 + 2.24 + int main(void) 2.25 + { 2.26 + int i, nmod; 2.27 + 2.28 + if(vr_init() == -1) { 2.29 + fprintf(stderr, "failed to initialize goatvr\n"); 2.30 + return 1; 2.31 + } 2.32 + 2.33 + nmod = vr_module_count(); 2.34 + printf("There are %d modules:\n", nmod); 2.35 + for(i=0; i<nmod; i++) { 2.36 + printf(" %2d - %s\n", i, vr_module_name(i)); 2.37 + } 2.38 + vr_shutdown(); 2.39 + return 0; 2.40 + } 2.41 + 2.42 +Running this on my computer, with the Oculus Rift DK2 connected, and oculusd 2.43 +running, produces this output:: 2.44 + 2.45 + initialized LibOVR 0.4.4 2.46 + 1 Oculus HMD(s) found 2.47 + [0]: Oculus VR - Oculus Rift DK2 2.48 + using vr module: libovr 2.49 + There are 2 modules: 2.50 + 0 - libovr 2.51 + 1 - null 2.52 + 2.53 +The first four lines come from the initialization of the ``libovr`` module which 2.54 +is selected by default if it's available. If however I turn off the DK2 or stop 2.55 +the daemon, then I'm getting just the ``null`` module in this list. 2.56 + 2.57 +If you'd like to override the default selected module, and use the ``null`` 2.58 +module instead of ``libovr``, which is useful during development to avoid having 2.59 +to put the HMD on and off all the time, you can call ``vr_use_module(1)``, or 2.60 +``vr_use_module_named("null")``.
3.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 3.2 +++ b/doc/Makefile Sun Mar 08 05:30:02 2015 +0200 3.3 @@ -0,0 +1,12 @@ 3.4 +rstfiles = $(wildcard *.rst) 3.5 +htmlfiles = $(rstfiles:.rst=.html) 3.6 + 3.7 +.PHONY: html 3.8 +html: $(htmlfiles) 3.9 + 3.10 +%.html: %.rst 3.11 + rst2html $(RSTFLAGS) $< >$@ 3.12 + 3.13 +.PHONY: clean 3.14 +clean: 3.15 + rm -f $(htmlfiles)
4.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 4.2 +++ b/doc/index.rst Sun Mar 08 05:30:02 2015 +0200 4.3 @@ -0,0 +1,22 @@ 4.4 +libgoatvr 4.5 +========= 4.6 + 4.7 +**This documentation is incomplete** 4.8 + 4.9 +Overview 4.10 +-------- 4.11 + 4.12 +Libgoatvr is a simplified abstraction library for dealing with VR headsets. It 4.13 +is designed to expose a single common API to access VR HMDs through any of the 4.14 +supported backend modules, such as the Oculus SDK or OpenHMD, even allowing the 4.15 +application to switch between them at runtime. 4.16 + 4.17 +This documentation describes how to use libgoatvr in your programs, and is 4.18 +split into the following sections: 4.19 + 4.20 + 1. Initialization_ 4.21 + 2. Head tracking 4.22 + 3. Rendering 4.23 + 4. options and properties 4.24 + 4.25 +.. _Initialization: 1-init.html