Skip to main content
Version : 3.5.x

00. Liste des appareils

Détecte tous Haply connectés via l'API REST HTTP — aucun WebSocket n'est nécessaire. Un simple test de fonctionnement permettant de vérifier que l'environnement d'exécution est opérationnel et détecte le matériel.

Ce que vous apprendrez :

  • Interrogation GET /devices pour répertorier les appareils Inverse3, VerseGrip et Wireless VerseGrip
  • Lecture des identifiants des appareils dans la réponse JSON, regroupés par type d'appareil
  • Utilisation d'un sélecteur de session pour basculer entre les coordonnées brutes du périphérique et la vue dans l'espace applicatif d'une session

Flux de travail

  1. Envoyer GET http://localhost:10001/devices.
  2. Analyser la réponse JSON — trois tableaux de niveau supérieur : inverse3, verse_grip, wireless_verse_grip.
  3. Affichez les identifiants des périphériques regroupés par type. Les tableaux vides indiquent qu'aucun périphérique de ce type n'a été détecté.
  4. Si un sélecteur de session est joint en annexe sous la forme ?session=<selector>, la réponse est filtrée pour les appareils de cette session et les coordonnées sont converties dans son espace d'application (base, montage, espace de travail appliqués). L'exemple Python expose cela sous la forme d'un --session SELECTOR Argument de ligne de commande (accepte :profile:instance, #id, :-1, :0, …) — le même indicateur avec le même texte d'aide que Tutoriel 08 (Configuration à distance HTTP) utilisations ; ainsi, un sélecteur trouvé ici peut être copié-collé directement là-bas. Les exemples en C++ effectuent la requête sans sélecteur.

Paramètres

ParamètresPar défautObjectif
URL du servicehttp://localhost:10001URL de base HTTP
Point d'extrémité/devicesPoint de terminaison de détection des périphériques
Sélecteur de session(aucun)?session=:0, ?session=:-1, ?session=:my_profile:0, ?session=co.haply.hub::*:0 (caractères génériques « * » pris en charge) — voir Sélecteurs. Dévoilé comme --session SELECTOR dans l'exemple Python (même indicateur que Tutoriel 08).

Code d'accès

L'exemple Python expose le sélecteur de session sous la forme d'un --session SELECTOR argument argparse. Sans cet argument, les périphériques sont renvoyés sous forme de coordonnées brutes dans l'espace périphérique ; avec cet argument, ils sont filtrés en fonction de la session sélectionnée et convertis dans l'espace applicatif. Le texte d'aide correspond à Tutoriel 08 (Configuration à distance HTTP) ainsi, un sélecteur trouvé ici peut être collé directement là-bas.

def parse_args():
parser = argparse.ArgumentParser(
description="List connected Haply Inverse devices via the HTTP API.")
parser.add_argument(
"--session", type=str, default="",
help=(
"Session selector. Formats:\n"
" :profile:instance by profile name (e.g. ':my_profile:0')\n"
" pattern:instance glob wildcard in profile (e.g. 'co.haply.hub::*:0')\n"
" '*' matches any sequence, '?' one character\n"
" #session_id by numeric id (e.g. '#42' — quote in shells to escape '#')\n"
" :-1 the last active session\n"
" :0 the first session"
))
return parser.parse_args()

def main():
args = parse_args()
session = args.session or None

url = f"{BASE_URL}/devices"
if session:
url += f"?session={session}"
print(f"Querying devices for session '{session}' (application space)\n")
else:
print("Querying all detected devices (device space)\n")

r = requests.get(url, timeout=3)
r.raise_for_status()
data = r.json()

print_devices("Inverse3", data.get("inverse3"))
print_devices("Wired Verse Grip", data.get("verse_grip"))
print_devices("Wireless Verse Grip", data.get("wireless_verse_grip"))
Fourni avec le programme d'installation du SDK

Le didacticiel 00 est également installé localement avec le SDK — consultez le répertoire tutorials/00-haply-inverse-device-list/ dans le répertoire d'installation du service.

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

À lire également : Conventions JSON · Sélecteurs · Sessions