2023-05-23 19:06:25 +02:00
|
|
|
{%- block pxd_header %}
|
|
|
|
{% endblock -%}
|
|
|
|
{%- block pyx_header %}
|
|
|
|
import math
|
|
|
|
|
|
|
|
cdef inline Vector2 Vector2_multiply_vector(Vector2 self, Vector2 b):
|
|
|
|
cdef Vector2 ret = Vector2.__new__(Vector2)
|
2023-06-02 11:05:45 +02:00
|
|
|
{{ force_mark_rendered("pandemonium_vector2_operator_multiply_vector") }}
|
|
|
|
ret._gd_data = gdapi10.pandemonium_vector2_operator_multiply_vector(&self._gd_data, &b._gd_data)
|
2023-05-23 19:06:25 +02:00
|
|
|
return ret
|
|
|
|
|
2023-06-02 11:05:45 +02:00
|
|
|
cdef inline Vector2 Vector2_multiply_scalar(Vector2 self, pandemonium_real b):
|
2023-05-23 19:06:25 +02:00
|
|
|
cdef Vector2 ret = Vector2.__new__(Vector2)
|
2023-06-02 11:05:45 +02:00
|
|
|
{{ force_mark_rendered("pandemonium_vector2_operator_multiply_scalar") }}
|
|
|
|
ret._gd_data = gdapi10.pandemonium_vector2_operator_multiply_scalar(&self._gd_data, b)
|
2023-05-23 19:06:25 +02:00
|
|
|
return ret
|
|
|
|
|
|
|
|
cdef inline Vector2 Vector2_divide_vector(Vector2 self, Vector2 b):
|
|
|
|
cdef Vector2 ret = Vector2.__new__(Vector2)
|
2023-06-02 11:05:45 +02:00
|
|
|
{{ force_mark_rendered("pandemonium_vector2_operator_divide_vector") }}
|
|
|
|
ret._gd_data = gdapi10.pandemonium_vector2_operator_divide_vector(&self._gd_data, &b._gd_data)
|
2023-05-23 19:06:25 +02:00
|
|
|
return ret
|
|
|
|
|
2023-06-02 11:05:45 +02:00
|
|
|
cdef inline Vector2 Vector2_divide_scalar(Vector2 self, pandemonium_real b):
|
2023-05-23 19:06:25 +02:00
|
|
|
cdef Vector2 ret = Vector2.__new__(Vector2)
|
2023-06-02 11:05:45 +02:00
|
|
|
{{ force_mark_rendered("pandemonium_vector2_operator_divide_scalar") }}
|
|
|
|
ret._gd_data = gdapi10.pandemonium_vector2_operator_divide_scalar(&self._gd_data, b)
|
2023-05-23 19:06:25 +02:00
|
|
|
return ret
|
|
|
|
{% endblock -%}
|
|
|
|
|
|
|
|
|
|
|
|
@cython.final
|
|
|
|
cdef class Vector2:
|
|
|
|
{% block cdef_attributes %}
|
2023-06-02 11:05:45 +02:00
|
|
|
cdef pandemonium_vector2 _gd_data
|
2023-05-23 19:06:25 +02:00
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{% block python_defs %}
|
2023-06-02 11:05:45 +02:00
|
|
|
def __init__(self, pandemonium_real x=0.0, pandemonium_real y=0.0):
|
|
|
|
{{ force_mark_rendered("pandemonium_vector2_new") }}
|
|
|
|
gdapi10.pandemonium_vector2_new(&self._gd_data, x, y)
|
2023-05-23 19:06:25 +02:00
|
|
|
|
|
|
|
def __repr__(Vector2 self):
|
|
|
|
return f"<Vector2(x={self.x}, y={self.y})>"
|
|
|
|
|
|
|
|
{{ render_operator_eq() | indent }}
|
|
|
|
{{ render_operator_ne() | indent }}
|
|
|
|
{{ render_operator_lt() | indent }}
|
|
|
|
|
|
|
|
{{ render_method("operator_neg", py_name="__neg__") | indent }}
|
|
|
|
|
|
|
|
def __pos__(Vector2 self):
|
|
|
|
return self
|
|
|
|
|
|
|
|
{{ render_method("operator_add", py_name="__add__") | indent }}
|
|
|
|
{{ render_method("operator_subtract", py_name="__sub__") | indent }}
|
|
|
|
|
|
|
|
def __mul__(Vector2 self, val):
|
|
|
|
cdef Vector2 _val
|
|
|
|
try:
|
|
|
|
_val = <Vector2?>val
|
|
|
|
except TypeError:
|
|
|
|
return Vector2_multiply_scalar(self, val)
|
|
|
|
else:
|
|
|
|
return Vector2_multiply_vector(self, _val)
|
|
|
|
|
|
|
|
def __truediv__(Vector2 self, val):
|
|
|
|
cdef Vector2 _val
|
|
|
|
try:
|
|
|
|
_val = <Vector2?>val
|
|
|
|
except TypeError:
|
|
|
|
if val is 0:
|
|
|
|
raise ZeroDivisionError()
|
|
|
|
return Vector2_divide_scalar(self, val)
|
|
|
|
else:
|
|
|
|
if _val.x == 0 or _val.y == 0:
|
|
|
|
raise ZeroDivisionError()
|
|
|
|
return Vector2_divide_vector(self, _val)
|
|
|
|
|
|
|
|
{{ render_property("x", "get_x", "set_x") | indent }}
|
|
|
|
{{ render_property("y", "get_y", "set_y") | indent }}
|
|
|
|
{{ render_property("width", "get_x", "set_x") | indent }}
|
|
|
|
{{ render_property("height", "get_y", "set_y") | indent }}
|
|
|
|
|
|
|
|
{{ render_method("as_string") | indent }}
|
|
|
|
{{ render_method("normalized") | indent }}
|
|
|
|
{{ render_method("length") | indent }}
|
|
|
|
{{ render_method("angle") | indent }}
|
|
|
|
{{ render_method("length_squared") | indent }}
|
|
|
|
{{ render_method("is_normalized") | indent }}
|
|
|
|
{{ render_method("distance_to") | indent }}
|
|
|
|
{{ render_method("distance_squared_to") | indent }}
|
|
|
|
{{ render_method("angle_to") | indent }}
|
|
|
|
{{ render_method("angle_to_point") | indent }}
|
|
|
|
{{ render_method("linear_interpolate") | indent }}
|
|
|
|
{{ render_method("cubic_interpolate") | indent }}
|
|
|
|
{{ render_method("move_toward") | indent }}
|
|
|
|
{{ render_method("direction_to") | indent }}
|
|
|
|
{{ render_method("rotated") | indent }}
|
|
|
|
{{ render_method("tangent") | indent }}
|
|
|
|
{{ render_method("floor") | indent }}
|
|
|
|
{{ render_method("snapped") | indent }}
|
|
|
|
{{ render_method("aspect") | indent }}
|
|
|
|
{{ render_method("dot") | indent }}
|
|
|
|
{{ render_method("slide") | indent }}
|
|
|
|
{{ render_method("bounce") | indent }}
|
|
|
|
{{ render_method("reflect") | indent }}
|
|
|
|
{{ render_method("abs") | indent }}
|
|
|
|
{{ render_method("clamped") | indent }}
|
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{%- block python_consts %}
|
|
|
|
AXIS_X = 0
|
|
|
|
AXIS_Y = 0
|
|
|
|
|
|
|
|
ZERO = Vector2(0, 0)
|
|
|
|
ONE = Vector2(1, 1)
|
|
|
|
INF = Vector2(math.inf, math.inf)
|
|
|
|
LEFT = Vector2(-1, 0)
|
|
|
|
RIGHT = Vector2(1, 0)
|
|
|
|
UP = Vector2(0, -1)
|
|
|
|
DOWN = Vector2(0, 1)
|
|
|
|
{% endblock %}
|