1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
use crate::Euler;
use crate::Matrix;
use crate::Quaternion;
use crate::Vec3;
use crate::Vec4;
use glib::translate::*;
impl Quaternion {
#[doc(alias = "graphene_quaternion_init")]
pub fn new(x: f32, y: f32, z: f32, w: f32) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init(alloc, x, y, z, w);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_from_angle_vec3")]
#[doc(alias = "new_from_angle_vec3")]
pub fn from_angle_vec3(angle: f32, axis: &Vec3) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_from_angle_vec3(alloc, angle, axis.to_glib_none().0);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_from_angles")]
#[doc(alias = "new_from_angles")]
pub fn from_angles(deg_x: f32, deg_y: f32, deg_z: f32) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_from_angles(alloc, deg_x, deg_y, deg_z);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_from_euler")]
#[doc(alias = "new_from_euler")]
pub fn from_euler(e: &Euler) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_from_euler(alloc, e.to_glib_none().0);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_from_matrix")]
#[doc(alias = "new_from_matrix")]
pub fn from_matrix(m: &Matrix) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_from_matrix(alloc, m.to_glib_none().0);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_from_quaternion")]
#[doc(alias = "new_from_quaternion")]
pub fn from_quaternion(src: &Quaternion) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_from_quaternion(alloc, src.to_glib_none().0);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_from_radians")]
#[doc(alias = "new_from_radians")]
pub fn from_radians(rad_x: f32, rad_y: f32, rad_z: f32) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_from_radians(alloc, rad_x, rad_y, rad_z);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_from_vec4")]
#[doc(alias = "new_from_vec4")]
pub fn from_vec4(src: &Vec4) -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_from_vec4(alloc, src.to_glib_none().0);
from_glib_full(alloc)
}
}
#[doc(alias = "graphene_quaternion_init_identity")]
pub fn new_identity() -> Quaternion {
assert_initialized_main_thread!();
unsafe {
let alloc = ffi::graphene_quaternion_alloc();
ffi::graphene_quaternion_init_identity(alloc);
from_glib_full(alloc)
}
}
}