Skip to content

Commit

Permalink
Renamed Vector2.tangent to perpendicular
Browse files Browse the repository at this point in the history
  • Loading branch information
Chaosus authored and aaronfranke committed Nov 25, 2020
1 parent 32b31a5 commit 6e38279
Show file tree
Hide file tree
Showing 22 changed files with 57 additions and 57 deletions.
2 changes: 1 addition & 1 deletion core/math/rect2.h
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ struct Rect2 {
}

//check inside
Vector2 tg = r.tangent();
Vector2 tg = r.perpendicular();
float s = tg.dot(center) - tg.dot(a);
if (s < 0.0) {
side_plus++;
Expand Down
2 changes: 1 addition & 1 deletion core/math/vector2.h
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,7 @@ struct Vector2 {
}

Vector2 rotated(real_t p_by) const;
Vector2 tangent() const {
Vector2 perpendicular() const {
return Vector2(y, -x);
}

Expand Down
2 changes: 1 addition & 1 deletion core/variant/variant_call.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -992,7 +992,7 @@ static void _register_variant_builtin_methods() {
bind_method(Vector2, cubic_interpolate, sarray("b", "pre_a", "post_b", "t"), varray());
bind_method(Vector2, move_toward, sarray("to", "delta"), varray());
bind_method(Vector2, rotated, sarray("phi"), varray());
bind_method(Vector2, tangent, sarray(), varray());
bind_method(Vector2, perpendicular, sarray(), varray());
bind_method(Vector2, floor, sarray(), varray());
bind_method(Vector2, ceil, sarray(), varray());
bind_method(Vector2, round, sarray(), varray());
Expand Down
14 changes: 7 additions & 7 deletions doc/classes/Vector2.xml
Original file line number Diff line number Diff line change
Expand Up @@ -390,6 +390,13 @@
<description>
</description>
</method>
<method name="perpendicular">
<return type="Vector2">
</return>
<description>
Returns a perpendicular vector rotated 90 degrees counter-clockwise compared to the original, with the same length.
</description>
</method>
<method name="posmod">
<return type="Vector2">
</return>
Expand Down Expand Up @@ -479,13 +486,6 @@
Returns this vector with each component snapped to the nearest multiple of [code]step[/code]. This can also be used to round to an arbitrary number of decimals.
</description>
</method>
<method name="tangent">
<return type="Vector2">
</return>
<description>
Returns a perpendicular vector rotated 90 degrees counter-clockwise compared to the original, with the same length.
</description>
</method>
</methods>
<members>
<member name="x" type="float" setter="" getter="" default="0.0">
Expand Down
4 changes: 2 additions & 2 deletions editor/plugins/animation_state_machine_editor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -520,7 +520,7 @@ void AnimationNodeStateMachineEditor::_connection_draw(const Vector2 &p_from, co

Transform2D xf;
xf.elements[0] = (p_to - p_from).normalized();
xf.elements[1] = xf.elements[0].tangent();
xf.elements[1] = xf.elements[0].perpendicular();
xf.elements[2] = (p_from + p_to) * 0.5 - xf.elements[1] * icon->get_height() * 0.5 - xf.elements[0] * icon->get_height() * 0.5;

state_machine_draw->draw_set_transform_matrix(xf);
Expand Down Expand Up @@ -689,7 +689,7 @@ void AnimationNodeStateMachineEditor::_state_machine_draw() {
tl.width = tr_bidi_offset;

if (state_machine->has_transition(tl.to_node, tl.from_node)) { //offset if same exists
Vector2 offset = -(tl.from - tl.to).normalized().tangent() * tr_bidi_offset;
Vector2 offset = -(tl.from - tl.to).normalized().perpendicular() * tr_bidi_offset;
tl.from += offset;
tl.to += offset;
}
Expand Down
6 changes: 3 additions & 3 deletions editor/plugins/canvas_item_editor_plugin.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -726,7 +726,7 @@ bool CanvasItemEditor::_get_bone_shape(Vector<Vector2> *shape, Vector<Vector2> *
}

Vector2 rel = to - from;
Vector2 relt = rel.tangent().normalized() * bone_width;
Vector2 relt = rel.perpendicular().normalized() * bone_width;
Vector2 reln = rel.normalized();
Vector2 reltn = relt.normalized();

Expand Down Expand Up @@ -1795,7 +1795,7 @@ bool CanvasItemEditor::_gui_input_resize(const Ref<InputEvent> &p_event) {
}

ofs = (endpoints[i] + endpoints[next]) / 2;
ofs += (endpoints[next] - endpoints[i]).tangent().normalized() * (select_handle->get_size().width / 2);
ofs += (endpoints[next] - endpoints[i]).perpendicular().normalized() * (select_handle->get_size().width / 2);
if (ofs.distance_to(b->get_position()) < radius) {
resize_drag = dragger[i * 2 + 1];
}
Expand Down Expand Up @@ -3470,7 +3470,7 @@ void CanvasItemEditor::_draw_selection() {
select_handle->draw(ci, (endpoints[i] + ofs - (select_handle->get_size() / 2)).floor());

ofs = (endpoints[i] + endpoints[next]) / 2;
ofs += (endpoints[next] - endpoints[i]).tangent().normalized() * (select_handle->get_size().width / 2);
ofs += (endpoints[next] - endpoints[i]).perpendicular().normalized() * (select_handle->get_size().width / 2);

select_handle->draw(ci, (ofs - (select_handle->get_size() / 2)).floor());
}
Expand Down
2 changes: 1 addition & 1 deletion editor/plugins/texture_region_editor_plugin.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -177,7 +177,7 @@ void TextureRegionEditor::_region_draw() {
}

ofs = (endpoints[next] - endpoints[i]) / 2;
ofs += (endpoints[next] - endpoints[i]).tangent().normalized() * (select_handle->get_size().width / 2);
ofs += (endpoints[next] - endpoints[i]).perpendicular().normalized() * (select_handle->get_size().width / 2);

if (snap_mode != SNAP_AUTOSLICE) {
edit_draw->draw_texture(select_handle, (endpoints[i] + ofs - (select_handle->get_size() / 2)).floor() - draw_ofs * draw_zoom);
Expand Down
4 changes: 2 additions & 2 deletions modules/gdnative/gdnative/vector2.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -154,10 +154,10 @@ godot_vector2 GDAPI godot_vector2_rotated(const godot_vector2 *p_self, const god
return dest;
}

godot_vector2 GDAPI godot_vector2_tangent(const godot_vector2 *p_self) {
godot_vector2 GDAPI godot_vector2_perpendicular(const godot_vector2 *p_self) {
godot_vector2 dest;
const Vector2 *self = (const Vector2 *)p_self;
*((Vector2 *)&dest) = self->tangent();
*((Vector2 *)&dest) = self->perpendicular();
return dest;
}

Expand Down
2 changes: 1 addition & 1 deletion modules/gdnative/gdnative_api.json
Original file line number Diff line number Diff line change
Expand Up @@ -6259,7 +6259,7 @@
]
},
{
"name": "godot_vector2_tangent",
"name": "godot_vector2_perpendicular",
"return_type": "godot_vector2",
"arguments": [
["const godot_vector2 *", "p_self"]
Expand Down
2 changes: 1 addition & 1 deletion modules/gdnative/include/gdnative/vector2.h
Original file line number Diff line number Diff line change
Expand Up @@ -102,7 +102,7 @@ godot_vector2 GDAPI godot_vector2_move_toward(const godot_vector2 *p_self, const

godot_vector2 GDAPI godot_vector2_rotated(const godot_vector2 *p_self, const godot_real p_phi);

godot_vector2 GDAPI godot_vector2_tangent(const godot_vector2 *p_self);
godot_vector2 GDAPI godot_vector2_perpendicular(const godot_vector2 *p_self);

godot_vector2 GDAPI godot_vector2_floor(const godot_vector2 *p_self);

Expand Down
20 changes: 10 additions & 10 deletions modules/mono/glue/GodotSharp/GodotSharp/Core/Vector2.cs
Original file line number Diff line number Diff line change
Expand Up @@ -378,6 +378,16 @@ public Vector2 Normalized()
return v;
}

/// <summary>
/// Returns a perpendicular vector rotated 90 degrees counter-clockwise
/// compared to the original, with the same length.
/// </summary>
/// <returns>The perpendicular vector.</returns>
public Vector2 Perpendicular()
{
return new Vector2(y, -x);
}

/// <summary>
/// Returns a vector composed of the <see cref="Mathf.PosMod(real_t, real_t)"/> of this vector's components and `mod`.
/// </summary>
Expand Down Expand Up @@ -513,16 +523,6 @@ public Vector2 Snapped(Vector2 step)
return new Vector2(Mathf.Stepify(x, step.x), Mathf.Stepify(y, step.y));
}

/// <summary>
/// Returns a perpendicular vector rotated 90 degrees counter-clockwise
/// compared to the original, with the same length.
/// </summary>
/// <returns>The perpendicular vector.</returns>
public Vector2 Perpendicular()
{
return new Vector2(y, -x);
}

// Constants
private static readonly Vector2 _zero = new Vector2(0, 0);
private static readonly Vector2 _one = new Vector2(1, 1);
Expand Down
4 changes: 2 additions & 2 deletions scene/2d/cpu_particles_2d.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -743,7 +743,7 @@ void CPUParticles2D::_particles_process(float p_delta) {
Vector2 normal = emission_normals.get(random_idx);
Transform2D m2;
m2.set_axis(0, normal);
m2.set_axis(1, normal.tangent());
m2.set_axis(1, normal.perpendicular());
p.velocity = m2.basis_xform(p.velocity);
}

Expand Down Expand Up @@ -908,7 +908,7 @@ void CPUParticles2D::_particles_process(float p_delta) {
if (flags[FLAG_ALIGN_Y_TO_VELOCITY]) {
if (p.velocity.length() > 0.0) {
p.transform.elements[1] = p.velocity.normalized();
p.transform.elements[0] = p.transform.elements[1].tangent();
p.transform.elements[0] = p.transform.elements[1].perpendicular();
}

} else {
Expand Down
2 changes: 1 addition & 1 deletion scene/2d/path_2d.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -200,7 +200,7 @@ void PathFollow2D::_update_transform() {
tangent_to_curve = (ahead_pos - pos).normalized();
}

Vector2 normal_of_curve = -tangent_to_curve.tangent();
Vector2 normal_of_curve = -tangent_to_curve.perpendicular();

pos += tangent_to_curve * h_offset;
pos += normal_of_curve * v_offset;
Expand Down
2 changes: 1 addition & 1 deletion scene/3d/cpu_particles_3d.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -730,7 +730,7 @@ void CPUParticles3D::_particles_process(float p_delta) {
Vector2 normal_2d(normal.x, normal.y);
Transform2D m2;
m2.set_axis(0, normal_2d);
m2.set_axis(1, normal_2d.tangent());
m2.set_axis(1, normal_2d.perpendicular());
Vector2 velocity_2d(p.velocity.x, p.velocity.y);
velocity_2d = m2.basis_xform(velocity_2d);
p.velocity.x = velocity_2d.x;
Expand Down
6 changes: 3 additions & 3 deletions scene/resources/line_shape_2d.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@

bool LineShape2D::_edit_is_selected_on_click(const Point2 &p_point, double p_tolerance) const {
Vector2 point = get_distance() * get_normal();
Vector2 l[2][2] = { { point - get_normal().tangent() * 100, point + get_normal().tangent() * 100 }, { point, point + get_normal() * 30 } };
Vector2 l[2][2] = { { point - get_normal().perpendicular() * 100, point + get_normal().perpendicular() * 100 }, { point, point + get_normal() * 30 } };

for (int i = 0; i < 2; i++) {
Vector2 closest = Geometry2D::get_closest_point_to_segment(p_point, l[i]);
Expand Down Expand Up @@ -77,7 +77,7 @@ real_t LineShape2D::get_distance() const {
void LineShape2D::draw(const RID &p_to_rid, const Color &p_color) {
Vector2 point = get_distance() * get_normal();

Vector2 l1[2] = { point - get_normal().tangent() * 100, point + get_normal().tangent() * 100 };
Vector2 l1[2] = { point - get_normal().perpendicular() * 100, point + get_normal().perpendicular() * 100 };
RS::get_singleton()->canvas_item_add_line(p_to_rid, l1[0], l1[1], p_color, 3);
Vector2 l2[2] = { point, point + get_normal() * 30 };
RS::get_singleton()->canvas_item_add_line(p_to_rid, l2[0], l2[1], p_color, 3);
Expand All @@ -86,7 +86,7 @@ void LineShape2D::draw(const RID &p_to_rid, const Color &p_color) {
Rect2 LineShape2D::get_rect() const {
Vector2 point = get_distance() * get_normal();

Vector2 l1[2] = { point - get_normal().tangent() * 100, point + get_normal().tangent() * 100 };
Vector2 l1[2] = { point - get_normal().perpendicular() * 100, point + get_normal().perpendicular() * 100 };
Vector2 l2[2] = { point, point + get_normal() * 30 };
Rect2 rect;
rect.position = l1[0];
Expand Down
4 changes: 2 additions & 2 deletions servers/physics_2d/body_pair_2d_sw.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -409,7 +409,7 @@ bool BodyPair2DSW::setup(real_t p_step) {
kNormal += A->get_inv_inertia() * (c.rA.dot(c.rA) - rnA * rnA) + B->get_inv_inertia() * (c.rB.dot(c.rB) - rnB * rnB);
c.mass_normal = 1.0f / kNormal;

Vector2 tangent = c.normal.tangent();
Vector2 tangent = c.normal.perpendicular();
real_t rtA = c.rA.dot(tangent);
real_t rtB = c.rB.dot(tangent);
real_t kTangent = A->get_inv_mass() + B->get_inv_mass();
Expand Down Expand Up @@ -469,7 +469,7 @@ void BodyPair2DSW::solve(real_t p_step) {

real_t vn = dv.dot(c.normal);
real_t vbn = dbv.dot(c.normal);
Vector2 tangent = c.normal.tangent();
Vector2 tangent = c.normal.perpendicular();
real_t vt = dv.dot(tangent);

real_t jbn = (c.bias - vbn) * c.mass_normal;
Expand Down
8 changes: 4 additions & 4 deletions servers/physics_2d/collision_solver_2d_sat.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ _FORCE_INLINE_ static void _generate_contacts_edge_edge(const Vector2 *p_points_
#endif

Vector2 n = p_collector->normal;
Vector2 t = n.tangent();
Vector2 t = n.perpendicular();
real_t dA = n.dot(p_points_A[0]);
real_t dB = n.dot(p_points_B[0]);

Expand Down Expand Up @@ -209,7 +209,7 @@ class SeparatorAxisTest2D {
if (!test_axis(na)) {
return false;
}
if (!test_axis(na.tangent())) {
if (!test_axis(na.perpendicular())) {
return false;
}
}
Expand All @@ -219,7 +219,7 @@ class SeparatorAxisTest2D {
if (!test_axis(nb)) {
return false;
}
if (!test_axis(nb.tangent())) {
if (!test_axis(nb.perpendicular())) {
return false;
}
}
Expand Down Expand Up @@ -450,7 +450,7 @@ static void _collision_segment_circle(const Shape2DSW *p_a, const Transform2D &p

//segment normal
if (!separator.test_axis(
(p_transform_a.xform(segment_A->get_b()) - p_transform_a.xform(segment_A->get_a())).normalized().tangent())) {
(p_transform_a.xform(segment_A->get_b()) - p_transform_a.xform(segment_A->get_a())).normalized().perpendicular())) {
return;
}

Expand Down
10 changes: 5 additions & 5 deletions servers/physics_2d/joints_2d_sw.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -75,9 +75,9 @@ static inline real_t k_scalar(Body2DSW *a, Body2DSW *b, const Vector2 &rA, const

static inline Vector2
relative_velocity(Body2DSW *a, Body2DSW *b, Vector2 rA, Vector2 rB) {
Vector2 sum = a->get_linear_velocity() - rA.tangent() * a->get_angular_velocity();
Vector2 sum = a->get_linear_velocity() - rA.perpendicular() * a->get_angular_velocity();
if (b) {
return (b->get_linear_velocity() - rB.tangent() * b->get_angular_velocity()) - sum;
return (b->get_linear_velocity() - rB.perpendicular() * b->get_angular_velocity()) - sum;
} else {
return -sum;
}
Expand Down Expand Up @@ -264,7 +264,7 @@ bool GrooveJoint2DSW::setup(real_t p_step) {
Space2DSW *space = A->get_space();

// calculate axis
Vector2 n = -(tb - ta).tangent().normalized();
Vector2 n = -(tb - ta).perpendicular().normalized();
real_t d = ta.dot(n);

xf_normal = n;
Expand All @@ -282,7 +282,7 @@ bool GrooveJoint2DSW::setup(real_t p_step) {
} else {
clamp = 0.0f;
//joint->r1 = cpvsub(cpvadd(cpvmult(cpvperp(n), -td), cpvmult(n, d)), a->p);
rA = ((-n.tangent() * -td) + n * d) - A->get_transform().get_origin();
rA = ((-n.perpendicular() * -td) + n * d) - A->get_transform().get_origin();
}

// Calculate mass tensor
Expand Down Expand Up @@ -332,7 +332,7 @@ GrooveJoint2DSW::GrooveJoint2DSW(const Vector2 &p_a_groove1, const Vector2 &p_a_
A_groove_1 = A->get_inv_transform().xform(p_a_groove1);
A_groove_2 = A->get_inv_transform().xform(p_a_groove2);
B_anchor = B->get_inv_transform().xform(p_b_anchor);
A_groove_normal = -(A_groove_2 - A_groove_1).normalized().tangent();
A_groove_normal = -(A_groove_2 - A_groove_1).normalized().perpendicular();

A->add_constraint(this, 0);
B->add_constraint(this, 1);
Expand Down
8 changes: 4 additions & 4 deletions servers/physics_2d/shape_2d_sw.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -228,7 +228,7 @@ void SegmentShape2DSW::set_data(const Variant &p_data) {
Rect2 r = p_data;
a = r.position;
b = r.size;
n = (b - a).tangent();
n = (b - a).perpendicular();

Rect2 aabb;
aabb.position = a;
Expand Down Expand Up @@ -612,7 +612,7 @@ void ConvexPolygonShape2DSW::set_data(const Variant &p_data) {
for (int i = 0; i < point_count; i++) {
Vector2 p = points[i].pos;
Vector2 pn = points[(i + 1) % point_count].pos;
points[i].normal = (pn - p).tangent().normalized();
points[i].normal = (pn - p).perpendicular().normalized();
}
} else {
Vector<real_t> dvr = p_data;
Expand Down Expand Up @@ -740,7 +740,7 @@ bool ConcavePolygonShape2DSW::intersect_segment(const Vector2 &p_begin, const Ve
if (nd < d) {
d = nd;
r_point = res;
r_normal = (b - a).tangent().normalized();
r_normal = (b - a).perpendicular().normalized();
inters = true;
}
}
Expand Down Expand Up @@ -960,7 +960,7 @@ void ConcavePolygonShape2DSW::cull(const Rect2 &p_local_aabb, Callback p_callbac
Vector2 a = pointptr[s.points[0]];
Vector2 b = pointptr[s.points[1]];

SegmentShape2DSW ss(a, b, (b - a).tangent().normalized());
SegmentShape2DSW ss(a, b, (b - a).perpendicular().normalized());

p_callback(p_userdata, &ss);
stack[level] = (VISIT_DONE_BIT << VISITED_BIT_SHIFT) | node;
Expand Down
4 changes: 2 additions & 2 deletions servers/physics_2d/shape_2d_sw.h
Original file line number Diff line number Diff line change
Expand Up @@ -237,7 +237,7 @@ class SegmentShape2DSW : public Shape2DSW {
virtual PhysicsServer2D::ShapeType get_type() const { return PhysicsServer2D::SHAPE_SEGMENT; }

_FORCE_INLINE_ Vector2 get_xformed_normal(const Transform2D &p_xform) const {
return (p_xform.xform(b) - p_xform.xform(a)).normalized().tangent();
return (p_xform.xform(b) - p_xform.xform(a)).normalized().perpendicular();
}
virtual void project_rangev(const Vector2 &p_normal, const Transform2D &p_transform, real_t &r_min, real_t &r_max) const { project_range(p_normal, p_transform, r_min, r_max); }
virtual void get_supports(const Vector2 &p_normal, Vector2 *r_supports, int &r_amount) const;
Expand Down Expand Up @@ -431,7 +431,7 @@ class ConvexPolygonShape2DSW : public Shape2DSW {
Vector2 a = points[p_idx].pos;
p_idx++;
Vector2 b = points[p_idx == point_count ? 0 : p_idx].pos;
return (p_xform.xform(b) - p_xform.xform(a)).normalized().tangent();
return (p_xform.xform(b) - p_xform.xform(a)).normalized().perpendicular();
}

virtual PhysicsServer2D::ShapeType get_type() const { return PhysicsServer2D::SHAPE_CONVEX_POLYGON; }
Expand Down
2 changes: 1 addition & 1 deletion servers/rendering/rasterizer_rd/rasterizer_canvas_rd.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1630,7 +1630,7 @@ void RasterizerCanvasRD::light_update_directional_shadow(RID p_rid, int p_shadow

to_light_xform[2] = from_pos;
to_light_xform[1] = light_dir;
to_light_xform[0] = -light_dir.tangent();
to_light_xform[0] = -light_dir.perpendicular();

to_light_xform.invert();

Expand Down
Loading

0 comments on commit 6e38279

Please sign in to comment.