diff options
| -rw-r--r-- | core/math/vector2.cpp | 7 | ||||
| -rw-r--r-- | core/math/vector2.h | 2 | ||||
| -rw-r--r-- | core/math/vector3.h | 6 | ||||
| -rw-r--r-- | core/variant_call.cpp | 4 | ||||
| -rw-r--r-- | doc/classes/Vector2.xml | 9 | ||||
| -rw-r--r-- | doc/classes/Vector3.xml | 9 | ||||
| -rw-r--r-- | editor/editor_properties.cpp | 2 | ||||
| -rw-r--r-- | editor/script_editor_debugger.cpp | 27 | ||||
| -rw-r--r-- | editor/script_editor_debugger.h | 2 | ||||
| -rw-r--r-- | modules/mobile_vr/mobile_vr_interface.cpp | 105 | ||||
| -rw-r--r-- | modules/mobile_vr/mobile_vr_interface.h | 2 | ||||
| -rw-r--r-- | scene/2d/node_2d.cpp | 2 | ||||
| -rw-r--r-- | scene/2d/polygon_2d.cpp | 4 | ||||
| -rw-r--r-- | scene/gui/popup_menu.cpp | 6 | ||||
| -rw-r--r-- | scene/gui/range.cpp | 4 | ||||
| -rw-r--r-- | scene/main/canvas_layer.cpp | 4 | ||||
| -rw-r--r-- | servers/physics_2d/joints_2d_sw.cpp | 2 | 
17 files changed, 128 insertions, 69 deletions
| diff --git a/core/math/vector2.cpp b/core/math/vector2.cpp index 441e7d8907..75d9b8b311 100644 --- a/core/math/vector2.cpp +++ b/core/math/vector2.cpp @@ -121,11 +121,8 @@ Vector2 Vector2::rotated(real_t p_by) const {  	return v;  } -Vector2 Vector2::project(const Vector2 &p_vec) const { - -	Vector2 v1 = p_vec; -	Vector2 v2 = *this; -	return v2 * (v1.dot(v2) / v2.dot(v2)); +Vector2 Vector2::project(const Vector2 &p_b) const { +	return p_b * (dot(p_b) / p_b.dot(p_b));  }  Vector2 Vector2::snapped(const Vector2 &p_by) const { diff --git a/core/math/vector2.h b/core/math/vector2.h index 7c8882f6e2..fbcdc80b60 100644 --- a/core/math/vector2.h +++ b/core/math/vector2.h @@ -68,7 +68,7 @@ struct Vector2 {  	real_t dot(const Vector2 &p_other) const;  	real_t cross(const Vector2 &p_other) const; -	Vector2 project(const Vector2 &p_vec) const; +	Vector2 project(const Vector2 &p_b) const;  	Vector2 plane_project(real_t p_d, const Vector2 &p_vec) const; diff --git a/core/math/vector3.h b/core/math/vector3.h index 433adf09ee..a719e3965d 100644 --- a/core/math/vector3.h +++ b/core/math/vector3.h @@ -109,6 +109,8 @@ struct Vector3 {  	_FORCE_INLINE_ real_t distance_to(const Vector3 &p_b) const;  	_FORCE_INLINE_ real_t distance_squared_to(const Vector3 &p_b) const; +	_FORCE_INLINE_ Vector3 project(const Vector3 &p_b) const; +  	_FORCE_INLINE_ real_t angle_to(const Vector3 &p_b) const;  	_FORCE_INLINE_ Vector3 slide(const Vector3 &p_normal) const; @@ -238,6 +240,10 @@ real_t Vector3::distance_squared_to(const Vector3 &p_b) const {  	return (p_b - *this).length_squared();  } +Vector3 Vector3::project(const Vector3 &p_b) const { +	return p_b * (dot(p_b) / p_b.dot(p_b)); +} +  real_t Vector3::angle_to(const Vector3 &p_b) const {  	return Math::atan2(cross(p_b).length(), dot(p_b)); diff --git a/core/variant_call.cpp b/core/variant_call.cpp index 80cb869db2..ea51419233 100644 --- a/core/variant_call.cpp +++ b/core/variant_call.cpp @@ -339,6 +339,7 @@ struct _VariantCall {  	VCALL_LOCALMEM0R(Vector2, is_normalized);  	VCALL_LOCALMEM1R(Vector2, distance_to);  	VCALL_LOCALMEM1R(Vector2, distance_squared_to); +	VCALL_LOCALMEM1R(Vector2, project);  	VCALL_LOCALMEM1R(Vector2, angle_to);  	VCALL_LOCALMEM1R(Vector2, angle_to_point);  	VCALL_LOCALMEM2R(Vector2, linear_interpolate); @@ -395,6 +396,7 @@ struct _VariantCall {  	VCALL_LOCALMEM0R(Vector3, round);  	VCALL_LOCALMEM1R(Vector3, distance_to);  	VCALL_LOCALMEM1R(Vector3, distance_squared_to); +	VCALL_LOCALMEM1R(Vector3, project);  	VCALL_LOCALMEM1R(Vector3, angle_to);  	VCALL_LOCALMEM1R(Vector3, slide);  	VCALL_LOCALMEM1R(Vector3, bounce); @@ -1551,6 +1553,7 @@ void register_variant_methods() {  	ADDFUNC0R(VECTOR2, BOOL, Vector2, is_normalized, varray());  	ADDFUNC1R(VECTOR2, REAL, Vector2, distance_to, VECTOR2, "to", varray());  	ADDFUNC1R(VECTOR2, REAL, Vector2, distance_squared_to, VECTOR2, "to", varray()); +	ADDFUNC1R(VECTOR2, VECTOR2, Vector2, project, VECTOR2, "b", varray());  	ADDFUNC1R(VECTOR2, REAL, Vector2, angle_to, VECTOR2, "to", varray());  	ADDFUNC1R(VECTOR2, REAL, Vector2, angle_to_point, VECTOR2, "to", varray());  	ADDFUNC2R(VECTOR2, VECTOR2, Vector2, linear_interpolate, VECTOR2, "b", REAL, "t", varray()); @@ -1606,6 +1609,7 @@ void register_variant_methods() {  	ADDFUNC0R(VECTOR3, VECTOR3, Vector3, round, varray());  	ADDFUNC1R(VECTOR3, REAL, Vector3, distance_to, VECTOR3, "b", varray());  	ADDFUNC1R(VECTOR3, REAL, Vector3, distance_squared_to, VECTOR3, "b", varray()); +	ADDFUNC1R(VECTOR3, VECTOR3, Vector3, project, VECTOR3, "b", varray());  	ADDFUNC1R(VECTOR3, REAL, Vector3, angle_to, VECTOR3, "to", varray());  	ADDFUNC1R(VECTOR3, VECTOR3, Vector3, slide, VECTOR3, "n", varray());  	ADDFUNC1R(VECTOR3, VECTOR3, Vector3, bounce, VECTOR3, "n", varray()); diff --git a/doc/classes/Vector2.xml b/doc/classes/Vector2.xml index 6ffeddf5c1..9b18962a6f 100644 --- a/doc/classes/Vector2.xml +++ b/doc/classes/Vector2.xml @@ -130,6 +130,15 @@  				Returns the distance to vector [code]b[/code].  			</description>  		</method> +		<method name="project"> +			<return type="Vector2"> +			</return> +			<argument index="0" name="b" type="Vector2"> +			</argument> +			<description> +				Returns the vector projected onto the vector [code]b[/code]. +			</description> +		</method>  		<method name="dot">  			<return type="float">  			</return> diff --git a/doc/classes/Vector3.xml b/doc/classes/Vector3.xml index 62a480166a..22384c5012 100644 --- a/doc/classes/Vector3.xml +++ b/doc/classes/Vector3.xml @@ -99,6 +99,15 @@  				Returns the distance to [code]b[/code].  			</description>  		</method> +		<method name="project_onto"> +			<return type="Vector3"> +			</return> +			<argument index="0" name="b" type="Vector3"> +			</argument> +			<description> +				Returns the vector projected onto the vector [code]b[/code]. +			</description> +		</method>  		<method name="dot">  			<return type="float">  			</return> diff --git a/editor/editor_properties.cpp b/editor/editor_properties.cpp index 59798bfab3..0cbd5f0bff 100644 --- a/editor/editor_properties.cpp +++ b/editor/editor_properties.cpp @@ -2052,7 +2052,7 @@ void EditorPropertyResource::_menu_option(int p_which) {  			ERR_BREAK(!resp);  			if (get_edited_object() && base_type != String() && base_type == "Script") {  				//make visual script the right type -				res->call("set_instance_base_type", get_edited_object()->get_class()); +				resp->call("set_instance_base_type", get_edited_object()->get_class());  			}  			res = Ref<Resource>(resp); diff --git a/editor/script_editor_debugger.cpp b/editor/script_editor_debugger.cpp index bd661ade53..97147535c0 100644 --- a/editor/script_editor_debugger.cpp +++ b/editor/script_editor_debugger.cpp @@ -734,7 +734,10 @@ void ScriptEditorDebugger::_parse_message(const String &p_msg, const Array &p_da  		error_list->set_item_metadata(error_list->get_item_count() - 1, stack); -		error_count++; +		if (warning) +			warning_count++; +		else +			error_count++;  	} else if (p_msg == "profile_sig") {  		//cache a signature @@ -1011,20 +1014,26 @@ void ScriptEditorDebugger::_notification(int p_what) {  				}  			} -			if (error_count != last_error_count) { +			if (error_count != last_error_count || warning_count != last_warning_count) { -				if (error_count == 0) { +				if (error_count == 0 && warning_count == 0) {  					error_split->set_name(TTR("Errors"));  					debugger_button->set_text(TTR("Debugger"));  					debugger_button->set_icon(Ref<Texture>());  					tabs->set_tab_icon(error_split->get_index(), Ref<Texture>());  				} else { -					error_split->set_name(TTR("Errors") + " (" + itos(error_count) + ")"); -					debugger_button->set_text(TTR("Debugger") + " (" + itos(error_count) + ")"); -					debugger_button->set_icon(get_icon("Error", "EditorIcons")); -					tabs->set_tab_icon(error_split->get_index(), get_icon("Error", "EditorIcons")); +					error_split->set_name(TTR("Errors") + " (" + itos(error_count + warning_count) + ")"); +					debugger_button->set_text(TTR("Debugger") + " (" + itos(error_count + warning_count) + ")"); +					if (error_count == 0) { +						debugger_button->set_icon(get_icon("Warning", "EditorIcons")); +						tabs->set_tab_icon(error_split->get_index(), get_icon("Warning", "EditorIcons")); +					} else { +						debugger_button->set_icon(get_icon("Error", "EditorIcons")); +						tabs->set_tab_icon(error_split->get_index(), get_icon("Error", "EditorIcons")); +					}  				}  				last_error_count = error_count; +				last_warning_count = warning_count;  			}  			if (connection.is_null()) { @@ -1054,6 +1063,7 @@ void ScriptEditorDebugger::_notification(int p_what) {  					error_list->clear();  					error_stack->clear();  					error_count = 0; +					warning_count = 0;  					profiler_signature.clear();  					//live_edit_root->set_text("/root"); @@ -1750,6 +1760,7 @@ void ScriptEditorDebugger::_clear_errors_list() {  	error_list->clear();  	error_count = 0; +	warning_count = 0;  	_notification(NOTIFICATION_PROCESS);  } @@ -2162,9 +2173,11 @@ ScriptEditorDebugger::ScriptEditorDebugger(EditorNode *p_editor) {  	live_debug = false;  	last_path_id = false;  	error_count = 0; +	warning_count = 0;  	hide_on_stop = true;  	enable_external_editor = false;  	last_error_count = 0; +	last_warning_count = 0;  	EditorNode::get_singleton()->get_pause_button()->connect("pressed", this, "_paused");  } diff --git a/editor/script_editor_debugger.h b/editor/script_editor_debugger.h index f7fe348b65..ce705aa35b 100644 --- a/editor/script_editor_debugger.h +++ b/editor/script_editor_debugger.h @@ -96,7 +96,9 @@ class ScriptEditorDebugger : public Control {  	EditorFileDialog *file_dialog;  	int error_count; +	int warning_count;  	int last_error_count; +	int last_warning_count;  	bool hide_on_stop;  	bool enable_external_editor; diff --git a/modules/mobile_vr/mobile_vr_interface.cpp b/modules/mobile_vr/mobile_vr_interface.cpp index 2ec00aa72d..e2c630565f 100644 --- a/modules/mobile_vr/mobile_vr_interface.cpp +++ b/modules/mobile_vr/mobile_vr_interface.cpp @@ -297,6 +297,47 @@ bool MobileVRInterface::initialize() {  		mag_current_min = Vector3(0, 0, 0);  		mag_current_max = Vector3(0, 0, 0); +		// build our shader +		if (lens_shader == NULL) { +			///@TODO need to switch between GLES2 and GLES3 version, Reduz suggested moving this into our drivers and making this a core shader +			// create a shader +			lens_shader = new LensDistortedShaderGLES3(); + +			// create our shader stuff +			lens_shader->init(); + +			glGenBuffers(1, &half_screen_quad); +			glBindBuffer(GL_ARRAY_BUFFER, half_screen_quad); +			{ +				/* clang-format off */ +				const float qv[16] = { +					0, -1, +					-1, -1, +					0, 1, +					-1, 1, +					1, 1, +					1, 1, +					1, -1, +					1, -1, +				}; +				/* clang-format on */ + +				glBufferData(GL_ARRAY_BUFFER, sizeof(float) * 16, qv, GL_STATIC_DRAW); +			} + +			glBindBuffer(GL_ARRAY_BUFFER, 0); //unbind + +			glGenVertexArrays(1, &half_screen_array); +			glBindVertexArray(half_screen_array); +			glBindBuffer(GL_ARRAY_BUFFER, half_screen_quad); +			glVertexAttribPointer(VS::ARRAY_VERTEX, 2, GL_FLOAT, GL_FALSE, sizeof(float) * 4, 0); +			glEnableVertexAttribArray(0); +			glVertexAttribPointer(VS::ARRAY_TEX_UV, 2, GL_FLOAT, GL_FALSE, sizeof(float) * 4, ((uint8_t *)NULL) + 8); +			glEnableVertexAttribArray(4); +			glBindVertexArray(0); +			glBindBuffer(GL_ARRAY_BUFFER, 0); //unbind +		} +  		// reset our orientation  		orientation = Basis(); @@ -304,7 +345,7 @@ bool MobileVRInterface::initialize() {  		arvr_server->set_primary_interface(this);  		last_ticks = OS::get_singleton()->get_ticks_usec(); -		; +  		initialized = true;  	}; @@ -319,6 +360,15 @@ void MobileVRInterface::uninitialize() {  			arvr_server->clear_primary_interface_if(this);  		} +		// cleanup our shader and buffers +		if (lens_shader != NULL) { +			glDeleteVertexArrays(1, &half_screen_array); +			glDeleteBuffers(1, &half_screen_quad); + +			delete lens_shader; +			lens_shader = NULL; +		} +  		initialized = false;  	};  }; @@ -394,6 +444,9 @@ void MobileVRInterface::commit_for_eye(ARVRInterface::Eyes p_eye, RID p_render_t  	// We must have a valid render target  	ERR_FAIL_COND(!p_render_target.is_valid()); +	// We must have an initialised shader +	ERR_FAIL_COND(lens_shader != NULL); +  	// Because we are rendering to our device we must use our main viewport!  	ERR_FAIL_COND(p_screen_rect == Rect2()); @@ -420,13 +473,13 @@ void MobileVRInterface::commit_for_eye(ARVRInterface::Eyes p_eye, RID p_render_t  	glActiveTexture(GL_TEXTURE0);  	glBindTexture(GL_TEXTURE_2D, texid); -	lens_shader.bind(); -	lens_shader.set_uniform(LensDistortedShaderGLES3::OFFSET_X, offset_x); -	lens_shader.set_uniform(LensDistortedShaderGLES3::K1, k1); -	lens_shader.set_uniform(LensDistortedShaderGLES3::K2, k2); -	lens_shader.set_uniform(LensDistortedShaderGLES3::EYE_CENTER, eye_center); -	lens_shader.set_uniform(LensDistortedShaderGLES3::UPSCALE, oversample); -	lens_shader.set_uniform(LensDistortedShaderGLES3::ASPECT_RATIO, aspect_ratio); +	lens_shader->bind(); +	lens_shader->set_uniform(LensDistortedShaderGLES3::OFFSET_X, offset_x); +	lens_shader->set_uniform(LensDistortedShaderGLES3::K1, k1); +	lens_shader->set_uniform(LensDistortedShaderGLES3::K2, k2); +	lens_shader->set_uniform(LensDistortedShaderGLES3::EYE_CENTER, eye_center); +	lens_shader->set_uniform(LensDistortedShaderGLES3::UPSCALE, oversample); +	lens_shader->set_uniform(LensDistortedShaderGLES3::ASPECT_RATIO, aspect_ratio);  	glBindVertexArray(half_screen_array);  	glDrawArrays(GL_TRIANGLE_FAN, 0, 4); @@ -454,41 +507,7 @@ MobileVRInterface::MobileVRInterface() {  	k2 = 0.215;  	last_ticks = 0; -	// create our shader stuff -	lens_shader.init(); - -	{ -		glGenBuffers(1, &half_screen_quad); -		glBindBuffer(GL_ARRAY_BUFFER, half_screen_quad); -		{ -			/* clang-format off */ -			const float qv[16] = { -				0, -1, -				-1, -1, -				0, 1, -				-1, 1, -				1, 1, -				1, 1, -				1, -1, -				1, -1, -			}; -			/* clang-format on */ - -			glBufferData(GL_ARRAY_BUFFER, sizeof(float) * 16, qv, GL_STATIC_DRAW); -		} - -		glBindBuffer(GL_ARRAY_BUFFER, 0); //unbind - -		glGenVertexArrays(1, &half_screen_array); -		glBindVertexArray(half_screen_array); -		glBindBuffer(GL_ARRAY_BUFFER, half_screen_quad); -		glVertexAttribPointer(VS::ARRAY_VERTEX, 2, GL_FLOAT, GL_FALSE, sizeof(float) * 4, 0); -		glEnableVertexAttribArray(0); -		glVertexAttribPointer(VS::ARRAY_TEX_UV, 2, GL_FLOAT, GL_FALSE, sizeof(float) * 4, ((uint8_t *)NULL) + 8); -		glEnableVertexAttribArray(4); -		glBindVertexArray(0); -		glBindBuffer(GL_ARRAY_BUFFER, 0); //unbind -	} +	lens_shader = NULL;  };  MobileVRInterface::~MobileVRInterface() { diff --git a/modules/mobile_vr/mobile_vr_interface.h b/modules/mobile_vr/mobile_vr_interface.h index 7b2344f1fe..cee0cca90e 100644 --- a/modules/mobile_vr/mobile_vr_interface.h +++ b/modules/mobile_vr/mobile_vr_interface.h @@ -58,7 +58,7 @@ private:  	float eye_height;  	uint64_t last_ticks; -	LensDistortedShaderGLES3 lens_shader; +	LensDistortedShaderGLES3 *lens_shader;  	GLuint half_screen_quad;  	GLuint half_screen_array; diff --git a/scene/2d/node_2d.cpp b/scene/2d/node_2d.cpp index 7252602a93..7de72dc41d 100644 --- a/scene/2d/node_2d.cpp +++ b/scene/2d/node_2d.cpp @@ -443,7 +443,7 @@ void Node2D::_bind_methods() {  	ADD_GROUP("Transform", "");  	ADD_PROPERTYNZ(PropertyInfo(Variant::VECTOR2, "position"), "set_position", "get_position");  	ADD_PROPERTYNZ(PropertyInfo(Variant::REAL, "rotation", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR), "set_rotation", "get_rotation"); -	ADD_PROPERTYNZ(PropertyInfo(Variant::REAL, "rotation_degrees", PROPERTY_HINT_RANGE, "-1440,1440,0.1", PROPERTY_USAGE_EDITOR), "set_rotation_degrees", "get_rotation_degrees"); +	ADD_PROPERTYNZ(PropertyInfo(Variant::REAL, "rotation_degrees", PROPERTY_HINT_RANGE, "-1080,1080,0.1,or_lesser,or_greater", PROPERTY_USAGE_EDITOR), "set_rotation_degrees", "get_rotation_degrees");  	ADD_PROPERTYNO(PropertyInfo(Variant::VECTOR2, "scale"), "set_scale", "get_scale");  	ADD_PROPERTY(PropertyInfo(Variant::TRANSFORM2D, "transform", PROPERTY_HINT_NONE, "", 0), "set_transform", "get_transform"); diff --git a/scene/2d/polygon_2d.cpp b/scene/2d/polygon_2d.cpp index c9e5408f06..34f4ccc03e 100644 --- a/scene/2d/polygon_2d.cpp +++ b/scene/2d/polygon_2d.cpp @@ -29,8 +29,10 @@  /*************************************************************************/  #include "polygon_2d.h" +  #include "core/math/geometry.h"  #include "skeleton_2d.h" +  Dictionary Polygon2D::_edit_get_state() const {  	Dictionary state = Node2D::_edit_get_state();  	state["offset"] = offset; @@ -646,7 +648,7 @@ void Polygon2D::_bind_methods() {  	ADD_GROUP("Texture", "texture_");  	ADD_PROPERTY(PropertyInfo(Variant::VECTOR2, "texture_offset"), "set_texture_offset", "get_texture_offset");  	ADD_PROPERTY(PropertyInfo(Variant::VECTOR2, "texture_scale"), "set_texture_scale", "get_texture_scale"); -	ADD_PROPERTY(PropertyInfo(Variant::REAL, "texture_rotation_degrees", PROPERTY_HINT_RANGE, "-1440,1440,0.1"), "set_texture_rotation_degrees", "get_texture_rotation_degrees"); +	ADD_PROPERTY(PropertyInfo(Variant::REAL, "texture_rotation_degrees", PROPERTY_HINT_RANGE, "-1080,1080,0.1,or_lesser,or_greater"), "set_texture_rotation_degrees", "get_texture_rotation_degrees");  	ADD_PROPERTY(PropertyInfo(Variant::REAL, "texture_rotation", PROPERTY_HINT_NONE, "", 0), "set_texture_rotation", "get_texture_rotation");  	ADD_GROUP("Skeleton", "");  	ADD_PROPERTY(PropertyInfo(Variant::NODE_PATH, "skeleton", PROPERTY_HINT_NODE_PATH_VALID_TYPES, "Skeleton2D"), "set_skeleton", "get_skeleton"); diff --git a/scene/gui/popup_menu.cpp b/scene/gui/popup_menu.cpp index cdc6b868ec..e81813d7a5 100644 --- a/scene/gui/popup_menu.cpp +++ b/scene/gui/popup_menu.cpp @@ -1071,6 +1071,9 @@ void PopupMenu::activate_item(int p_item) {  		pop = Object::cast_to<PopupMenu>(next);  	} +	emit_signal("id_pressed", id); +	emit_signal("index_pressed", p_item); +  	// Hides popup by default; unless otherwise specified  	// by using set_hide_on_item_selection and set_hide_on_checkable_item_selection @@ -1084,9 +1087,6 @@ void PopupMenu::activate_item(int p_item) {  		return;  	hide(); - -	emit_signal("id_pressed", id); -	emit_signal("index_pressed", p_item);  }  void PopupMenu::remove_item(int p_idx) { diff --git a/scene/gui/range.cpp b/scene/gui/range.cpp index 4062e48640..09d8664240 100644 --- a/scene/gui/range.cpp +++ b/scene/gui/range.cpp @@ -260,8 +260,8 @@ void Range::_bind_methods() {  	ADD_PROPERTY(PropertyInfo(Variant::REAL, "ratio", PROPERTY_HINT_RANGE, "0,1,0.01", 0), "set_as_ratio", "get_as_ratio");  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "exp_edit"), "set_exp_ratio", "is_ratio_exp");  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "rounded"), "set_use_rounded_values", "is_using_rounded_values"); -	ADD_PROPERTY(PropertyInfo(Variant::REAL, "allow_greater"), "set_allow_greater", "is_greater_allowed"); -	ADD_PROPERTY(PropertyInfo(Variant::REAL, "allow_lesser"), "set_allow_lesser", "is_lesser_allowed"); +	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "allow_greater"), "set_allow_greater", "is_greater_allowed"); +	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "allow_lesser"), "set_allow_lesser", "is_lesser_allowed");  }  void Range::set_use_rounded_values(bool p_enable) { diff --git a/scene/main/canvas_layer.cpp b/scene/main/canvas_layer.cpp index 8414210952..a2e890e7a7 100644 --- a/scene/main/canvas_layer.cpp +++ b/scene/main/canvas_layer.cpp @@ -248,12 +248,10 @@ void CanvasLayer::_bind_methods() {  	ClassDB::bind_method(D_METHOD("get_custom_viewport"), &CanvasLayer::get_custom_viewport);  	ClassDB::bind_method(D_METHOD("get_canvas"), &CanvasLayer::get_canvas); -	//ClassDB::bind_method(D_METHOD("get_viewport"),&CanvasLayer::get_viewport);  	ADD_PROPERTY(PropertyInfo(Variant::INT, "layer", PROPERTY_HINT_RANGE, "-128,128,1"), "set_layer", "get_layer"); -	//ADD_PROPERTY( PropertyInfo(Variant::MATRIX32,"transform",PROPERTY_HINT_RANGE),"set_transform","get_transform") ;  	ADD_PROPERTY(PropertyInfo(Variant::VECTOR2, "offset"), "set_offset", "get_offset"); -	ADD_PROPERTY(PropertyInfo(Variant::REAL, "rotation_degrees", PROPERTY_HINT_RANGE, "-1440,1440,0.1", PROPERTY_USAGE_EDITOR), "set_rotation_degrees", "get_rotation_degrees"); +	ADD_PROPERTY(PropertyInfo(Variant::REAL, "rotation_degrees", PROPERTY_HINT_RANGE, "-1080,1080,0.1,or_lesser,or_greater", PROPERTY_USAGE_EDITOR), "set_rotation_degrees", "get_rotation_degrees");  	ADD_PROPERTY(PropertyInfo(Variant::REAL, "rotation", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR), "set_rotation", "get_rotation");  	ADD_PROPERTY(PropertyInfo(Variant::VECTOR2, "scale"), "set_scale", "get_scale");  	ADD_PROPERTY(PropertyInfo(Variant::TRANSFORM2D, "transform"), "set_transform", "get_transform"); diff --git a/servers/physics_2d/joints_2d_sw.cpp b/servers/physics_2d/joints_2d_sw.cpp index d49c1b8376..517dce0043 100644 --- a/servers/physics_2d/joints_2d_sw.cpp +++ b/servers/physics_2d/joints_2d_sw.cpp @@ -321,7 +321,7 @@ void GrooveJoint2DSW::solve(real_t p_step) {  	Vector2 jOld = jn_acc;  	j += jOld; -	jn_acc = (((clamp * j.cross(xf_normal)) > 0) ? j : xf_normal.project(j)).clamped(jn_max); +	jn_acc = (((clamp * j.cross(xf_normal)) > 0) ? j : j.project(xf_normal)).clamped(jn_max);  	j = jn_acc - jOld; |