Skip to main content
Version : 3.5.x

02. Imprimer VerseGrip

Transmet l'orientation (quaternion + angles d'Euler Z-X-Y), le niveau du capteur à effet Hall et l'état des boutons du premier VerseGrip connecté par câble.

Ce que vous apprendrez :

  • Lecture quaternion orientation par rapport au repère de l'État
  • Conversion d'un quaternion en angles d'Euler Z-X-Y en degrés (+X à droite, +Y vers l'avant, +Z vers le haut)
  • Utilisation de probe_orientation en tant que mécanisme de maintien de connexion autonome
  • Le modèle de négociation de connexion par premier message uniquement (identique à celui du tutoriel 01)

Flux de travail

  1. Ouvrir un WebSocket vers ws://localhost:10001 et attendre la première trame d'état.
  2. Choisissez les premiers VerseGrip filaires device_id à partir de verse_grip tableau.
  3. Construisez une requête avec le profil de session et par appareil probe_orientation keepalive (une commande d'objet vide qui maintient la circulation de l'orientation de la prise dans les trames d'état).
  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 télémétriques avec un débit limité. 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-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.verse_grip[0].state:

  • orientationquaternion (w, x, y, z)
  • hall — valeur entière de la lecture du capteur Hall
  • button — booléen

Envoyer / recevoir

La boucle WebSocket : réception d'une trame d'état, création et renvoi de 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 — recv() → commande de compilation → send() → répéter.

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["verse_grip"][0]["device_id"]
request_msg = {
"session": {"configure": {"profile": {
"name": "co.haply.inverse.tutorials:print-verse-grip"}}},
"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 : Types (quaternion) · Commandes de contrôle (probe_orientation) · Protocole WebSocket · Tutoriel 03 (VG sans fil)