Add a get_system_info method to XRInterface
This commit is contained in:
parent
550a779851
commit
e31c2e4277
14 changed files with 69 additions and 1 deletions
|
@ -57,6 +57,13 @@
|
||||||
Returns the an array of supported environment blend modes, see [enum XRInterface.EnvironmentBlendMode].
|
Returns the an array of supported environment blend modes, see [enum XRInterface.EnvironmentBlendMode].
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="get_system_info">
|
||||||
|
<return type="Dictionary" />
|
||||||
|
<description>
|
||||||
|
Returns a [Dictionary] with extra system info. Interfaces are expected to return [code]XRRuntimeName[/code] and [code]XRRuntimeVersion[/code] providing info about the used XR runtime. Additional entries may be provided specific to an interface.
|
||||||
|
[b]Note:[/b]This information may only be available after [method initialize] was successfully called.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="get_tracking_status" qualifiers="const">
|
<method name="get_tracking_status" qualifiers="const">
|
||||||
<return type="int" enum="XRInterface.TrackingStatus" />
|
<return type="int" enum="XRInterface.TrackingStatus" />
|
||||||
<description>
|
<description>
|
||||||
|
|
|
@ -98,6 +98,12 @@
|
||||||
Returns a [PackedStringArray] with tracker names configured by this interface. Note that user configuration can override this list.
|
Returns a [PackedStringArray] with tracker names configured by this interface. Note that user configuration can override this list.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="_get_system_info" qualifiers="virtual const">
|
||||||
|
<return type="Dictionary" />
|
||||||
|
<description>
|
||||||
|
Returns a [Dictionary] with system informationr elated to this interface.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="_get_tracking_status" qualifiers="virtual const">
|
<method name="_get_tracking_status" qualifiers="virtual const">
|
||||||
<return type="int" enum="XRInterface.TrackingStatus" />
|
<return type="int" enum="XRInterface.TrackingStatus" />
|
||||||
<description>
|
<description>
|
||||||
|
|
|
@ -372,6 +372,15 @@ void MobileVRInterface::uninitialize() {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Dictionary MobileVRInterface::get_system_info() {
|
||||||
|
Dictionary dict;
|
||||||
|
|
||||||
|
dict[SNAME("XRRuntimeName")] = String("Godot mobile VR interface");
|
||||||
|
dict[SNAME("XRRuntimeVersion")] = String("");
|
||||||
|
|
||||||
|
return dict;
|
||||||
|
}
|
||||||
|
|
||||||
bool MobileVRInterface::supports_play_area_mode(XRInterface::PlayAreaMode p_mode) {
|
bool MobileVRInterface::supports_play_area_mode(XRInterface::PlayAreaMode p_mode) {
|
||||||
// This interface has no positional tracking so fix this to 3DOF
|
// This interface has no positional tracking so fix this to 3DOF
|
||||||
return p_mode == XR_PLAY_AREA_3DOF;
|
return p_mode == XR_PLAY_AREA_3DOF;
|
||||||
|
|
|
@ -141,6 +141,7 @@ public:
|
||||||
virtual bool is_initialized() const override;
|
virtual bool is_initialized() const override;
|
||||||
virtual bool initialize() override;
|
virtual bool initialize() override;
|
||||||
virtual void uninitialize() override;
|
virtual void uninitialize() override;
|
||||||
|
virtual Dictionary get_system_info() override;
|
||||||
|
|
||||||
virtual bool supports_play_area_mode(XRInterface::PlayAreaMode p_mode) override;
|
virtual bool supports_play_area_mode(XRInterface::PlayAreaMode p_mode) override;
|
||||||
virtual XRInterface::PlayAreaMode get_play_area_mode() const override;
|
virtual XRInterface::PlayAreaMode get_play_area_mode() const override;
|
||||||
|
|
|
@ -385,8 +385,13 @@ bool OpenXRAPI::create_instance() {
|
||||||
if (XR_FAILED(result)) {
|
if (XR_FAILED(result)) {
|
||||||
// not fatal probably
|
// not fatal probably
|
||||||
print_line("OpenXR: Failed to get XR instance properties [", get_error_string(result), "]");
|
print_line("OpenXR: Failed to get XR instance properties [", get_error_string(result), "]");
|
||||||
|
|
||||||
|
runtime_name = "";
|
||||||
|
runtime_version = "";
|
||||||
} else {
|
} else {
|
||||||
print_line("OpenXR: Running on OpenXR runtime: ", instanceProps.runtimeName, " ", OpenXRUtil::make_xr_version_string(instanceProps.runtimeVersion));
|
runtime_name = instanceProps.runtimeName;
|
||||||
|
runtime_version = OpenXRUtil::make_xr_version_string(instanceProps.runtimeVersion);
|
||||||
|
print_line("OpenXR: Running on OpenXR runtime: ", runtime_name, " ", runtime_version);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (OpenXRExtensionWrapper *wrapper : registered_extension_wrappers) {
|
for (OpenXRExtensionWrapper *wrapper : registered_extension_wrappers) {
|
||||||
|
|
|
@ -95,6 +95,10 @@ private:
|
||||||
uint32_t num_swapchain_formats = 0;
|
uint32_t num_swapchain_formats = 0;
|
||||||
int64_t *supported_swapchain_formats = nullptr;
|
int64_t *supported_swapchain_formats = nullptr;
|
||||||
|
|
||||||
|
// system info
|
||||||
|
String runtime_name;
|
||||||
|
String runtime_version;
|
||||||
|
|
||||||
// configuration
|
// configuration
|
||||||
XrFormFactor form_factor = XR_FORM_FACTOR_HEAD_MOUNTED_DISPLAY;
|
XrFormFactor form_factor = XR_FORM_FACTOR_HEAD_MOUNTED_DISPLAY;
|
||||||
XrViewConfigurationType view_configuration = XR_VIEW_CONFIGURATION_TYPE_PRIMARY_STEREO;
|
XrViewConfigurationType view_configuration = XR_VIEW_CONFIGURATION_TYPE_PRIMARY_STEREO;
|
||||||
|
@ -294,6 +298,8 @@ public:
|
||||||
XrInstance get_instance() const { return instance; };
|
XrInstance get_instance() const { return instance; };
|
||||||
XrSystemId get_system_id() const { return system_id; };
|
XrSystemId get_system_id() const { return system_id; };
|
||||||
XrSession get_session() const { return session; };
|
XrSession get_session() const { return session; };
|
||||||
|
String get_runtime_name() const { return runtime_name; };
|
||||||
|
String get_runtime_version() const { return runtime_version; };
|
||||||
|
|
||||||
// helper method to convert an XrPosef to a Transform3D
|
// helper method to convert an XrPosef to a Transform3D
|
||||||
Transform3D transform_from_pose(const XrPosef &p_pose);
|
Transform3D transform_from_pose(const XrPosef &p_pose);
|
||||||
|
|
|
@ -583,6 +583,17 @@ void OpenXRInterface::uninitialize() {
|
||||||
initialized = false;
|
initialized = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Dictionary OpenXRInterface::get_system_info() {
|
||||||
|
Dictionary dict;
|
||||||
|
|
||||||
|
if (openxr_api) {
|
||||||
|
dict[SNAME("XRRuntimeName")] = openxr_api->get_runtime_name();
|
||||||
|
dict[SNAME("XRRuntimeVersion")] = openxr_api->get_runtime_version();
|
||||||
|
}
|
||||||
|
|
||||||
|
return dict;
|
||||||
|
}
|
||||||
|
|
||||||
bool OpenXRInterface::supports_play_area_mode(XRInterface::PlayAreaMode p_mode) {
|
bool OpenXRInterface::supports_play_area_mode(XRInterface::PlayAreaMode p_mode) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -112,6 +112,7 @@ public:
|
||||||
virtual bool is_initialized() const override;
|
virtual bool is_initialized() const override;
|
||||||
virtual bool initialize() override;
|
virtual bool initialize() override;
|
||||||
virtual void uninitialize() override;
|
virtual void uninitialize() override;
|
||||||
|
virtual Dictionary get_system_info() override;
|
||||||
|
|
||||||
virtual void trigger_haptic_pulse(const String &p_action_name, const StringName &p_tracker_name, double p_frequency, double p_amplitude, double p_duration_sec, double p_delay_sec = 0) override;
|
virtual void trigger_haptic_pulse(const String &p_action_name, const StringName &p_tracker_name, double p_frequency, double p_amplitude, double p_duration_sec, double p_delay_sec = 0) override;
|
||||||
|
|
||||||
|
|
|
@ -301,6 +301,16 @@ void WebXRInterfaceJS::uninitialize() {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Dictionary WebXRInterfaceJS::get_system_info() {
|
||||||
|
Dictionary dict;
|
||||||
|
|
||||||
|
// TODO get actual information from WebXR to return here
|
||||||
|
dict[SNAME("XRRuntimeName")] = String("WebXR");
|
||||||
|
dict[SNAME("XRRuntimeVersion")] = String("");
|
||||||
|
|
||||||
|
return dict;
|
||||||
|
}
|
||||||
|
|
||||||
Transform3D WebXRInterfaceJS::_js_matrix_to_transform(float *p_js_matrix) {
|
Transform3D WebXRInterfaceJS::_js_matrix_to_transform(float *p_js_matrix) {
|
||||||
Transform3D transform;
|
Transform3D transform;
|
||||||
|
|
||||||
|
|
|
@ -108,6 +108,7 @@ public:
|
||||||
virtual bool is_initialized() const override;
|
virtual bool is_initialized() const override;
|
||||||
virtual bool initialize() override;
|
virtual bool initialize() override;
|
||||||
virtual void uninitialize() override;
|
virtual void uninitialize() override;
|
||||||
|
virtual Dictionary get_system_info() override;
|
||||||
|
|
||||||
virtual Size2 get_render_target_size() override;
|
virtual Size2 get_render_target_size() override;
|
||||||
virtual uint32_t get_view_count() override;
|
virtual uint32_t get_view_count() override;
|
||||||
|
|
|
@ -43,6 +43,7 @@ void XRInterface::_bind_methods() {
|
||||||
ClassDB::bind_method(D_METHOD("is_initialized"), &XRInterface::is_initialized);
|
ClassDB::bind_method(D_METHOD("is_initialized"), &XRInterface::is_initialized);
|
||||||
ClassDB::bind_method(D_METHOD("initialize"), &XRInterface::initialize);
|
ClassDB::bind_method(D_METHOD("initialize"), &XRInterface::initialize);
|
||||||
ClassDB::bind_method(D_METHOD("uninitialize"), &XRInterface::uninitialize);
|
ClassDB::bind_method(D_METHOD("uninitialize"), &XRInterface::uninitialize);
|
||||||
|
ClassDB::bind_method(D_METHOD("get_system_info"), &XRInterface::get_system_info);
|
||||||
|
|
||||||
ClassDB::bind_method(D_METHOD("get_tracking_status"), &XRInterface::get_tracking_status);
|
ClassDB::bind_method(D_METHOD("get_tracking_status"), &XRInterface::get_tracking_status);
|
||||||
|
|
||||||
|
|
|
@ -100,6 +100,7 @@ public:
|
||||||
virtual bool is_initialized() const = 0; /* returns true if we've initialized this interface */
|
virtual bool is_initialized() const = 0; /* returns true if we've initialized this interface */
|
||||||
virtual bool initialize() = 0; /* initialize this interface, if this has an HMD it becomes the primary interface */
|
virtual bool initialize() = 0; /* initialize this interface, if this has an HMD it becomes the primary interface */
|
||||||
virtual void uninitialize() = 0; /* deinitialize this interface */
|
virtual void uninitialize() = 0; /* deinitialize this interface */
|
||||||
|
virtual Dictionary get_system_info() = 0; /* return a dictionary with info about our system */
|
||||||
|
|
||||||
/** input and output **/
|
/** input and output **/
|
||||||
|
|
||||||
|
|
|
@ -39,6 +39,7 @@ void XRInterfaceExtension::_bind_methods() {
|
||||||
GDVIRTUAL_BIND(_is_initialized);
|
GDVIRTUAL_BIND(_is_initialized);
|
||||||
GDVIRTUAL_BIND(_initialize);
|
GDVIRTUAL_BIND(_initialize);
|
||||||
GDVIRTUAL_BIND(_uninitialize);
|
GDVIRTUAL_BIND(_uninitialize);
|
||||||
|
GDVIRTUAL_BIND(_get_system_info);
|
||||||
|
|
||||||
GDVIRTUAL_BIND(_supports_play_area_mode, "mode");
|
GDVIRTUAL_BIND(_supports_play_area_mode, "mode");
|
||||||
GDVIRTUAL_BIND(_get_play_area_mode);
|
GDVIRTUAL_BIND(_get_play_area_mode);
|
||||||
|
@ -119,6 +120,12 @@ void XRInterfaceExtension::uninitialize() {
|
||||||
GDVIRTUAL_CALL(_uninitialize);
|
GDVIRTUAL_CALL(_uninitialize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Dictionary XRInterfaceExtension::get_system_info() {
|
||||||
|
Dictionary dict;
|
||||||
|
GDVIRTUAL_CALL(_get_system_info, dict);
|
||||||
|
return dict;
|
||||||
|
}
|
||||||
|
|
||||||
PackedStringArray XRInterfaceExtension::get_suggested_tracker_names() const {
|
PackedStringArray XRInterfaceExtension::get_suggested_tracker_names() const {
|
||||||
PackedStringArray arr;
|
PackedStringArray arr;
|
||||||
|
|
||||||
|
|
|
@ -57,10 +57,12 @@ public:
|
||||||
virtual bool is_initialized() const override;
|
virtual bool is_initialized() const override;
|
||||||
virtual bool initialize() override;
|
virtual bool initialize() override;
|
||||||
virtual void uninitialize() override;
|
virtual void uninitialize() override;
|
||||||
|
virtual Dictionary get_system_info() override;
|
||||||
|
|
||||||
GDVIRTUAL0RC(bool, _is_initialized);
|
GDVIRTUAL0RC(bool, _is_initialized);
|
||||||
GDVIRTUAL0R(bool, _initialize);
|
GDVIRTUAL0R(bool, _initialize);
|
||||||
GDVIRTUAL0(_uninitialize);
|
GDVIRTUAL0(_uninitialize);
|
||||||
|
GDVIRTUAL0RC(Dictionary, _get_system_info);
|
||||||
|
|
||||||
/** input and output **/
|
/** input and output **/
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue