Zum Hauptinhalt springen
Version: 3.5.x

Haply Inverse SDK

Das Haply Inverse SDK ist eine sprachunabhängige WebSocket- und HTTP-Schnittstelle zu den Haply Geräten Haply – dem Inverse3, Inverse3x, Minverse, VerseGrip und Wireless VerseGrip. Es läuft als lokaler Dienst, der die Geräteerkennung, serielle Kommunikation, Sicherheitsüberwachung und Statusübertragung übernimmt – so muss Ihre Anwendung lediglich JSON über einen Socket kommunizieren.

Zu seinen Funktionen gehören:

  • Geräteerkennung und -verwaltung – listet angeschlossene Haply automatisch über eine HTTP-REST-API auf und konfiguriert sie.
  • Echtzeit-Statusübertragung – übermittelt den Gerätestatus mit haptischen Steuerungsraten (mehrere kHz) über WebSockets.
  • Befehlsverarbeitung – führt Kraft- und Positionsbefehle mit hoher Genauigkeit aus, um ein präzises haptisches Feedback zu gewährleisten.
  • Hintergrundbetrieb – läuft als lokaler Dienst und hält die Geräte ohne Benutzereingriff betriebsbereit.

Mit dem Haply installieren

Der einfachste Weg, um loszulegen, ist der Haply – eine Desktop-Anwendung zum Installieren, Ausführen, Konfigurieren, Testen und Überwachen Ihrer Haply . Sie hält die Firmware auf dem neuesten Stand, bündelt den Inverse Service und enthält Demos, damit Sie Ihre Hardware überprüfen können, bevor Sie auch nur eine Zeile Code schreiben.

Haply Hub

Haply Hub

Laden Sie die neueste Version des Haply Hub herunter

Laden Sie den Hub herunter und installieren Sie ihn, schließen Sie Ihr Gerät an, und der Hub führt Sie durch alle Firmware-Updates. Nach der Installation läuft der Inverse Service automatisch im Hintergrund, sobald der Hub geöffnet ist.

Bevorzugen Sie eine eigenständige Installation?

Sie können eine bestimmte Version des Inverse Service auch ohne den Hub als Systemdienst (Windows) oder Daemon (Linux/macOS) installieren. Den Link zum Installationsprogramm sowie eine Anleitung finden Sie unter „Ausführen des Dienstes “.

Kurzes Beispiel

Stelle eine Verbindung zum Dienst her, lies die Cursorposition des ersten Inverse3 aus und sende ein Keepalive ohne Kraft, damit der Dienst weiterhin Status-Frames überträgt:

import asyncio, json, websockets

async def main():
async with websockets.connect("ws://localhost:10001") as ws:
# Handshake: register profile and send a zero-force keepalive
first_state = json.loads(await ws.recv())
device_id = first_state["inverse3"][0]["device_id"]
keepalive = {"inverse3": [{
"device_id": device_id,
"commands": {"set_cursor_force": {"vector": {"x": 0, "y": 0, "z": 0}}}
}]}
while True:
state = json.loads(await ws.recv())
pos = state["inverse3"][0]["state"]["cursor_position"]
print(f"pos: {pos}")
await ws.send(json.dumps(keepalive))

asyncio.run(main())
Warnung

Ändern Sie die Kraftwerte mit Bedacht. Plötzliche hohe Kraftwerte können das Gerät beschädigen oder zu unerwartetem Verhalten führen.

Infos

Informationen zu den Regeln für den Nachrichten-Envelope, die Ports und den Content-Type finden Sie auf der Seite „JSON-Konventionen “.

Weitere Beispiele

Umfassende Tutorials zu Python, C++ (nlohmann) und C++ (Glaze) – mit Themen wie Force Feedback, Positionssteuerung, Konfigurationen mit mehreren Geräten, Halterungs- und Basiskonfiguration sowie Event-Streaming – finden Sie auf der Seite „Tutorials “.