diff options
Diffstat (limited to 'servers/xr/xr_interface.cpp')
| -rw-r--r-- | servers/xr/xr_interface.cpp | 67 | 
1 files changed, 60 insertions, 7 deletions
| diff --git a/servers/xr/xr_interface.cpp b/servers/xr/xr_interface.cpp index bf54158905..ca11df439c 100644 --- a/servers/xr/xr_interface.cpp +++ b/servers/xr/xr_interface.cpp @@ -32,6 +32,8 @@  // #include "servers/rendering/renderer_compositor.h"  void XRInterface::_bind_methods() { +	ADD_SIGNAL(MethodInfo("play_area_changed", PropertyInfo(Variant::INT, "mode"))); +  	ClassDB::bind_method(D_METHOD("get_name"), &XRInterface::get_name);  	ClassDB::bind_method(D_METHOD("get_capabilities"), &XRInterface::get_capabilities); @@ -47,12 +49,21 @@ void XRInterface::_bind_methods() {  	ClassDB::bind_method(D_METHOD("get_render_target_size"), &XRInterface::get_render_target_size);  	ClassDB::bind_method(D_METHOD("get_view_count"), &XRInterface::get_view_count); +	ClassDB::bind_method(D_METHOD("trigger_haptic_pulse", "action_name", "tracker_name", "frequency", "amplitude", "duration_sec", "delay_sec"), &XRInterface::trigger_haptic_pulse); +  	ADD_GROUP("Interface", "interface_");  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "interface_is_primary"), "set_primary", "is_primary"); -	// we don't have any properties specific to VR yet.... +	// methods and properties specific to VR... +	ClassDB::bind_method(D_METHOD("supports_play_area_mode", "mode"), &XRInterface::supports_play_area_mode); +	ClassDB::bind_method(D_METHOD("get_play_area_mode"), &XRInterface::get_play_area_mode); +	ClassDB::bind_method(D_METHOD("set_play_area_mode", "mode"), &XRInterface::set_play_area_mode); +	ClassDB::bind_method(D_METHOD("get_play_area"), &XRInterface::get_play_area); + +	ADD_GROUP("XR", "xr_"); +	ADD_PROPERTY(PropertyInfo(Variant::INT, "xr_play_area_mode", PROPERTY_HINT_ENUM, "Unknown,3DOF,Sitting,Roomscale,Stage"), "set_play_area_mode", "get_play_area_mode"); -	// but we do have properties specific to AR.... +	// methods and properties specific to AR....  	ClassDB::bind_method(D_METHOD("get_anchor_detection_is_enabled"), &XRInterface::get_anchor_detection_is_enabled);  	ClassDB::bind_method(D_METHOD("set_anchor_detection_is_enabled", "enable"), &XRInterface::set_anchor_detection_is_enabled);  	ClassDB::bind_method(D_METHOD("get_camera_feed_id"), &XRInterface::get_camera_feed_id); @@ -63,19 +74,23 @@ void XRInterface::_bind_methods() {  	BIND_ENUM_CONSTANT(XR_NONE);  	BIND_ENUM_CONSTANT(XR_MONO);  	BIND_ENUM_CONSTANT(XR_STEREO); +	BIND_ENUM_CONSTANT(XR_QUAD); +	BIND_ENUM_CONSTANT(XR_VR);  	BIND_ENUM_CONSTANT(XR_AR);  	BIND_ENUM_CONSTANT(XR_EXTERNAL); -	BIND_ENUM_CONSTANT(EYE_MONO); -	BIND_ENUM_CONSTANT(EYE_LEFT); -	BIND_ENUM_CONSTANT(EYE_RIGHT); -  	BIND_ENUM_CONSTANT(XR_NORMAL_TRACKING);  	BIND_ENUM_CONSTANT(XR_EXCESSIVE_MOTION);  	BIND_ENUM_CONSTANT(XR_INSUFFICIENT_FEATURES);  	BIND_ENUM_CONSTANT(XR_UNKNOWN_TRACKING);  	BIND_ENUM_CONSTANT(XR_NOT_TRACKING); -} + +	BIND_ENUM_CONSTANT(XR_PLAY_AREA_UNKNOWN); +	BIND_ENUM_CONSTANT(XR_PLAY_AREA_3DOF); +	BIND_ENUM_CONSTANT(XR_PLAY_AREA_SITTING); +	BIND_ENUM_CONSTANT(XR_PLAY_AREA_ROOMSCALE); +	BIND_ENUM_CONSTANT(XR_PLAY_AREA_STAGE); +};  bool XRInterface::is_primary() {  	XRServer *xr_server = XRServer::get_singleton(); @@ -101,6 +116,29 @@ XRInterface::XRInterface() {}  XRInterface::~XRInterface() {} +// query if this interface supports this play area mode +bool XRInterface::supports_play_area_mode(XRInterface::PlayAreaMode p_mode) { +	return p_mode == XR_PLAY_AREA_UNKNOWN; +} + +// get the current play area mode +XRInterface::PlayAreaMode XRInterface::get_play_area_mode() const { +	return XR_PLAY_AREA_UNKNOWN; +} + +// change the play area mode, note that this should return false if the mode is not available +bool XRInterface::set_play_area_mode(XRInterface::PlayAreaMode p_mode) { +	return p_mode == XR_PLAY_AREA_UNKNOWN; +} + +// if available, returns an array of vectors denoting the play area the player can move around in +PackedVector3Array XRInterface::get_play_area() const { +	// Return an empty array by default. +	// Note implementation is responsible for applying our reference frame and world scale to the raw data. +	// `play_area_changed` should be emitted if play area data is available and either the reference frame or world scale changes. +	return PackedVector3Array(); +}; +  /** these will only be implemented on AR interfaces, so we want dummies for VR **/  bool XRInterface::get_anchor_detection_is_enabled() const {  	return false; @@ -114,9 +152,24 @@ int XRInterface::get_camera_feed_id() {  }  /** these are optional, so we want dummies **/ +PackedStringArray XRInterface::get_suggested_tracker_names() const { +	PackedStringArray arr; + +	return arr; +} + +PackedStringArray XRInterface::get_suggested_pose_names(const StringName &p_tracker_name) const { +	PackedStringArray arr; + +	return arr; +} +  XRInterface::TrackingStatus XRInterface::get_tracking_status() const {  	return XR_UNKNOWN_TRACKING;  }  void XRInterface::notification(int p_what) {  } + +void XRInterface::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) { +} |