Tilt Five NDK
types.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2020-2023 Tilt Five, Inc.
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#pragma once
18
21
22#ifndef __cplusplus
23#include <stdbool.h>
24#include <stdint.h>
25#else
26#include <cstdint>
27#endif
28
32
36
38#define T5_MAX_STRING_PARAM_LEN (260)
39
41#define T5_MIN_CAM_IMAGE_BUFFER_WIDTH (768)
42
44#define T5_MIN_CAM_IMAGE_BUFFER_HEIGHT (600)
45
47typedef struct {
48 float x;
49 float y;
50} T5_Vec2;
51
53typedef struct {
54 uint32_t x;
55 uint32_t y;
56} T5_Offset;
57
59typedef struct {
60 uint32_t width;
61 uint32_t height;
62} T5_Extent;
63
65typedef struct {
66 T5_Offset offset;
67 T5_Extent extent;
68} T5_Rect;
69
71typedef struct {
72 float x;
73 float y;
75
77typedef struct {
78 float width;
79 float height;
81
83typedef struct {
84 T5_Offsetf offset;
85 T5_Extentf extent;
86} T5_Rectf;
87
89typedef struct {
90 float x;
91 float y;
92 float z;
93} T5_Vec3;
94
96typedef struct {
97 float w;
98 float x;
99 float y;
100 float z;
101} T5_Quat;
102
104typedef enum {
105 kT5_MatrixOrder_RowMajor = 1,
106 kT5_MatrixOrder_ColumnMajor = 2,
108
110typedef enum {
111 kT5_DepthRange_MinusOneToOne = 1,
112 kT5_DepthRange_ZeroToOne = 2,
114
119typedef enum {
120 kT5_CartesianCoordinateHandedness_Left = 1,
121 kT5_CartesianCoordinateHandedness_Right = 2,
123
128typedef struct T5_ContextImpl* T5_Context;
129
134typedef struct T5_GlassesImpl* T5_Glasses;
135
140typedef uint8_t T5_WandHandle;
141
143typedef enum {
146
149
152
155
158
163
168
171
176
180
181typedef enum {
185
193
194typedef struct {
197
200
204
205typedef enum {
209
214
215typedef struct {
217 void* instance;
218
221
223 void* device;
224
229 void* queue;
230
233
237
238typedef struct {
240 void* device;
241
243 void* queue;
245
247typedef enum {
250
253
256
260
262typedef struct {
266
270
274
278
283
285typedef struct {
287 const char* applicationId;
288
291
295 uint8_t sdkType;
296
298 uint64_t reserved;
300
302typedef enum {
305
308
311
315
317typedef enum {
326
334
348typedef struct {
351
355
359
363
365typedef struct {
367 uint8_t cameraIndex;
368
372
374typedef struct {
381
388
390 uint16_t texWidth_PIX;
391
394
396 bool isSrgb;
397
400
402 struct {
403 float startX_VCI;
404 float startY_VCI;
405 float width_VCI;
406 float height_VCI;
407 } vci;
408
411
415
418
423
424typedef struct {
425 struct {
431 void* texture;
432
438
440 uint16_t arraySize;
441 } texture;
442
443 struct {
448
452 uint16_t arrayIndex;
453 } subImage;
454
459 int64_t format;
460
464
466typedef struct {
469 uint16_t imageWidth;
470
473 uint16_t imageHeight;
474
477 uint16_t imageStride;
478
481 uint8_t cameraIndex;
482
486
489 uint32_t bufferSize;
490
492 uint8_t* pixelData;
493
496
500
502typedef struct {
505
507
509typedef enum {
512
515
518
522
524typedef enum {
527
530
533} T5_Hand;
534
536typedef struct {
539
542
545
548
551
553 float trigger;
554
557
558 // TODO(khunt) : Determine units
560 uint8_t battery;
561
563 struct {
564 bool t5;
565 bool one;
566 bool two;
567 bool three;
568 bool a;
569 bool b;
570 bool x;
571 bool y;
572 } buttons;
573
579
582
585
588
592
594typedef struct {
597
600
603
607
609typedef enum {
613
617
619typedef enum {
622
627
629typedef struct {
631 double matrix[16];
632
635
638
641
645
T5_GraphicsApi_GL_TextureMode
Definition: types.h:181
T5_ConnectionState
Glasses connection state.
Definition: types.h:302
T5_MatrixOrder
Matrix order.
Definition: types.h:104
T5_ParamGlasses
Possible parameters that can be retrieved for glasses.
Definition: types.h:609
uint8_t T5_WandHandle
Opaque handle used with wands.
Definition: types.h:140
T5_DepthRange
Z Depth range.
Definition: types.h:110
struct T5_ContextImpl * T5_Context
Opaque handle used with system-wide functions.
Definition: types.h:128
T5_GraphicsApi
Graphics API types.
Definition: types.h:143
T5_Hand
Wand hand.
Definition: types.h:524
T5_GraphicsApi_Vulkan_TextureMode
Definition: types.h:205
T5_ParamSys
Possible parameters that can be retrieved with System-wide parameters.
Definition: types.h:619
T5_GameboardType
Possible gameboard types.
Definition: types.h:247
T5_WandStreamEventType
Wand stream event type.
Definition: types.h:509
struct T5_GlassesImpl * T5_Glasses
Opaque handle used with glasses.
Definition: types.h:134
T5_GlassesPoseUsage
Glasses pose usage indicator.
Definition: types.h:317
T5_CartesianCoordinateHandedness
Handedness of a cartesian coordinate system.
Definition: types.h:119
@ kT5_GraphicsApi_GL_TextureMode_Pair
Treat T5_FrameInfo.leftTexHandle and T5_FrameInfo.rightTexHandle as a pair of GL_TEXTURE_2D.
Definition: types.h:184
@ kT5_GraphicsApi_GL_TextureMode_Array
Treat T5_FrameInfo.leftTexHandle as a GL_TEXTURE_2D_ARRAY. T5_FrameInfo.rightTexHandle is unused.
Definition: types.h:191
@ kT5_ConnectionState_Disconnected
Glasses were previously exclusively connected, but the device has disconnected.
Definition: types.h:313
@ kT5_ConnectionState_ExclusiveConnection
Glasses are connected for exclusive use.
Definition: types.h:304
@ kT5_ConnectionState_NotExclusivelyConnected
Glasses have not been exclusively connected or reserved.
Definition: types.h:310
@ kT5_ConnectionState_ExclusiveReservation
Glasses are reserved for exclusive use.
Definition: types.h:307
@ kT5_ParamGlasses_Float_IPD
Interpupillary distance - Float, millimeters
Definition: types.h:612
@ kT5_ParamGlasses_UTF8_FriendlyName
User-facing name of the glasses - UTF8.
Definition: types.h:615
@ kT5_GraphicsApi_Vulkan
Vulkan.
Definition: types.h:154
@ kT5_GraphicsApi_None
No graphics API (for clients that don't send frames)
Definition: types.h:145
@ kT5_GraphicsApi_GL_TI
Definition: types.h:167
@ kT5_GraphicsApi_Vulkan_TI
Definition: types.h:175
@ kT5_GraphicsApi_D3D12
Direct3D 12 (Windows Only)
Definition: types.h:157
@ kT5_GraphicsApi_D3D11
Direct3D 11 (Windows Only)
Definition: types.h:151
@ kT5_GraphicsApi_D3D12_TI
Direct3D 12 (With T5_TextureInfo textures) (Windows Only)
Definition: types.h:178
@ kT5_GraphicsApi_GL
OpenGL.
Definition: types.h:148
@ kT5_GraphicsApi_D3D11_TI
Direct3D 11 (With T5_TextureInfo textures) (Windows Only)
Definition: types.h:170
@ kT5_Hand_Right
Right hand.
Definition: types.h:532
@ kT5_Hand_Unknown
Hand unknown.
Definition: types.h:526
@ kT5_Hand_Left
Left hand.
Definition: types.h:529
@ kT5_GraphicsApi_Vulkan_TextureMode_Image
Treat T5_FrameInfo.leftTexHandle and T5_FrameInfo.rightTexHandle as a pair of pointers to VkImage han...
Definition: types.h:208
@ kT5_GraphicsApi_Vulkan_TextureMode_ImageView
Treat T5_FrameInfo.leftTexHandle and T5_FrameInfo.rightTexHandle as a pair of pointers to VkImageView...
Definition: types.h:212
@ kT5_ParamSys_Integer_CPL_AttRequired
Non-zero if the control panel requires user interaction (E.g. Important firmware update) - Integer,...
Definition: types.h:625
@ kT5_ParamSys_UTF8_Service_Version
Version of the service software - UTF8.
Definition: types.h:621
@ kT5_GameboardType_LE
An LE gameboard.
Definition: types.h:252
@ kT5_GameboardType_XE
An XE gameboard, flap laid flat.
Definition: types.h:255
@ kT5_GameboardType_None
No gameboard.
Definition: types.h:249
@ kT5_GameboardType_XE_Raised
An XE gameboard, flap raised at an angle on the kickstand.
Definition: types.h:258
@ kT5_WandStreamEventType_Connect
Wand connected.
Definition: types.h:511
@ kT5_WandStreamEventType_Disconnect
Wand disconnected.
Definition: types.h:514
@ kT5_WandStreamEventType_Report
Wand report (Pose, Buttons, Trigger, Stick, Battery)
Definition: types.h:520
@ kT5_WandStreamEventType_Desync
Stream has desynchronized.
Definition: types.h:517
@ kT5_GlassesPoseUsage_GlassesPresentation
The pose will be used to render images to be presented on the glasses.
Definition: types.h:325
@ kT5_GlassesPoseUsage_SpectatorPresentation
The pose will be used to render images to be presented on a device other than the glasses,...
Definition: types.h:332
2D vector
Definition: types.h:47
An integer cartesian offset.
Definition: types.h:53
An integer width and height.
Definition: types.h:59
A rectangle in integer cartesian coordinates.
Definition: types.h:65
An integer cartesian offset.
Definition: types.h:71
An integer width and height.
Definition: types.h:77
A rectangle in floating point cartesian coordinates.
Definition: types.h:83
3D vector
Definition: types.h:89
Quaternion.
Definition: types.h:96
T5_GraphicsApi_GL_TextureMode textureMode
Specify the interpretation of the texture handles in T5_FrameInfo.
Definition: types.h:196
uint32_t rightEyeArrayIndex
In kT5_GraphicsApi_GL_TextureMode_Array, specify the array index of the right eye.
Definition: types.h:202
uint32_t leftEyeArrayIndex
In kT5_GraphicsApi_GL_TextureMode_Array, specify the array index of the left eye.
Definition: types.h:199
void * physicalDevice
A pointer to a VkPhysicalDevice.
Definition: types.h:220
T5_GraphicsApi_Vulkan_TextureMode textureMode
Specify the interpretation of the texture handles in T5_FrameInfo.
Definition: types.h:235
void * queue
A pointer to a VkQueue.
Definition: types.h:229
void * device
A pointer to a VkDevice.
Definition: types.h:223
void * instance
A pointer to a VkInstance.
Definition: types.h:217
uint32_t queueFamilyIndex
The queue family index used to create the queue.
Definition: types.h:232
void * queue
\breif A pointer to a ID3D12CommandQueue
Definition: types.h:243
void * device
A pointer to a ID3D12Device.
Definition: types.h:240
Physical dimensions of a gameboard.
Definition: types.h:262
float viewableExtentNegativeY
The distance in meters from the gameboard origin to the edge of the viewable area in the negative Y d...
Definition: types.h:277
float viewableExtentPositiveZ
The distance in meters above the gameboard origin that the viewable area extends in the positive Z di...
Definition: types.h:281
float viewableExtentPositiveY
The distance in meters from the gameboard origin to the edge of the viewable area in the positive Y d...
Definition: types.h:273
float viewableExtentNegativeX
The distance in meters from the gameboard origin to the edge of the viewable area in the negative X d...
Definition: types.h:269
float viewableExtentPositiveX
The distance in meters from the gameboard origin to the edge of the viewable area in the positive X d...
Definition: types.h:265
Client provided information for use with t5CreateGlasses()
Definition: types.h:285
uint8_t sdkType
The SDK type.
Definition: types.h:295
const char * applicationId
The application ID.
Definition: types.h:287
const char * applicationVersion
The application version.
Definition: types.h:290
uint64_t reserved
RESERVED: Must be set to 0.
Definition: types.h:298
Glasses pose information to be retrieved with t5GetGlassesPose()
Definition: types.h:348
uint64_t timestampNanos
The timestamp of the pose.
Definition: types.h:350
T5_Vec3 posGLS_GBD
The position of the origin of the GLS (glasses) frame relative to the GBD (gameboard) frame.
Definition: types.h:354
T5_Quat rotToGLS_GBD
The rotation that transforms points in the GBD (gameboard) frame orientation to the GLS (glasses) fra...
Definition: types.h:358
T5_GameboardType gameboardType
The type of gameboard visible for this pose.
Definition: types.h:361
Camera stream configuration.
Definition: types.h:365
uint8_t cameraIndex
The index of the camera to be modified.
Definition: types.h:367
bool enabled
Enable or disable the camera stream. True = enabled.
Definition: types.h:370
Render information to be used with t5SendFrameToGlasses()
Definition: types.h:374
T5_Quat rotToLVC_GBD
The rotation from GBD to VC, the virtual camera reference frame for the left eye.
Definition: types.h:410
void * rightTexHandle
Texture handle for the right image.
Definition: types.h:387
T5_Vec3 posLVC_GBD
The position of VC, the virtual camera reference frame, relative to GBD for the left eye.
Definition: types.h:414
bool isUpsideDown
True if the image is 'upside down'.
Definition: types.h:399
bool isSrgb
True if the texture is srgb. This is only relevant for the OpenGL graphics API.
Definition: types.h:396
T5_Vec3 posRVC_GBD
The position of VC, the virtual camera reference frame, relative to GBD for the right eye.
Definition: types.h:421
uint16_t texWidth_PIX
Width of the textures pointed to by leftTexHandle and rightTexHandle.
Definition: types.h:390
uint16_t texHeight_PIX
Height of the textures pointed to by leftTexHandle and rightTexHandle.
Definition: types.h:393
void * leftTexHandle
Texture handle for the left image.
Definition: types.h:380
T5_Quat rotToRVC_GBD
The rotation from GBD to VC, the virtual camera reference frame for the right eye.
Definition: types.h:417
void * texture
Texture handle.
Definition: types.h:431
int64_t format
The graphics API specific format used to create this texture.
Definition: types.h:459
T5_Rect rect
A rectangle defining which part of the texture is used.
Definition: types.h:447
uint16_t arraySize
The array size of array based textures.
Definition: types.h:440
uint16_t arrayIndex
For array textures, the index of the array to use.
Definition: types.h:452
T5_Extent dimensions
The dimensions of the texture.
Definition: types.h:437
T5_Rectf vci
The image rectangle in the normalized (z=1) image space of the virtual cameras.
Definition: types.h:462
Camera Frame information to be retrieved with t5GetFilledCamImageBuffer()
Definition: types.h:466
T5_Quat rotToCAM_GBD
The rotation of the camera relative to the GBD.
Definition: types.h:498
uint8_t illuminationMode
The illumination mode for incoming frames. 0 for unknown frame. 1 for Light frames....
Definition: types.h:485
uint8_t * pixelData
The image buffer being filled by the Tilt Five service.
Definition: types.h:492
uint16_t imageHeight
The height of the image in the image buffer. Empty buffers should set these parameters to 0.
Definition: types.h:473
uint16_t imageStride
The stride of the image in the image buffer. Empty buffers should set these parameters to 0.
Definition: types.h:477
uint32_t bufferSize
The total size of the provided image buffer. Must be at least T5_MIN_CAM_IMAGE_BUFFER_WIDTH * T5_MIN_...
Definition: types.h:489
T5_Vec3 posCAM_GBD
The position of the camera relative to the GBD.
Definition: types.h:495
uint8_t cameraIndex
The index of the desired camera. 0 for tangible tracking camera, 1 for head tracking camera.
Definition: types.h:481
uint16_t imageWidth
The width of the image in the image buffer. Empty buffers should set these parameters to 0.
Definition: types.h:469
Wand stream configuration.
Definition: types.h:502
bool enabled
Enable or disable the entire stream. True = enabled.
Definition: types.h:504
Contains wand related information (Pose, Buttons, Trigger, Stick, Battery)
Definition: types.h:536
bool poseValid
Validity of pose parameters. True = valid.
Definition: types.h:550
bool batteryValid
Validity of battery parameters. True = valid.
Definition: types.h:544
uint64_t timestampNanos
The timestamp of the wand event in nanoseconds.
Definition: types.h:538
uint8_t battery
Battery.
Definition: types.h:560
T5_Quat rotToWND_GBD
WND/GBD rotation unit quaternion.
Definition: types.h:578
T5_Vec3 posGrip_GBD
Position (Grip) - Vector3f.
Definition: types.h:587
float trigger
Trigger - Analog, Range [0.0 - 1.0], 1.0 = Fully depressed.
Definition: types.h:553
T5_Vec3 posAim_GBD
Position (Aim Point) - Vector3f.
Definition: types.h:581
bool analogValid
Validity of analog parameters. True = valid.
Definition: types.h:541
T5_Hand hand
Wand hand.
Definition: types.h:590
bool buttonsValid
Validity of button parameters. True = valid.
Definition: types.h:547
T5_Vec3 posFingertips_GBD
Position (Fingertips) - Vector3f.
Definition: types.h:584
T5_Vec2 stick
Stick (X/Y) - Analog, Range [-1.0 - 1.0], 0 = Centered, 1.0 = Top/Right.
Definition: types.h:556
Represents an event from the wand stream.
Definition: types.h:594
uint64_t timestampNanos
The timestamp of the wand event in nanoseconds.
Definition: types.h:602
T5_WandReport report
Report (Valid if type = kT5_WandStreamEventType_Report)
Definition: types.h:605
T5_WandStreamEventType type
Type of event.
Definition: types.h:599
T5_WandHandle wandId
Opaque identifier for the wand.
Definition: types.h:596
Projection parameters.
Definition: types.h:629
uint16_t framebufferWidth
Framebuffer Width.
Definition: types.h:640
uint16_t framebufferHeight
Framebuffer Height.
Definition: types.h:643
double fieldOfView
Field of View (Y Axis in Degrees)
Definition: types.h:634
double aspectRatio
Aspect Ratio.
Definition: types.h:637