d/wmr: Add more to the I/O

This commit is contained in:
Jakob Bornecrantz 2021-11-20 18:25:34 +00:00
parent 7fa3109e2a
commit 839ada7115
2 changed files with 85 additions and 7 deletions

View file

@ -39,6 +39,8 @@
#define WMR_WARN(d, ...) U_LOG_XDEV_IFL_W(&d->base, d->ll, __VA_ARGS__) #define WMR_WARN(d, ...) U_LOG_XDEV_IFL_W(&d->base, d->ll, __VA_ARGS__)
#define WMR_ERROR(d, ...) U_LOG_XDEV_IFL_E(&d->base, d->ll, __VA_ARGS__) #define WMR_ERROR(d, ...) U_LOG_XDEV_IFL_E(&d->base, d->ll, __VA_ARGS__)
#define SET_INPUT(NAME) (d->base.inputs[WMR_INDEX_##NAME].name = XRT_INPUT_WMR_##NAME)
static inline struct wmr_bt_controller * static inline struct wmr_bt_controller *
wmr_bt_controller(struct xrt_device *p) wmr_bt_controller(struct xrt_device *p)
@ -113,8 +115,20 @@ wmr_bt_controller_get_tracked_pose(struct xrt_device *xdev,
static void static void
wmr_bt_controller_update_inputs(struct xrt_device *xdev) wmr_bt_controller_update_inputs(struct xrt_device *xdev)
{ {
// struct wmr_bt_controller *d = wmr_bt_controller(xdev); struct wmr_bt_controller *d = wmr_bt_controller(xdev);
// Todo: implement
struct xrt_input *inputs = d->base.inputs;
//! @todo Mutex protect the input struct.
inputs[WMR_INDEX_MENU_CLICK].value.boolean = d->input.menu;
inputs[WMR_INDEX_SQUEEZE_CLICK].value.boolean = d->input.squeeze;
inputs[WMR_INDEX_TRIGGER_VALUE].value.vec1.x = d->input.trigger;
inputs[WMR_INDEX_THUMBSTICK_CLICK].value.boolean = d->input.thumbstick.click;
inputs[WMR_INDEX_THUMBSTICK].value.vec2 = d->input.thumbstick.values;
inputs[WMR_INDEX_TRACKPAD_CLICK].value.boolean = d->input.trackpad.click;
inputs[WMR_INDEX_TRACKPAD_TOUCH].value.boolean = d->input.trackpad.touch;
inputs[WMR_INDEX_TRACKPAD].value.vec2 = d->input.trackpad.values;
} }
static void * static void *
@ -144,6 +158,9 @@ wmr_bt_controller_destroy(struct xrt_device *xdev)
{ {
struct wmr_bt_controller *d = wmr_bt_controller(xdev); struct wmr_bt_controller *d = wmr_bt_controller(xdev);
// Remove the variable tracking.
u_var_remove_root(d);
// Destroy the thread object. // Destroy the thread object.
os_thread_helper_destroy(&d->controller_thread); os_thread_helper_destroy(&d->controller_thread);
@ -201,7 +218,7 @@ wmr_bt_controller_create(struct os_hid_device *controller_hid,
{ {
enum u_device_alloc_flags flags = U_DEVICE_ALLOC_TRACKING_NONE; enum u_device_alloc_flags flags = U_DEVICE_ALLOC_TRACKING_NONE;
struct wmr_bt_controller *d = U_DEVICE_ALLOCATE(struct wmr_bt_controller, flags, 2, 0); struct wmr_bt_controller *d = U_DEVICE_ALLOCATE(struct wmr_bt_controller, flags, 10, 1);
d->ll = ll; d->ll = ll;
d->controller_hid = controller_hid; d->controller_hid = controller_hid;
@ -217,10 +234,23 @@ wmr_bt_controller_create(struct os_hid_device *controller_hid,
d->base.set_output = wmr_bt_controller_set_output; d->base.set_output = wmr_bt_controller_set_output;
d->base.update_inputs = wmr_bt_controller_update_inputs; d->base.update_inputs = wmr_bt_controller_update_inputs;
d->base.inputs[0].name = XRT_INPUT_WMR_GRIP_POSE; SET_INPUT(MENU_CLICK);
SET_INPUT(SQUEEZE_CLICK);
SET_INPUT(TRIGGER_VALUE);
SET_INPUT(THUMBSTICK_CLICK);
SET_INPUT(THUMBSTICK);
SET_INPUT(TRACKPAD_CLICK);
SET_INPUT(TRACKPAD_TOUCH);
SET_INPUT(TRACKPAD);
SET_INPUT(GRIP_POSE);
SET_INPUT(AIM_POSE);
for (uint32_t i = 0; i < d->base.input_count; i++) {
d->base.inputs[0].active = true; d->base.inputs[0].active = true;
d->base.inputs[1].name = XRT_INPUT_WMR_AIM_POSE; }
d->base.inputs[1].active = true;
d->base.outputs[0].name = XRT_OUTPUT_NAME_WMR_HAPTIC;
d->base.binding_profiles = binding_profiles; d->base.binding_profiles = binding_profiles;
d->base.binding_profile_count = ARRAY_SIZE(binding_profiles); d->base.binding_profile_count = ARRAY_SIZE(binding_profiles);
@ -257,5 +287,17 @@ wmr_bt_controller_create(struct os_hid_device *controller_hid,
} }
u_var_add_root(d, d->base.str, true);
u_var_add_bool(d, &d->input.menu, "input.menu");
u_var_add_bool(d, &d->input.squeeze, "input.squeeze");
u_var_add_f32(d, &d->input.trigger, "input.trigger");
u_var_add_bool(d, &d->input.thumbstick.click, "input.thumbstick.click");
u_var_add_f32(d, &d->input.thumbstick.values.x, "input.thumbstick.values.y");
u_var_add_f32(d, &d->input.thumbstick.values.y, "input.thumbstick.values.x");
u_var_add_bool(d, &d->input.trackpad.click, "input.trackpad.click");
u_var_add_bool(d, &d->input.trackpad.touch, "input.trackpad.touch");
u_var_add_f32(d, &d->input.trackpad.values.x, "input.trackpad.values.x");
u_var_add_f32(d, &d->input.trackpad.values.y, "input.trackpad.values.y");
return &d->base; return &d->base;
} }

View file

@ -23,6 +23,23 @@ extern "C" {
#endif #endif
/*!
* Indices where each input is in the input list.
*/
enum wmr_bt_input_index
{
WMR_INDEX_MENU_CLICK,
WMR_INDEX_SQUEEZE_CLICK,
WMR_INDEX_TRIGGER_VALUE,
WMR_INDEX_THUMBSTICK_CLICK,
WMR_INDEX_THUMBSTICK,
WMR_INDEX_TRACKPAD_CLICK,
WMR_INDEX_TRACKPAD_TOUCH,
WMR_INDEX_TRACKPAD,
WMR_INDEX_GRIP_POSE,
WMR_INDEX_AIM_POSE,
};
/*! /*!
* A Bluetooth connected WMR Controller device, representing just a single controller. * A Bluetooth connected WMR Controller device, representing just a single controller.
* *
@ -52,6 +69,25 @@ struct wmr_bt_controller
enum u_logging_level ll; enum u_logging_level ll;
uint32_t last_ticks; uint32_t last_ticks;
struct
{
bool menu;
bool squeeze;
float trigger;
struct
{
bool click;
struct xrt_vec2 values;
} thumbstick;
struct
{
bool click;
bool touch;
struct xrt_vec2 values;
} trackpad;
} input;
}; };