This repository provides the tool to read the position and pressed button from the Oculus Quest device.
Oculus reader consits of two elements: python script which receives the readings from the APK and the APK itself. Currently the pose of the controllers and pressed buttons are transfered from the APK. This behavior can be extended using provided APK source code.
To pull the APK correctly, Git LFS has to be configured before cloning the repository. The installation is described here https://git-lfs.github.com. On Ubuntu follow these steps:
curl -s https://packagecloud.io/install/repositories/github/git-lfs/script.deb.sh | sudo bash
sudo apt-get install git-lfs
git lfs install # has to be run only once on a single user accountNow you can clone this repository either with HTTPS or SSH.
If you decide to use the HTTPS protocol, you can reduce the number of authentification prompts when pushing/pulling caused by Git LFS with:
git config lfs.https://github.com/rail-berkeley/oculus_reader.git/info/lfs.locksverify falseThis command has to be run from the repository workspace.
ADB is required for the communication between Oculus Quest and the python reader script.
To install ADB on Ubuntu run:
sudo apt install android-tools-adb
On other systems follow the steps from the 'app_source' folder.
- Determine your Oculus Quest account name:
If you haven’t used Oculus Quest before, start it and follow the steps to create your profile and get yourself started. Otherwise follow these steps to find out your username:
- Go to: https://www.oculus.com/
- Log in to account:
 
- After logging in select your profile again in top right corner and select ‘Profile’
 
- You will be able to see your username on the following screen:
 
 
- Enable Oculus Quest development mode:
- If you belong to RAIL, inform me (Jedrzej Orbik) that you need to join the development organization. This is required to activate debugging mode on the device. Otherwise create your own organization https://developer.oculus.com/manage/organizations/create/ and fill in the appropriate informaiton.
- Turn on the device you want to use for development.
- Open the Oculus app on your phone and then go to Settings.
- Tap the device and then go to More Settings > Developer Mode.
- Turn on the Developer Mode toggle.
- Connect your device to your computer using a USB-C cable and then wear the device.
- Accept Allow USB Debugging and Always allow from this computer when prompted to on the device.
  
- (Windows only) Install the Oculus ADB Drivers
- Download the zip file containing the driver.
- Unzip the file.
- Right-click on the .inf file and select Install.
 
 
If you intend to use the precompiled APK with the predefined behavior, where the position and the pressed buttons are transferred, please follow the steps from the scripts folder. If you plan to extend the app, please read the README from the app_source folder.
- Connect Oculus Quest to PC with USB cable. This is required to establish the connection.
- Run the exemplary file: python oculus_reader/reader.py
- (optionally) If ROS is installed on your machine, the current transformation can be visualized using the script visualize_oculus_transforms.py.
- Make sure that Oculus Quest is connected to the same network as the computer.
- Connect Oculus Quest to PC with USB cable. This is required to establish the connection.
- Put on the headset and allow the permission as requested.
- Verify that a device is visible with: adb devices. The expected output:
 List of devices attached
 ce0551e7 device
- Check the IP address of the headset:
 adb shell ip route
 Expected output:
 10.0.30.0/19 dev wlan0 proto kernel scope link **src **10.0.32.101
- Read the IP address of the device standing after **src.
- Provide the IP address when creating OculusReader object.
- Run the exemplary file: python oculus_reader/reader.py
- (optionally) If ROS is installed on your machine, the current transformation can be visualized using the script visualize_oculus_transforms.py.
It is possible to stop the app from adb. Use: adb shell am force-stop com.rail.oculus.teleop
If you find this work helpful, please consider citing it using the following reference:
@misc{OrbikEbert2021OculusReader,
  author = {Jedrzej Orbik, Frederik Ebert},
  title = {Oculus Reader: Robotic Teleoperation Interface},
  year = {2021},
  url = {https://github.com/rail-berkeley/oculus_reader},
  note = {Accessed: YYYY-MM-DD}
}