Skip to main content

Python package for easy interaction with head tracker hardware.

Project description

PyHeadTracker

This package provides an interface for interacting with head tracking hardware in Python.

The use of head trackers can greatly enhance the user experience in applications such as immersive audio, virtual reality, gaming, and assistive technologies. By providing precise head position and orientation data, developers can create more immersive and responsive environments for their users. However, interacting with different head trackers and their APIs can be a tedious process. PyHeadTracker aims to simplify this process by providing a unified interface for various head tracking devices in python.

A detailed documentation is available here.

Overview

PyHeadTracker is designed to provide a simple and consistent interface for accessing head tracking data from various devices. The library abstracts the complexities of dealing with different hardware and APIs, allowing developers to focus on building their applications without worrying about the underlying details.

Typically, each head tracker is instantiated as object before opening the connection, e.g.

import pyheadtracker as pht

ht = pht.diy.MrHeadTracker(
    device_name="MrHeadTracker 1",
    orient_format="q",
)
ht.open()

Now you can access the head tracking data using the read_orientation() or read_position() method:

while True:
    orientation = ht.read_orientation()

    if orientation is not None:
        w, x, y, z = orientation

        # Print the quaternion values for debugging
        print(f"WXYZ: {w:7.2f} {x:7.2f} {y:7.2f} {z:7.2f}", end="\r")

Orientation data is provided as Quaternion or YPR (yaw/pitch/roll) object, which can easily be converted to a list or NumPy array. when requesting the poition, a Position object is returned to access Cartesian coordinates.

Examples how to use this package can be found here.

Supported devices

Currently the following head tracking devices are supported:

If you are missing a device, feel free to contact us or open an issue.

Roadmap

In future releases, we plan to support additional head tracking devices and improve the overall functionality of the library. Some of the planned features include:

  • Support for
    • SteamVR HMDs (e.g. HTC Vive)
    • OptiTrack
  • Standalone CLI tool

License

This project is licensed under the MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyheadtracker-0.1.3.tar.gz (3.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyheadtracker-0.1.3-py3-none-any.whl (3.4 MB view details)

Uploaded Python 3

File details

Details for the file pyheadtracker-0.1.3.tar.gz.

File metadata

  • Download URL: pyheadtracker-0.1.3.tar.gz
  • Upload date:
  • Size: 3.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pyheadtracker-0.1.3.tar.gz
Algorithm Hash digest
SHA256 1732d441f09082bd16370b5aecf976bc17d6f1e29869c5b1b426f4b77bd45f46
MD5 a9ac716a23742ce2408d06521b0bd9ae
BLAKE2b-256 a3d2f662d01a4eae30a14c7e4276ba1087cefca64ac7670d877f500aa35a921a

See more details on using hashes here.

File details

Details for the file pyheadtracker-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: pyheadtracker-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 3.4 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.11 {"installer":{"name":"uv","version":"0.9.11"},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for pyheadtracker-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 8086cdb3b0844ab877b8558a75112036ea6c78a33e3332d01eb18c2eaf9b6f05
MD5 f63af6e3843e2b111303152834fe507c
BLAKE2b-256 372cd76e63fbdd863cbd8f21af1b205c7fb241722644ca061d38f749860b0f2c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page