Skip to main content
Version : 3.5.x

03. Imprimer le VerseGrip sans fil

Même schéma que dans le tutoriel 02, mais pour un VerseGrip sans fil — ajoute les boutons (A/B/C) et le niveau de batterie à l'affichage en temps réel.

Ce que vous apprendrez :

  • Lecture des champs d'état spécifiques à la communication sans fil : buttons.{a,b,c}, battery_level, hall
  • Utilisation de probe_orientation en tant que mécanisme de maintien de connexion autonome
  • Même modèle de négociation de connexion par « premier message uniquement » que dans le tutoriel 02

Flux de travail

  1. Ouvrir un WebSocket vers ws://localhost:10001 et attendre la première trame d'état.
  2. Choisissez les premiers VerseGrip sans fil device_id à partir de wireless_verse_grip tableau.
  3. Construisez une requête avec le profil de session et par appareil probe_orientation keepalive.
  4. Envoyez la requête, puis supprimez le session champ — il s'agit d'une poignée de main unique.
  5. À chaque image suivante, convertissez le quaternion en angles d'Euler et affichez les données de télémétrie (avec un débit limité), y compris l'état des boutons et le niveau de la batterie. Renvoyez le message de maintien de connexion à chaque tick.

Paramètres

NomPar défautObjectif
URIws://localhost:10001URL WebSocket du canal de simulation
PRINT_EVERY_MS100Régulateur de débit via la console
Nom du profil de sessionco.haply.inverse.tutorials:print-wireless-verse-gripIdentifie cette simulation dans Haply
convention d'Euler

La conversion est intrinsèque Z-X-Y (lacet → tangage → roulis) dans le repère de l'application +X right, +Y forward, +Z up. Ne pas utiliser glm::eulerAngles — elle suit une convention différente et ne s'affichera pas correctement ici. Ces trois variantes de langage utilisent le même calcul ; consultez les sources pour voir la formule.

Quand probe_orientation est en fait nécessaire

probe_orientation n'est utile que lorsque votre session pas envoyer n'importe quelle commande à un Inverse3. Dès que vous envoyez une commande à un Inverse3 force, position, couple...), le service transmet automatiquement l'orientation du VerseGrip appairé à chaque trame d'état — aucune sonde n'est nécessaire. Utilisez probe_orientation uniquement pour les outils autonomes de surveillance de la prise en main, comme dans ce tutoriel.

Champs d'état lus

De data.wireless_verse_grip[0].state:

  • orientationquaternion (w, x, y, z)
  • hall — valeur entière de la lecture du capteur Hall
  • buttons.a, buttons.b, buttons.c — booléens
  • battery_level — nombre à virgule flottante (0,0 – 1,0)

Envoyer / recevoir

De la même forme que Tutoriel 02, simplement avec le wireless_verse_grip tableau de périphériques. La boucle WebSocket reçoit une trame d'état et renvoie la poignée de main + probe_orientation keepalive ; le premier message sortant contient le profil de session, chaque trame suivante ne contient que le keepalive.

Boucle asynchrone unique.

async with websockets.connect(URI) as websocket:
while True:
msg = await websocket.recv()
data = json.loads(msg)

if first_message:
first_message = False
device_id = data["wireless_verse_grip"][0]["device_id"]
request_msg = {
"session": {"configure": {"profile": {
"name": "co.haply.inverse.tutorials:print-wireless-verse-grip"}}},
"wireless_verse_grip": [{
"device_id": device_id,
"commands": {"probe_orientation": {}} # empty — keepalive
}]
}

await websocket.send(json.dumps(request_msg))
request_msg.pop("session", None) # one-shot handshake

Source : Python · C++ · C++ Glaze

À lire également : Tutoriel 02 (Wired VG) · Types (quaternion) · Commandes de contrôle (probe_orientation) · Protocole WebSocket