diff options
| -rw-r--r-- | core/math/math_2d.cpp | 5 | ||||
| -rw-r--r-- | core/math/math_2d.h | 1 | ||||
| -rw-r--r-- | core/os/os.h | 3 | ||||
| -rw-r--r-- | core/variant_call.cpp | 4 | ||||
| -rw-r--r-- | doc/classes/Vector2.xml | 9 | ||||
| -rw-r--r-- | platform/javascript/os_javascript.cpp | 29 | ||||
| -rw-r--r-- | scene/2d/sprite.cpp | 30 | ||||
| -rw-r--r-- | scene/gui/grid_container.cpp | 4 | ||||
| -rw-r--r-- | servers/physics_2d/joints_2d_sw.cpp | 9 | 
9 files changed, 73 insertions, 21 deletions
| diff --git a/core/math/math_2d.cpp b/core/math/math_2d.cpp index d2e4101999..3767d298a1 100644 --- a/core/math/math_2d.cpp +++ b/core/math/math_2d.cpp @@ -98,11 +98,6 @@ real_t Vector2::cross(const Vector2 &p_other) const {  	return x * p_other.y - y * p_other.x;  } -Vector2 Vector2::cross(real_t p_other) const { - -	return Vector2(p_other * y, -p_other * x); -} -  Vector2 Vector2::floor() const {  	return Vector2(Math::floor(x), Math::floor(y)); diff --git a/core/math/math_2d.h b/core/math/math_2d.h index 8928349a44..02d921b67e 100644 --- a/core/math/math_2d.h +++ b/core/math/math_2d.h @@ -104,7 +104,6 @@ struct Vector2 {  	real_t dot(const Vector2 &p_other) const;  	real_t cross(const Vector2 &p_other) const; -	Vector2 cross(real_t p_other) const;  	Vector2 project(const Vector2 &p_vec) const;  	Vector2 plane_project(real_t p_d, const Vector2 &p_vec) const; diff --git a/core/os/os.h b/core/os/os.h index f8033c2546..5a2c998782 100644 --- a/core/os/os.h +++ b/core/os/os.h @@ -46,7 +46,8 @@  enum VideoDriver {  	VIDEO_DRIVER_GLES3, -	VIDEO_DRIVER_GLES2 +	VIDEO_DRIVER_GLES2, +	VIDEO_DRIVER_MAX,  };  class OS { diff --git a/core/variant_call.cpp b/core/variant_call.cpp index d1d45f0e7c..cda7dccf0c 100644 --- a/core/variant_call.cpp +++ b/core/variant_call.cpp @@ -347,7 +347,7 @@ struct _VariantCall {  	VCALL_LOCALMEM1R(Vector2, bounce);  	VCALL_LOCALMEM1R(Vector2, reflect);  	VCALL_LOCALMEM0R(Vector2, angle); -	//VCALL_LOCALMEM1R(Vector2,cross); +	VCALL_LOCALMEM1R(Vector2, cross);  	VCALL_LOCALMEM0R(Vector2, abs);  	VCALL_LOCALMEM1R(Vector2, clamped); @@ -1517,7 +1517,7 @@ void register_variant_methods() {  	ADDFUNC1R(VECTOR2, VECTOR2, Vector2, slide, VECTOR2, "n", varray());  	ADDFUNC1R(VECTOR2, VECTOR2, Vector2, bounce, VECTOR2, "n", varray());  	ADDFUNC1R(VECTOR2, VECTOR2, Vector2, reflect, VECTOR2, "n", varray()); -	//ADDFUNC1R(VECTOR2,REAL,Vector2,cross,VECTOR2,"with",varray()); +	ADDFUNC1R(VECTOR2, REAL, Vector2, cross, VECTOR2, "with", varray());  	ADDFUNC0R(VECTOR2, VECTOR2, Vector2, abs, varray());  	ADDFUNC1R(VECTOR2, VECTOR2, Vector2, clamped, REAL, "length", varray()); diff --git a/doc/classes/Vector2.xml b/doc/classes/Vector2.xml index 9df2eb143b..b293ec3368 100644 --- a/doc/classes/Vector2.xml +++ b/doc/classes/Vector2.xml @@ -81,6 +81,15 @@  				Returns the vector with a maximum length.  			</description>  		</method> +		<method name="cross"> +			<return type="float"> +			</return> +			<argument index="0" name="b" type="Vector2"> +			</argument> +			<description> +				Returns the 2-dimensional analog of the cross product with [code]b[/code]. +			</description> +		</method>  		<method name="cubic_interpolate">  			<return type="Vector2">  			</return> diff --git a/platform/javascript/os_javascript.cpp b/platform/javascript/os_javascript.cpp index 5ae232d8f3..ace0bdad60 100644 --- a/platform/javascript/os_javascript.cpp +++ b/platform/javascript/os_javascript.cpp @@ -33,6 +33,7 @@  #include "core/engine.h"  #include "core/io/file_access_buffered_fa.h"  #include "dom_keys.h" +#include "drivers/gles2/rasterizer_gles2.h"  #include "drivers/gles3/rasterizer_gles3.h"  #include "drivers/unix/dir_access_unix.h"  #include "drivers/unix/file_access_unix.h" @@ -57,12 +58,19 @@ static void dom2godot_mod(T emscripten_event_ptr, Ref<InputEventWithModifiers> g  int OS_JavaScript::get_video_driver_count() const { -	return 1; +	return VIDEO_DRIVER_MAX;  }  const char *OS_JavaScript::get_video_driver_name(int p_driver) const { -	return "GLES3"; +	switch (p_driver) { +		case VIDEO_DRIVER_GLES3: +			return "GLES3"; +		case VIDEO_DRIVER_GLES2: +			return "GLES2"; +	} +	ERR_EXPLAIN("Invalid video driver index " + itos(p_driver)); +	ERR_FAIL_V(NULL);  }  int OS_JavaScript::get_audio_driver_count() const { @@ -422,7 +430,19 @@ Error OS_JavaScript::initialize(const VideoMode &p_desired, int p_video_driver,  	emscripten_webgl_init_context_attributes(&attributes);  	attributes.alpha = false;  	attributes.antialias = false; -	attributes.majorVersion = 2; +	ERR_FAIL_INDEX_V(p_video_driver, VIDEO_DRIVER_MAX, ERR_INVALID_PARAMETER); +	switch (p_video_driver) { +		case VIDEO_DRIVER_GLES3: +			attributes.majorVersion = 2; +			RasterizerGLES3::register_config(); +			RasterizerGLES3::make_current(); +			break; +		case VIDEO_DRIVER_GLES2: +			attributes.majorVersion = 1; +			RasterizerGLES2::register_config(); +			RasterizerGLES2::make_current(); +			break; +	}  	EMSCRIPTEN_WEBGL_CONTEXT_HANDLE ctx = emscripten_webgl_create_context(NULL, &attributes);  	ERR_FAIL_COND_V(emscripten_webgl_make_context_current(ctx) != EMSCRIPTEN_RESULT_SUCCESS, ERR_UNAVAILABLE); @@ -449,9 +469,6 @@ Error OS_JavaScript::initialize(const VideoMode &p_desired, int p_video_driver,  	AudioDriverManager::initialize(p_audio_driver); -	RasterizerGLES3::register_config(); -	RasterizerGLES3::make_current(); -  	print_line("Init VS");  	visual_server = memnew(VisualServerRaster()); diff --git a/scene/2d/sprite.cpp b/scene/2d/sprite.cpp index 0dd02a982c..e3fa1fdcb7 100644 --- a/scene/2d/sprite.cpp +++ b/scene/2d/sprite.cpp @@ -281,13 +281,39 @@ bool Sprite::_edit_is_selected_on_click(const Point2 &p_point, double p_toleranc  	Rect2 src_rect, dst_rect;  	bool filter_clip;  	_get_rects(src_rect, dst_rect, filter_clip); +	dst_rect.size = dst_rect.size.abs();  	if (!dst_rect.has_point(p_point))  		return false; -	Vector2 q = ((p_point - dst_rect.position) / dst_rect.size) * src_rect.size + src_rect.position; +	Vector2 q = (p_point - dst_rect.position) / dst_rect.size; +	if (hflip) +		q.x = 1.0f - q.x; +	if (vflip) +		q.y = 1.0f - q.y; +	q = q * src_rect.size + src_rect.position; + +	Ref<Image> image; +	Ref<AtlasTexture> atlasTexture = texture; +	if (atlasTexture.is_null()) { +		image = texture->get_data(); +	} else { +		ERR_FAIL_COND_V(atlasTexture->get_atlas().is_null(), false); + +		image = atlasTexture->get_atlas()->get_data(); + +		Rect2 region = atlasTexture->get_region(); +		Rect2 margin = atlasTexture->get_margin(); + +		q -= margin.position; + +		if ((q.x > region.size.width) || (q.y > region.size.height)) { +			return false; +		} + +		q += region.position; +	} -	Ref<Image> image = texture->get_data();  	ERR_FAIL_COND_V(image.is_null(), false);  	image->lock(); diff --git a/scene/gui/grid_container.cpp b/scene/gui/grid_container.cpp index c2b8a7dfab..9aac5137bc 100644 --- a/scene/gui/grid_container.cpp +++ b/scene/gui/grid_container.cpp @@ -130,8 +130,8 @@ void GridContainer::_notification(int p_what) {  			}  			// Finally, fit the nodes -			int col_expand = remaining_space.width / col_expanded.size(); -			int row_expand = remaining_space.height / row_expanded.size(); +			int col_expand = col_expanded.size() > 0 ? remaining_space.width / col_expanded.size() : 0; +			int row_expand = row_expanded.size() > 0 ? remaining_space.height / row_expanded.size() : 0;  			int col_ofs = 0;  			int row_ofs = 0; diff --git a/servers/physics_2d/joints_2d_sw.cpp b/servers/physics_2d/joints_2d_sw.cpp index 7fba8acebd..d49c1b8376 100644 --- a/servers/physics_2d/joints_2d_sw.cpp +++ b/servers/physics_2d/joints_2d_sw.cpp @@ -146,14 +146,19 @@ bool PinJoint2DSW::setup(real_t p_step) {  	return true;  } +inline Vector2 custom_cross(const Vector2 &p_vec, real_t p_other) { + +	return Vector2(p_other * p_vec.y, -p_other * p_vec.x); +} +  void PinJoint2DSW::solve(real_t p_step) {  	// compute relative velocity -	Vector2 vA = A->get_linear_velocity() - rA.cross(A->get_angular_velocity()); +	Vector2 vA = A->get_linear_velocity() - custom_cross(rA, A->get_angular_velocity());  	Vector2 rel_vel;  	if (B) -		rel_vel = B->get_linear_velocity() - rB.cross(B->get_angular_velocity()) - vA; +		rel_vel = B->get_linear_velocity() - custom_cross(rB, B->get_angular_velocity()) - vA;  	else  		rel_vel = -vA; |