diff --git a/interface/resources/controllers/openxr_index.json b/interface/resources/controllers/openxr_index.json index 774b55981e..15ee5b5d3b 100644 --- a/interface/resources/controllers/openxr_index.json +++ b/interface/resources/controllers/openxr_index.json @@ -5,15 +5,10 @@ { "from": "Index.RightHand", "to": "Standard.RightHand" }, { "from": "Index.Head", "to" : "Standard.Head", "when" : [ "Application.InHMD"] }, - { "from": "Index.A", "to": "Standard.RightPrimaryThumb", "peek": true }, - { "from": "Index.B", "to": "Standard.RightSecondaryThumb", "peek": true }, - { "from": "Index.X", "to": "Standard.LeftPrimaryThumb", "peek": true }, - { "from": "Index.Y", "to": "Standard.LeftSecondaryThumb", "peek": true}, - - { "from": "Index.A", "to": "Standard.A" }, - { "from": "Index.B", "to": "Standard.B" }, - { "from": "Index.X", "to": "Standard.X" }, - { "from": "Index.Y", "to": "Standard.Y" }, + { "from": "Index.RightPrimaryThumb", "to": "Standard.RightPrimaryThumb" }, + { "from": "Index.RightSecondaryThumb", "to": "Standard.RightSecondaryThumb" }, + { "from": "Index.LeftPrimaryThumb", "to": "Standard.LeftPrimaryThumb" }, + { "from": "Index.LeftSecondaryThumb", "to": "Standard.LeftSecondaryThumb" }, { "from": "Index.LeftPrimaryThumbTouch", "to": "Standard.LeftPrimaryThumbTouch" }, { "from": "Index.LeftSecondaryThumbTouch", "to": "Standard.LeftSecondaryThumbTouch" }, @@ -27,6 +22,8 @@ { "from": "Index.LX", "to": "Standard.LX" }, { "from": "Index.RY", "to": "Standard.RY" }, { "from": "Index.RX", "to": "Standard.RX" }, + { "from": "Index.LS", "to": "Standard.LS" }, + { "from": "Index.RS", "to": "Standard.RS" }, { "from": "Index.LSTouch", "to": "Standard.LSTouch" }, { "from": "Index.RSTouch", "to": "Standard.RSTouch" }, diff --git a/plugins/openxr/src/OpenXrInputPlugin.cpp b/plugins/openxr/src/OpenXrInputPlugin.cpp index f5eaabff0b..58ab880814 100644 --- a/plugins/openxr/src/OpenXrInputPlugin.cpp +++ b/plugins/openxr/src/OpenXrInputPlugin.cpp @@ -302,18 +302,29 @@ controller::Input::NamedVector OpenXrInputPlugin::InputDevice::getAvailableInput // Sticks makePair(LX, "LX"), makePair(LY, "LY"), + makePair(LS, "LS"), + makePair(LS_TOUCH, "LSTouch"), makePair(RX, "RX"), makePair(RY, "RY"), + makePair(RS, "RS"), + makePair(RS_TOUCH, "RSTouch"), // Face buttons - makePair(A, "A"), - makePair(B, "B"), - makePair(X, "X"), - makePair(Y, "Y"), + makePair(RIGHT_PRIMARY_THUMB, "RightPrimaryThumb"), + makePair(RIGHT_PRIMARY_THUMB_TOUCH, "RightPrimaryThumbTouch"), + makePair(RIGHT_SECONDARY_THUMB, "RightSecondaryThumb"), + makePair(RIGHT_SECONDARY_THUMB_TOUCH, "RightSecondaryThumbTouch"), + + makePair(LEFT_PRIMARY_THUMB, "LeftPrimaryThumb"), + makePair(LEFT_PRIMARY_THUMB_TOUCH, "LeftPrimaryThumbTouch"), + makePair(LEFT_SECONDARY_THUMB, "LeftSecondaryThumb"), + makePair(LEFT_SECONDARY_THUMB_TOUCH, "LeftSecondaryThumbTouch"), // Triggers makePair(RT, "RT"), makePair(LT, "LT"), makePair(RT_CLICK, "RTClick"), makePair(LT_CLICK, "LTClick"), + makePair(LEFT_PRIMARY_INDEX_TOUCH, "LeftPrimaryIndexTouch"), + makePair(RIGHT_PRIMARY_INDEX_TOUCH, "RightPrimaryIndexTouch"), // Menu buttons // TODO: Add this to button channel // Input::NamedPair(Input(_deviceID, LEFT_APP_MENU, ChannelType::BUTTON), "LeftApplicationMenu"), @@ -350,10 +361,15 @@ bool OpenXrInputPlugin::InputDevice::initActions() { std::map actionsToInit = { { "/input/thumbstick/x", XR_ACTION_TYPE_FLOAT_INPUT }, { "/input/thumbstick/y", XR_ACTION_TYPE_FLOAT_INPUT }, + { "/input/thumbstick/touch", XR_ACTION_TYPE_BOOLEAN_INPUT }, + { "/input/thumbstick/click", XR_ACTION_TYPE_BOOLEAN_INPUT }, { "/input/a/click", XR_ACTION_TYPE_BOOLEAN_INPUT }, + { "/input/a/touch", XR_ACTION_TYPE_BOOLEAN_INPUT }, { "/input/b/click", XR_ACTION_TYPE_BOOLEAN_INPUT }, + { "/input/b/touch", XR_ACTION_TYPE_BOOLEAN_INPUT }, { "/input/trigger/value", XR_ACTION_TYPE_FLOAT_INPUT }, { "/input/trigger/click", XR_ACTION_TYPE_BOOLEAN_INPUT }, + { "/input/trigger/touch", XR_ACTION_TYPE_BOOLEAN_INPUT }, { "/output/haptic", XR_ACTION_TYPE_VIBRATION_OUTPUT }, { "/input/grip/pose", XR_ACTION_TYPE_POSE_INPUT }, { "/input/select/click", XR_ACTION_TYPE_BOOLEAN_INPUT }, @@ -387,9 +403,15 @@ bool OpenXrInputPlugin::InputDevice::initActions() { "/input/grip/pose", "/input/thumbstick/x", "/input/thumbstick/y", + "/input/thumbstick/touch", + "/input/thumbstick/click", "/input/a/click", + "/input/a/touch", "/input/b/click", + "/input/b/touch", "/input/trigger/value", + "/input/trigger/click", + "/input/trigger/touch", "/output/haptic", "/input/system/click", }; @@ -499,15 +521,25 @@ void OpenXrInputPlugin::InputDevice::update(float deltaTime, const controller::I // TODO: Figure out why LEFT_APP_MENU is misssing in StandardButtonChannel std::map buttonsToUpdate[2] = { { - { controller::X, "/input/a/click" }, - { controller::Y, "/input/b/click" }, + { controller::LEFT_PRIMARY_THUMB, "/input/a/click" }, + { controller::LEFT_PRIMARY_THUMB_TOUCH, "/input/a/touch" }, + { controller::LEFT_SECONDARY_THUMB, "/input/b/click" }, + { controller::LEFT_SECONDARY_THUMB_TOUCH, "/input/b/touch" }, { controller::LT_CLICK, "/input/trigger/click" }, + { controller::LEFT_PRIMARY_INDEX_TOUCH, "/input/trigger/touch" }, + { controller::LS, "/input/thumbstick/click" }, + { controller::LS_TOUCH, "/input/thumbstick/touch" }, //{ LEFT_APP_MENU, "/input/system/click" }, }, { - { controller::A, "/input/a/click" }, - { controller::B, "/input/b/click" }, + { controller::RIGHT_PRIMARY_THUMB, "/input/a/click" }, + { controller::RIGHT_PRIMARY_THUMB_TOUCH, "/input/a/touch" }, + { controller::RIGHT_SECONDARY_THUMB, "/input/b/click" }, + { controller::RIGHT_SECONDARY_THUMB_TOUCH, "/input/b/touch" }, { controller::RT_CLICK, "/input/trigger/click" }, + { controller::RIGHT_PRIMARY_INDEX_TOUCH, "/input/trigger/touch" }, + { controller::RS, "/input/thumbstick/click" }, + { controller::RS_TOUCH, "/input/thumbstick/touch" }, //{ RIGHT_APP_MENU, "/input/system/click" }, }, };