Python interface for a Daydream controller.
Provides a Python interface to a Daydream controller, by subscribing to GATT notifications for a characteristic (UUID: 00000001-1000-1000-8000-00805f9b34fb
).
The DaydreamController
class can be found in snakedream.device
.
Byte definitions to interpret returned data are found in snakedream.constants
(see this Stack Overflow answer for more information).
Data models to represent returned data and handle byte definition calculations are found in snakedream.models
.
Please note, ctypes.c_int32
is used when performing bitwise shifts to intentionally allow overflows.
snakedream.mouse
and snakedream.graph
contain callbacks for mouse and graph support, respectively.
Mouse control is currently supported via two backends: uinput
, creating a virtual mouse device, and PyAutoGUI
, which controls the cursor directly.
uinput
is supported on Linux, both Xorg and Wayland.
PyAutoGUI
supports all known platforms, except Wayland on Linux.
To manually specify which backend is used, set snakedream.config.MOUSE_BACKEND
to the desired value.
snakedream.base
provides an abstract base class, BaseCallback
, to provide a parent for subclasses which utilise data from the Daydream controller.
To create a new callback class, create a subclass of BaseCallback
, which implements the callback
async method, which accepts the following arguments: sender: BleakGATTCharacteristic, data: bytearray
.
To register the callback for the controller, call the start
method of the instance.
When new data is available from the controller, the callback will be called.
The subclass will also have a controller
attribute - passed at instantiation - which can be accessed directly within the callback.
For example:
class ExampleCallback(BaseCallback):
async def callback(self, sender: BleakGATTCharacteristic, data: bytearray) -> None:
if self.controller.buttons.click:
print("Button clicked!")
callback = ExampleCallback(controller)
await callback.start()
- Install project:
pip install snakedream
- Run:
snakedream
Alternatively, after cloning the repository with:
git clone https://github.com/Zedeldi/snakedream.git
- Install project:
pip install .
- Run:
snakedream
- Install dependencies:
pip install -r requirements.txt
- Run:
python -m snakedream
By default, with no arguments, snakedream
will control the mouse with the gyroscope, using the appropriate backend for the host platform.
Additionally, snakedream
can output the controller state as JSON or to a graph with matplotlib
.
For more information, see snakedream --help
.
- Bleak - BLE Client
- Matplotlib - Graph support
- python-uinput - Mouse support (device backend)
- PyAutoGUI - Mouse support (GUI backend)
- daydream-controller.js - WebBluetooth Daydream Controller
- Forrest Porter - Stack Overflow answer for byte definitions
snakedream
is licensed under the MIT Licence for everyone to use, modify and share freely.
This project is distributed in the hope that it will be useful, but without any warranty.
If you found this project useful, please consider donating. Any amount is greatly appreciated! Thank you 😃