mirror of
https://github.com/Relintai/gdnative_python.git
synced 2025-01-21 15:17:19 +01:00
87 lines
3.0 KiB
Cython
87 lines
3.0 KiB
Cython
{%- block pxd_header %}
|
|
{% endblock -%}
|
|
{%- block pyx_header %}
|
|
{% endblock -%}
|
|
|
|
|
|
@cython.final
|
|
cdef class Quat:
|
|
{% block cdef_attributes %}
|
|
cdef godot_quat _gd_data
|
|
{% endblock %}
|
|
|
|
{% block python_defs %}
|
|
def __init__(self, x=0, y=0, z=0, w=0):
|
|
{{ force_mark_rendered("godot_quat_new") }}
|
|
gdapi10.godot_quat_new(&self._gd_data, x, y, z, w)
|
|
|
|
@staticmethod
|
|
def from_axis_angle(Vector3 axis not None, godot_real angle):
|
|
# Call to __new__ bypasses __init__ constructor
|
|
cdef Quat ret = Quat.__new__(Quat)
|
|
{{ force_mark_rendered("godot_quat_new_with_axis_angle") }}
|
|
gdapi10.godot_quat_new_with_axis_angle(&ret._gd_data, &axis._gd_data, angle)
|
|
return ret
|
|
|
|
@staticmethod
|
|
def from_basis(Basis basis not None):
|
|
# Call to __new__ bypasses __init__ constructor
|
|
cdef Quat ret = Quat.__new__(Quat)
|
|
{{ force_mark_rendered("godot_quat_new_with_basis") }}
|
|
gdapi11.godot_quat_new_with_basis(&ret._gd_data, &basis._gd_data)
|
|
return ret
|
|
|
|
@staticmethod
|
|
def from_euler(Vector3 euler not None):
|
|
# Call to __new__ bypasses __init__ constructor
|
|
cdef Quat ret = Quat.__new__(Quat)
|
|
{{ force_mark_rendered("godot_quat_new_with_euler") }}
|
|
gdapi11.godot_quat_new_with_euler(&ret._gd_data, &euler._gd_data)
|
|
return ret
|
|
|
|
def __repr__(Quat self):
|
|
return f"<Quat(x={self.x}, y={self.y}, z={self.z}, w={self.w})>"
|
|
|
|
{{ render_operator_eq() | indent }}
|
|
{{ render_operator_ne() | indent }}
|
|
|
|
{{ render_method("operator_neg", py_name="__neg__") | indent }}
|
|
|
|
def __pos__(Quat self):
|
|
return self
|
|
|
|
{{ render_method("operator_add", py_name="__add__") | indent }}
|
|
{{ render_method("operator_subtract", py_name="__sub__") | indent }}
|
|
{{ render_method("operator_multiply", py_name="__mul__") | indent }}
|
|
|
|
def __truediv__(Quat self, godot_real val):
|
|
if val == 0:
|
|
raise ZeroDivisionError
|
|
cdef Quat ret = Quat.__new__(Quat)
|
|
{{ force_mark_rendered("godot_quat_operator_divide") }}
|
|
ret._gd_data = gdapi10.godot_quat_operator_divide(&self._gd_data, val)
|
|
return ret
|
|
|
|
{{ render_property("x", getter="get_x", setter="set_x") | indent }}
|
|
{{ render_property("y", getter="get_y", setter="set_y") | indent }}
|
|
{{ render_property("z", getter="get_z", setter="set_z") | indent }}
|
|
{{ render_property("w", getter="get_w", setter="set_w") | indent }}
|
|
|
|
{{ render_method("as_string") | indent }}
|
|
{{ render_method("length") | indent }}
|
|
{{ render_method("length_squared") | indent }}
|
|
{{ render_method("normalized") | indent }}
|
|
{{ render_method("is_normalized") | indent }}
|
|
{{ render_method("inverse") | indent }}
|
|
{{ render_method("dot") | indent }}
|
|
{{ render_method("xform") | indent }}
|
|
{{ render_method("slerp") | indent }}
|
|
{{ render_method("slerpni") | indent }}
|
|
{{ render_method("cubic_slerp") | indent }}
|
|
{{ render_method("set_axis_angle") | indent }}
|
|
{% endblock %}
|
|
|
|
{%- block python_consts %}
|
|
IDENTITY = Quat(0, 0, 0, 1)
|
|
{% endblock %}
|