주요 콘텐츠로 건너뛰기
버전: 3.5.x

02. VerseGrip 인쇄

첫 번째 유선 VerseGrip의 방향(쿼터니언 + Z-X-Y 오일러 각도), 홀 센서 레벨 및 버튼 상태를 스트리밍합니다.

배울 내용:

  • 읽기 quaternion 상태 프레임에 대한 방향
  • 쿼터니언을 도(°) 단위의 Z-X-Y 오일러 각도로 변환하기 (+X는 오른쪽, +Y는 앞쪽, +Z는 위쪽)
  • 사용 probe_orientation 독립형 관찰자 키팔라이브로서
  • 첫 번째 메시지만 사용하는 핸드셰이크 패턴 ( 튜토리얼 01과 동일)

작업 흐름

  1. 다음으로 WebSocket 연결을 열기 ws://localhost:10001 그리고 첫 번째 상태 프레임이 나타날 때까지 기다립니다.
  2. 최초의 유선 VerseGrip을 선택하세요 device_id ~에서 verse_grip 배열.
  3. 다음과 같이 요청을 생성합니다. 세션 프로필 그리고 기기당 probe_orientation keepalive (상태 프레임에서 그립 방향을 지속적으로 유지하도록 하는 빈 객체 명령어).
  4. 요청을 전송한 다음, session 필드 — 일회성 핸드셰이크입니다.
  5. 이후 모든 프레임에서 쿼터니언을 오일러 각도로 변환하고, 전송 속도를 조절하여 텔레메트리 데이터를 출력합니다. 매 틱마다 키팔라이브를 재전송합니다.

매개변수

이름기본값목적
URIws://localhost:10001시뮬레이션 채널 WebSocket URL
PRINT_EVERY_MS100콘솔 출력 스로틀
세션 프로필 이름co.haply.inverse.tutorials:print-verse-gripHaply Hub에서 이 시뮬레이션을 식별합니다
오일러 표기법

응용 좌표계에서 변환은 내재적 Z-X-Y(요 → 피치 → 롤) 변환입니다. +X right, +Y forward, +Z up. 하지 마세요 사용 glm::eulerAngles — 이 코드는 다른 규칙을 따르기 때문에 여기서는 올바르게 표시되지 않습니다. 세 가지 언어 변형 모두 동일한 수학적 연산을 구현하고 있습니다. 공식은 소스 코드를 참조하십시오.

~할 때 probe_orientation 실제로 필요한지

probe_orientation 세션이 활성화된 경우에만 유용합니다 ~하지 않는다 Inverse3 명령을 전송하세요. Inverse3 명령 Inverse3 힘, 위치, 토크 등)을 내리는 즉시, 이 서비스는 페어링된 VerseGrip의 방향을 모든 상태 프레임마다 자동으로 스트리밍합니다. 별도의 프로브가 필요하지 않습니다. 사용법 probe_orientation 이 튜토리얼과 같은 독립형 그립 모니터링 도구에만 해당됩니다.

상태 필드 읽기

발신자 data.verse_grip[0].state:

  • orientationquaternion (w, x, y, z)
  • hall — 홀 센서 측정값(정수)
  • button — 부울
  • transform.rotation — 작업 공간 회전 (quaternion); 방향만 지원하는 기기에는 위치와 배율이 적용되지 않으며, 이러한 속성은 절대 반환되지 않습니다
부분 업데이트 의미론

transform.rotation 정체 사원수인 경우 생략된다 {w:1,x:0,y:0,z:0}. 읽을 때 기본값을 지정합니다. 활성화 serialization/explicit_fields 항상 받아보시려면.

보내기 / 받기

웹소켓 루프: 상태 프레임 수신, 핸드셰이크 구성 및 전송 + probe_orientation keepalive. 첫 번째 송신 메시지에는 세션 프로필이 포함되며, 그 이후의 모든 프레임에는 keepalive만 포함됩니다.

단일 비동기 루프 — recv() → 빌드 명령어 → send() → 반복.

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

명령줄 옵션 (Python)

이 Python 변형은 튜토리얼 01과 동일한 두 가지 플래그를 지원합니다:

  • --full — 한 줄 요약 대신 원본 JSON 페이로드를 보기 좋게 형식화하여 출력합니다.
  • --query-config — 재주입 session.force_render_full_state 모든 아웃바운드 틱마다, 따라서 모든 프레임에 config 상태 변화량뿐만 아니라 블록(장치 유형, 펌웨어, 마운트 변환 등)을 함께 표시합니다. 설정 변경 사항을 실시간으로 디버깅할 때 유용합니다.

두 플래그가 결합됩니다. C++ 변형에서는 이러한 플래그를 노출하지 않습니다.

SDK 설치 프로그램과 함께 제공

튜토리얼 02도 SDK와 함께 로컬에 설치되어 있습니다. 다음 경로를 확인해 보세요. tutorials/02-haply-inverse-print-verse-grip/ 서비스 설치 디렉터리 아래에.

출처: Python · C++ · C++ Glaze

관련 기사: 유형 (쿼터니언) · 제어 명령어 (probe_orientation) · 웹소켓 프로토콜 · 튜토리얼 03 (무선 VG)