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)
  • transform.rotation — rotation de l'espace de travail (quaternion); la position et l'échelle ne s'appliquent pas à un périphérique à orientation unique et ne sont jamais transmises
Sémantique des mises à jour partielles

transform.rotation est omis lorsqu'il est égal au quaternion identité {w:1,x:0,y:0,z:0}. Fournir une valeur par défaut lors de la lecture. Activer serialization/explicit_fields pour toujours le recevoir.

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

Options de ligne de commande (Python)

La variante Python accepte les deux mêmes indicateurs que le tutoriel 01:

  • --full — affiche le contenu JSON brut sous une forme lisible, au lieu du résumé sur une seule ligne.
  • --query-config — réinjecte session.force_render_full_state à chaque impulsion sortante, de sorte que chaque trame transporte le config le bloc plutôt que simplement le delta d'état.

--query-config est particulièrement utile pour le VerseGrip sans fil car le config Ce bloc contient les éléments spécifiques à WVG sub_type champ (stylus / prototype / ruko / kingfisher, ajouté dans la version 3.5) en plus des champs de configuration habituels. Exécution de python 03-haply-inverse-print-wireless-verse-grip.py --full --query-config vous permet de regarder config.sub_type se mettre à jour en temps réel, parallèlement aux autres valeurs de configuration.

Les variantes C++ ne mettent pas ces indicateurs à disposition.

Fourni avec le programme d'installation du SDK

Le didacticiel 03 est également installé localement avec le SDK — regardez dans tutorials/03-haply-inverse-print-wireless-verse-grip/ dans le répertoire d'installation du service.

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

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