Library to interface with Gran Turismo's motion rig telemetry service.
Project description
Gran Turismo Telemetry
Python library for interfacing with Polyphony Digital's telemetry service for motion rigs in GT6/GTS/GT7 (maybe older?)
Features
- Playstation IP Address discovery
- Asynchronous callbacks
- Game event observer
- Telemetry as an object or a dictionary
Installation
Install with pip:
pip install gt-telem
Usage
Getting telemetry is fairly straightforward. Here's a simple example:
import json
from gt_telem import TurismoClient
from gt_telem.models import Telemetry
async def print_telem(t: Telemetry):
print(json.dumps(t.as_dict, indent=4))
tc = TurismoClient()
tc.register_callback(print_telem)
tc.run()
print_telem()
is invoked with each frame rendered (60hz). This tends to produces a lot of noise, especially when in menus, or even if the race is paused.
Hooking into game events
Here's a more complex example of a telemetry recorder that hooks into race start, pause, and race end:
from gt_telem import TurismoClient
from gt_telem.events import GameEvents
from gt_telem.errors.playstation_errors import *
class MySimpleTelemetryRecorder():
def __init__(self, tc: TurismoClient):
self.tc = tc
self.storage = []
def start(self):
tc.register_callback(MySimpleTelemetryRecorder.receive_telem, [self])
def stop(self):
self.deregister_callback(MySimpleTelemetryRecorder.receive_telem)
# save self.storage somewhere
@staticmethod
async def receive_telem(t, context):
context.storage.append(t)
print(f"{t.engine_rpm}RPM - {t.boost_pressure}kPa")
print(f"Best: {t.best_lap_time}\tLast: {t.last_lap_time}")
if __name__ == "__main__":
try:
tc = TurismoClient()
except PlayStatonOnStandbyError as e:
print("Turn the playstation on")
print(e)
except PlayStationNotFoundError:
print("Maybe I'm on the wrong network")
print(e)
else:
ge = GameEvents(tc)
mstr = MySimpleTelemetryRecorder(tc)
ge.on_in_race.append(mstr.start)
ge.on_race_end.append(mstr.stop)
ge.on_paused.append(mstr.stop)
print("Listening for telemetry. CTRL+C to stop")
tc.run()
TurismoClient.run()
is a blocking call, but does shut down gracefully when a keyboard interrupt is issued. It also accepts a cancellation token.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file gt-telem-0.2.2.tar.gz
.
File metadata
- Download URL: gt-telem-0.2.2.tar.gz
- Upload date:
- Size: 52.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 46ac11876ffdc438c3cfd10b6b3b3ef4d12fa56f1ba1363222788eaf2ea763b6 |
|
MD5 | 0fdc18a9ea7a3154f9a8050c760b122d |
|
BLAKE2b-256 | 92134973db08a0696cd94d12927706916b23387b87bd030ffbbde244698984a1 |
File details
Details for the file gt_telem-0.2.2-py3-none-any.whl
.
File metadata
- Download URL: gt_telem-0.2.2-py3-none-any.whl
- Upload date:
- Size: 42.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 636cfedf60e4f67521b48f5d1b42790e2b5b57f6c1a857cfcf6bcf1186fc4a38 |
|
MD5 | 68648686e85597753928450cf9461f2c |
|
BLAKE2b-256 | cb43abac5f1ed8908ae8bcf276e0ebba4d4a9c7125244bc7b59b2f466c713b8b |