mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-04 06:06:17 +00:00
d/steamvr_lh: Add support for Vive Pro & Index
Co-Authored-By: Gabriele Musco <gabmus@disroot.org>
This commit is contained in:
parent
3a75d66c69
commit
6d8463823b
|
@ -35,7 +35,11 @@ struct InputClass
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
InputClass hmd_class{{}, "Generic HMD", {XRT_INPUT_GENERIC_HEAD_POSE}, {}};
|
const std::unordered_map<std::string_view, InputClass> hmd_classes{
|
||||||
|
{"vive", InputClass{XRT_DEVICE_GENERIC_HMD, "Vive HMD", {XRT_INPUT_GENERIC_HEAD_POSE}, {}, {}}},
|
||||||
|
{"indexhmd", InputClass{XRT_DEVICE_GENERIC_HMD, "Index HMD", {XRT_INPUT_GENERIC_HEAD_POSE}, {}, {}}},
|
||||||
|
{"vive_pro", InputClass{XRT_DEVICE_GENERIC_HMD, "Vive Pro HMD", {XRT_INPUT_GENERIC_HEAD_POSE}, {}, {}}},
|
||||||
|
};
|
||||||
|
|
||||||
// Adding support for a new controller is a simple as adding it here.
|
// Adding support for a new controller is a simple as adding it here.
|
||||||
// The key for the map needs to be the name of input profile as indicated by the lighthouse driver.
|
// The key for the map needs to be the name of input profile as indicated by the lighthouse driver.
|
||||||
|
@ -407,9 +411,15 @@ HmdDevice::handle_property_write(const vr::PropertyWrite_t &prop)
|
||||||
case vr::Prop_InputProfilePath_String: {
|
case vr::Prop_InputProfilePath_String: {
|
||||||
std::string_view profile =
|
std::string_view profile =
|
||||||
parse_profile(std::string_view(static_cast<char *>(prop.pvBuffer), prop.unBufferSize));
|
parse_profile(std::string_view(static_cast<char *>(prop.pvBuffer), prop.unBufferSize));
|
||||||
if (profile == "vive") {
|
auto input_class = hmd_classes.find(profile);
|
||||||
std::strcpy(this->str, "Vive HMD");
|
if (input_class == hmd_classes.end()) {
|
||||||
|
DEV_ERR("Could not find input class for hmd profile %s", std::string(profile).c_str());
|
||||||
|
} else {
|
||||||
|
std::strcpy(this->str, input_class->second.description.c_str());
|
||||||
|
this->name = input_class->second.name;
|
||||||
|
set_input_class(&input_class->second);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
default: break;
|
default: break;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue