d/steamvr_lh: Enable vive tracker pucks

This commit is contained in:
BabbleBones 2023-08-29 23:32:33 -04:00 committed by Jakob Bornecrantz
parent 96ea303623
commit 466398dc5a
3 changed files with 67 additions and 26 deletions

View file

@ -126,7 +126,7 @@ const std::unordered_map<std::string_view, InputClass> controller_classes{
XRT_DEVICE_VIVE_TRACKER,
"HTC Vive Tracker",
{
XRT_INPUT_VIVE_TRACKER_GRIP_POSE,
XRT_INPUT_GENERIC_TRACKER_POSE,
},
{
{"/input/system/click", XRT_INPUT_VIVE_TRACKER_SYSTEM_CLICK},
@ -357,6 +357,10 @@ ControllerDevice::set_haptic_handle(vr::VRInputComponentHandle_t handle)
name = XRT_OUTPUT_NAME_INDEX_HAPTIC;
break;
}
case XRT_DEVICE_VIVE_TRACKER: {
name = XRT_OUTPUT_NAME_VIVE_TRACKER_HAPTIC;
break;
}
default: {
DEV_WARN("Unknown device name (%u), haptics will not work", this->name);
return;
@ -603,7 +607,7 @@ void
Device::update_pose(const vr::DriverPose_t &newPose)
{
xrt_space_relation relation;
if (newPose.poseIsValid) {
if (newPose.poseIsValid && newPose.deviceIsConnected) {
relation.relation_flags = XRT_SPACE_RELATION_BITMASK_ALL;
const xrt_vec3 to_local_pos = copy_vec3(newPose.vecDriverFromHeadTranslation);
@ -758,6 +762,10 @@ ControllerDevice::handle_property_write(const vr::PropertyWrite_t &prop)
set_hand_tracking_hand(XRT_INPUT_GENERIC_HAND_TRACKING_LEFT);
break;
}
case vr::TrackedControllerRole_OptOut: {
this->device_type = XRT_DEVICE_TYPE_GENERIC_TRACKER;
break;
}
default: {
}
}

View file

@ -118,7 +118,7 @@ protected:
public:
// These are owned by monado, context is destroyed when these are destroyed
class HmdDevice *hmd{nullptr};
class ControllerDevice *controller[2]{nullptr, nullptr};
class ControllerDevice *controller[16]{nullptr};
const u_logging_level log_level;
~Context();

View file

@ -27,6 +27,8 @@ namespace {
DEBUG_GET_ONCE_LOG_OPTION(lh_log, "LIGHTHOUSE_LOG", U_LOGGING_INFO)
static const size_t MAX_CONTROLLERS = 16;
// ~/.steam/root is a symlink to where the Steam root is
const std::string STEAM_INSTALL_DIR = std::string(getenv("HOME")) + "/.steam/root";
constexpr auto STEAMVR_APPID = "250820";
@ -185,21 +187,28 @@ Context::setup_hmd(const char *serial, vr::ITrackedDeviceServerDriver *driver)
bool
Context::setup_controller(const char *serial, vr::ITrackedDeviceServerDriver *driver)
{
if (controller[0] && controller[1]) {
CTX_WARN("Attempted to activate more than two controllers - this is unsupported");
// Find the first available slot for a new controller
size_t device_idx = 0;
for (; device_idx < MAX_CONTROLLERS; ++device_idx) {
if (!controller[device_idx])
break;
}
// Check if we've exceeded the maximum number of controllers
if (device_idx == MAX_CONTROLLERS) {
CTX_WARN("Attempted to activate more than %zu controllers - this is unsupported", MAX_CONTROLLERS);
return false;
}
size_t device_idx = (controller[0]) ? 2 : 1;
auto &dev = controller[device_idx - 1];
dev = new ControllerDevice(device_idx + 1,
DeviceBuilder{this->shared_from_this(), driver, serial, STEAM_INSTALL_DIR});
vr::EVRInitError err = driver->Activate(device_idx);
// Create the new controller
controller[device_idx] = new ControllerDevice(
device_idx + 1, DeviceBuilder{this->shared_from_this(), driver, serial, STEAM_INSTALL_DIR});
vr::EVRInitError err = driver->Activate(device_idx + 1);
if (err != vr::VRInitError_None) {
CTX_ERR("Activating controller failed: error %u", err);
return false;
}
return true;
}
@ -231,6 +240,10 @@ Context::TrackedDeviceAdded(const char *pchDeviceSerialNumber,
CTX_INFO("Found lighthouse device: %s", pchDeviceSerialNumber);
return false;
}
case vr::TrackedDeviceClass_GenericTracker: {
return setup_controller(pchDeviceSerialNumber, pDriver);
break;
}
default: {
CTX_WARN("Attempted to add unsupported device class: %u", eDeviceClass);
return false;
@ -242,10 +255,21 @@ void
Context::TrackedDevicePoseUpdated(uint32_t unWhichDevice, const vr::DriverPose_t &newPose, uint32_t unPoseStructSize)
{
assert(sizeof(newPose) == unPoseStructSize);
if (unWhichDevice > 2)
// Check for valid device index, allowing for the HMD plus up to 16 controllers
if (unWhichDevice > 16)
return;
Device *dev = (unWhichDevice == 0) ? static_cast<Device *>(this->hmd)
: static_cast<Device *>(this->controller[unWhichDevice - 1]);
Device *dev = nullptr;
// If unWhichDevice is 0, it refers to the HMD; otherwise, it refers to one of the controllers
if (unWhichDevice == 0) {
dev = static_cast<Device *>(this->hmd);
} else {
// unWhichDevice - 1 will give the index into the controller array
dev = static_cast<Device *>(this->controller[unWhichDevice - 1]);
}
assert(dev);
dev->update_pose(newPose);
}
@ -571,14 +595,15 @@ Context::prop_container_to_device(vr::PropertyContainerHandle_t handle)
return hmd;
break;
}
case 2:
case 3: {
return controller[handle - 2];
break;
}
default: {
// If the handle corresponds to a controller
if (handle >= 2 && handle <= 17) {
return controller[handle - 2];
} else {
return nullptr;
}
break;
}
}
}
@ -586,9 +611,10 @@ vr::PropertyContainerHandle_t
Context::TrackedDeviceToPropertyContainer(vr::TrackedDeviceIndex_t nDevice)
{
size_t container = nDevice + 1;
if (nDevice == 0 && this->hmd)
if (nDevice == 0 && this->hmd) {
return container;
if ((nDevice == 1 || nDevice == 2) && this->controller[nDevice - 1]) {
}
if (nDevice >= 1 && nDevice <= 16 && this->controller[nDevice - 1]) {
return container;
}
@ -665,11 +691,18 @@ steamvr_lh_get_devices(struct xrt_device **out_xdevs)
U_LOG_IFL_I(level, "Device search time complete.");
int devices = 0;
Device *devs[] = {ctx->hmd, ctx->controller[0], ctx->controller[1]};
for (Device *dev : devs) {
if (dev) {
out_xdevs[devices++] = dev;
// Include the HMD
if (ctx->hmd) {
out_xdevs[devices++] = ctx->hmd;
}
// Include the controllers (up to 16)
for (int i = 0; i < 16; i++) {
if (ctx->controller[i]) {
out_xdevs[devices++] = ctx->controller[i];
}
}
return devices;
}