raylib-bindings 0.7.9-x86_64-darwin → 0.7.10-x86_64-darwin
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/ChangeLog +539 -531
- data/LICENSE.txt +1 -1
- data/README.md +217 -209
- data/examples/template.rb +144 -144
- data/lib/config.rb +117 -116
- data/lib/libraylib.x86_64.dylib +0 -0
- data/lib/physac.rb +331 -331
- data/lib/physac.x86_64.dylib +0 -0
- data/lib/raygui.x86_64.dylib +0 -0
- data/lib/raygui_helper.rb +127 -127
- data/lib/raygui_main.rb +912 -912
- data/lib/raylib.rb +62 -62
- data/lib/raylib_helper.rb +431 -415
- data/lib/raylib_main.rb +5341 -5330
- data/lib/raymath.rb +1067 -1067
- data/lib/rcamera.rb +126 -126
- data/lib/rlgl.rb +1375 -1374
- metadata +3 -6
data/lib/raymath.rb
CHANGED
@@ -1,1067 +1,1067 @@
|
|
1
|
-
# Yet another raylib wrapper for Ruby
|
2
|
-
#
|
3
|
-
# * https://github.com/vaiorabbit/raylib-bindings
|
4
|
-
#
|
5
|
-
# [NOTICE] Autogenerated. Do not edit.
|
6
|
-
|
7
|
-
require 'ffi'
|
8
|
-
|
9
|
-
module Raylib
|
10
|
-
extend FFI::Library
|
11
|
-
|
12
|
-
# Define/Macro
|
13
|
-
|
14
|
-
EPSILON = 0.000001
|
15
|
-
|
16
|
-
# Typedef
|
17
|
-
|
18
|
-
|
19
|
-
# Struct
|
20
|
-
|
21
|
-
# NOTE: Helper types to be used instead of array return types for *ToFloat functions
|
22
|
-
class Float3 < FFI::Struct
|
23
|
-
layout(
|
24
|
-
:v, [:float, 3],
|
25
|
-
)
|
26
|
-
def v = self[:v]
|
27
|
-
def v=(v) self[:v] = v end
|
28
|
-
end
|
29
|
-
|
30
|
-
class Float16 < FFI::Struct
|
31
|
-
layout(
|
32
|
-
:v, [:float, 16],
|
33
|
-
)
|
34
|
-
def v = self[:v]
|
35
|
-
def v=(v) self[:v] = v end
|
36
|
-
end
|
37
|
-
|
38
|
-
|
39
|
-
# Function
|
40
|
-
|
41
|
-
def self.setup_raymath_symbols(method_naming: :original)
|
42
|
-
entries = [
|
43
|
-
|
44
|
-
# @!method Clamp(value, min, max)
|
45
|
-
# Clamp
|
46
|
-
# @param value [float]
|
47
|
-
# @param min [float]
|
48
|
-
# @param max [float]
|
49
|
-
# @return [float]
|
50
|
-
[:Clamp, :Clamp, [:float, :float, :float], :float],
|
51
|
-
|
52
|
-
# @!method Lerp(start, end, amount)
|
53
|
-
# Lerp
|
54
|
-
# @param start [float]
|
55
|
-
# @param end [float]
|
56
|
-
# @param amount [float]
|
57
|
-
# @return [float]
|
58
|
-
[:Lerp, :Lerp, [:float, :float, :float], :float],
|
59
|
-
|
60
|
-
# @!method Normalize(value, start, end)
|
61
|
-
# Normalize
|
62
|
-
# @param value [float]
|
63
|
-
# @param start [float]
|
64
|
-
# @param end [float]
|
65
|
-
# @return [float]
|
66
|
-
[:Normalize, :Normalize, [:float, :float, :float], :float],
|
67
|
-
|
68
|
-
# @!method Remap(value, inputStart, inputEnd, outputStart, outputEnd)
|
69
|
-
# Remap
|
70
|
-
# @param value [float]
|
71
|
-
# @param inputStart [float]
|
72
|
-
# @param inputEnd [float]
|
73
|
-
# @param outputStart [float]
|
74
|
-
# @param outputEnd [float]
|
75
|
-
# @return [float]
|
76
|
-
[:Remap, :Remap, [:float, :float, :float, :float, :float], :float],
|
77
|
-
|
78
|
-
# @!method Wrap(value, min, max)
|
79
|
-
# Wrap
|
80
|
-
# @param value [float]
|
81
|
-
# @param min [float]
|
82
|
-
# @param max [float]
|
83
|
-
# @return [float]
|
84
|
-
[:Wrap, :Wrap, [:float, :float, :float], :float],
|
85
|
-
|
86
|
-
# @!method FloatEquals(x, y)
|
87
|
-
# FloatEquals
|
88
|
-
# @param x [float]
|
89
|
-
# @param y [float]
|
90
|
-
# @return [int]
|
91
|
-
[:FloatEquals, :FloatEquals, [:float, :float], :int],
|
92
|
-
|
93
|
-
# @!method Vector2Zero()
|
94
|
-
# Vector2Zero
|
95
|
-
# @return [Vector2]
|
96
|
-
[:Vector2Zero, :Vector2Zero, [], Vector2.by_value],
|
97
|
-
|
98
|
-
# @!method Vector2One()
|
99
|
-
# Vector2One
|
100
|
-
# @return [Vector2]
|
101
|
-
[:Vector2One, :Vector2One, [], Vector2.by_value],
|
102
|
-
|
103
|
-
# @!method Vector2Add(v1, v2)
|
104
|
-
# Vector2Add
|
105
|
-
# @param v1 [Vector2]
|
106
|
-
# @param v2 [Vector2]
|
107
|
-
# @return [Vector2]
|
108
|
-
[:Vector2Add, :Vector2Add, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
109
|
-
|
110
|
-
# @!method Vector2AddValue(v, add)
|
111
|
-
# Vector2AddValue
|
112
|
-
# @param v [Vector2]
|
113
|
-
# @param add [float]
|
114
|
-
# @return [Vector2]
|
115
|
-
[:Vector2AddValue, :Vector2AddValue, [Vector2.by_value, :float], Vector2.by_value],
|
116
|
-
|
117
|
-
# @!method Vector2Subtract(v1, v2)
|
118
|
-
# Vector2Subtract
|
119
|
-
# @param v1 [Vector2]
|
120
|
-
# @param v2 [Vector2]
|
121
|
-
# @return [Vector2]
|
122
|
-
[:Vector2Subtract, :Vector2Subtract, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
123
|
-
|
124
|
-
# @!method Vector2SubtractValue(v, sub)
|
125
|
-
# Vector2SubtractValue
|
126
|
-
# @param v [Vector2]
|
127
|
-
# @param sub [float]
|
128
|
-
# @return [Vector2]
|
129
|
-
[:Vector2SubtractValue, :Vector2SubtractValue, [Vector2.by_value, :float], Vector2.by_value],
|
130
|
-
|
131
|
-
# @!method Vector2Length(v)
|
132
|
-
# Vector2Length
|
133
|
-
# @param v [Vector2]
|
134
|
-
# @return [float]
|
135
|
-
[:Vector2Length, :Vector2Length, [Vector2.by_value], :float],
|
136
|
-
|
137
|
-
# @!method Vector2LengthSqr(v)
|
138
|
-
# Vector2LengthSqr
|
139
|
-
# @param v [Vector2]
|
140
|
-
# @return [float]
|
141
|
-
[:Vector2LengthSqr, :Vector2LengthSqr, [Vector2.by_value], :float],
|
142
|
-
|
143
|
-
# @!method Vector2DotProduct(v1, v2)
|
144
|
-
# Vector2DotProduct
|
145
|
-
# @param v1 [Vector2]
|
146
|
-
# @param v2 [Vector2]
|
147
|
-
# @return [float]
|
148
|
-
[:Vector2DotProduct, :Vector2DotProduct, [Vector2.by_value, Vector2.by_value], :float],
|
149
|
-
|
150
|
-
# @!method Vector2CrossProduct(v1, v2)
|
151
|
-
# Vector2CrossProduct
|
152
|
-
# @param v1 [Vector2]
|
153
|
-
# @param v2 [Vector2]
|
154
|
-
# @return [float]
|
155
|
-
[:Vector2CrossProduct, :Vector2CrossProduct, [Vector2.by_value, Vector2.by_value], :float],
|
156
|
-
|
157
|
-
# @!method Vector2Distance(v1, v2)
|
158
|
-
# Vector2Distance
|
159
|
-
# @param v1 [Vector2]
|
160
|
-
# @param v2 [Vector2]
|
161
|
-
# @return [float]
|
162
|
-
[:Vector2Distance, :Vector2Distance, [Vector2.by_value, Vector2.by_value], :float],
|
163
|
-
|
164
|
-
# @!method Vector2DistanceSqr(v1, v2)
|
165
|
-
# Vector2DistanceSqr
|
166
|
-
# @param v1 [Vector2]
|
167
|
-
# @param v2 [Vector2]
|
168
|
-
# @return [float]
|
169
|
-
[:Vector2DistanceSqr, :Vector2DistanceSqr, [Vector2.by_value, Vector2.by_value], :float],
|
170
|
-
|
171
|
-
# @!method Vector2Angle(v1, v2)
|
172
|
-
# Vector2Angle
|
173
|
-
# @param v1 [Vector2]
|
174
|
-
# @param v2 [Vector2]
|
175
|
-
# @return [float]
|
176
|
-
[:Vector2Angle, :Vector2Angle, [Vector2.by_value, Vector2.by_value], :float],
|
177
|
-
|
178
|
-
# @!method Vector2LineAngle(start, end)
|
179
|
-
# Vector2LineAngle
|
180
|
-
# @param start [Vector2]
|
181
|
-
# @param end [Vector2]
|
182
|
-
# @return [float]
|
183
|
-
[:Vector2LineAngle, :Vector2LineAngle, [Vector2.by_value, Vector2.by_value], :float],
|
184
|
-
|
185
|
-
# @!method Vector2Scale(v, scale)
|
186
|
-
# Vector2Scale
|
187
|
-
# @param v [Vector2]
|
188
|
-
# @param scale [float]
|
189
|
-
# @return [Vector2]
|
190
|
-
[:Vector2Scale, :Vector2Scale, [Vector2.by_value, :float], Vector2.by_value],
|
191
|
-
|
192
|
-
# @!method Vector2Multiply(v1, v2)
|
193
|
-
# Vector2Multiply
|
194
|
-
# @param v1 [Vector2]
|
195
|
-
# @param v2 [Vector2]
|
196
|
-
# @return [Vector2]
|
197
|
-
[:Vector2Multiply, :Vector2Multiply, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
198
|
-
|
199
|
-
# @!method Vector2Negate(v)
|
200
|
-
# Vector2Negate
|
201
|
-
# @param v [Vector2]
|
202
|
-
# @return [Vector2]
|
203
|
-
[:Vector2Negate, :Vector2Negate, [Vector2.by_value], Vector2.by_value],
|
204
|
-
|
205
|
-
# @!method Vector2Divide(v1, v2)
|
206
|
-
# Vector2Divide
|
207
|
-
# @param v1 [Vector2]
|
208
|
-
# @param v2 [Vector2]
|
209
|
-
# @return [Vector2]
|
210
|
-
[:Vector2Divide, :Vector2Divide, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
211
|
-
|
212
|
-
# @!method Vector2Normalize(v)
|
213
|
-
# Vector2Normalize
|
214
|
-
# @param v [Vector2]
|
215
|
-
# @return [Vector2]
|
216
|
-
[:Vector2Normalize, :Vector2Normalize, [Vector2.by_value], Vector2.by_value],
|
217
|
-
|
218
|
-
# @!method Vector2Transform(v, mat)
|
219
|
-
# Vector2Transform
|
220
|
-
# @param v [Vector2]
|
221
|
-
# @param mat [Matrix]
|
222
|
-
# @return [Vector2]
|
223
|
-
[:Vector2Transform, :Vector2Transform, [Vector2.by_value, Matrix.by_value], Vector2.by_value],
|
224
|
-
|
225
|
-
# @!method Vector2Lerp(v1, v2, amount)
|
226
|
-
# Vector2Lerp
|
227
|
-
# @param v1 [Vector2]
|
228
|
-
# @param v2 [Vector2]
|
229
|
-
# @param amount [float]
|
230
|
-
# @return [Vector2]
|
231
|
-
[:Vector2Lerp, :Vector2Lerp, [Vector2.by_value, Vector2.by_value, :float], Vector2.by_value],
|
232
|
-
|
233
|
-
# @!method Vector2Reflect(v, normal)
|
234
|
-
# Vector2Reflect
|
235
|
-
# @param v [Vector2]
|
236
|
-
# @param normal [Vector2]
|
237
|
-
# @return [Vector2]
|
238
|
-
[:Vector2Reflect, :Vector2Reflect, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
239
|
-
|
240
|
-
# @!method Vector2Min(v1, v2)
|
241
|
-
# Vector2Min
|
242
|
-
# @param v1 [Vector2]
|
243
|
-
# @param v2 [Vector2]
|
244
|
-
# @return [Vector2]
|
245
|
-
[:Vector2Min, :Vector2Min, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
246
|
-
|
247
|
-
# @!method Vector2Max(v1, v2)
|
248
|
-
# Vector2Max
|
249
|
-
# @param v1 [Vector2]
|
250
|
-
# @param v2 [Vector2]
|
251
|
-
# @return [Vector2]
|
252
|
-
[:Vector2Max, :Vector2Max, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
253
|
-
|
254
|
-
# @!method Vector2Rotate(v, angle)
|
255
|
-
# Vector2Rotate
|
256
|
-
# @param v [Vector2]
|
257
|
-
# @param angle [float]
|
258
|
-
# @return [Vector2]
|
259
|
-
[:Vector2Rotate, :Vector2Rotate, [Vector2.by_value, :float], Vector2.by_value],
|
260
|
-
|
261
|
-
# @!method Vector2MoveTowards(v, target, maxDistance)
|
262
|
-
# Vector2MoveTowards
|
263
|
-
# @param v [Vector2]
|
264
|
-
# @param target [Vector2]
|
265
|
-
# @param maxDistance [float]
|
266
|
-
# @return [Vector2]
|
267
|
-
[:Vector2MoveTowards, :Vector2MoveTowards, [Vector2.by_value, Vector2.by_value, :float], Vector2.by_value],
|
268
|
-
|
269
|
-
# @!method Vector2Invert(v)
|
270
|
-
# Vector2Invert
|
271
|
-
# @param v [Vector2]
|
272
|
-
# @return [Vector2]
|
273
|
-
[:Vector2Invert, :Vector2Invert, [Vector2.by_value], Vector2.by_value],
|
274
|
-
|
275
|
-
# @!method Vector2Clamp(v, min, max)
|
276
|
-
# Vector2Clamp
|
277
|
-
# @param v [Vector2]
|
278
|
-
# @param min [Vector2]
|
279
|
-
# @param max [Vector2]
|
280
|
-
# @return [Vector2]
|
281
|
-
[:Vector2Clamp, :Vector2Clamp, [Vector2.by_value, Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
282
|
-
|
283
|
-
# @!method Vector2ClampValue(v, min, max)
|
284
|
-
# Vector2ClampValue
|
285
|
-
# @param v [Vector2]
|
286
|
-
# @param min [float]
|
287
|
-
# @param max [float]
|
288
|
-
# @return [Vector2]
|
289
|
-
[:Vector2ClampValue, :Vector2ClampValue, [Vector2.by_value, :float, :float], Vector2.by_value],
|
290
|
-
|
291
|
-
# @!method Vector2Equals(p, q)
|
292
|
-
# Vector2Equals
|
293
|
-
# @param p [Vector2]
|
294
|
-
# @param q [Vector2]
|
295
|
-
# @return [int]
|
296
|
-
[:Vector2Equals, :Vector2Equals, [Vector2.by_value, Vector2.by_value], :int],
|
297
|
-
|
298
|
-
# @!method Vector2Refract(v, n, r)
|
299
|
-
# Vector2Refract
|
300
|
-
# @param v [Vector2]
|
301
|
-
# @param n [Vector2]
|
302
|
-
# @param r [float]
|
303
|
-
# @return [Vector2]
|
304
|
-
[:Vector2Refract, :Vector2Refract, [Vector2.by_value, Vector2.by_value, :float], Vector2.by_value],
|
305
|
-
|
306
|
-
# @!method Vector3Zero()
|
307
|
-
# Vector3Zero
|
308
|
-
# @return [Vector3]
|
309
|
-
[:Vector3Zero, :Vector3Zero, [], Vector3.by_value],
|
310
|
-
|
311
|
-
# @!method Vector3One()
|
312
|
-
# Vector3One
|
313
|
-
# @return [Vector3]
|
314
|
-
[:Vector3One, :Vector3One, [], Vector3.by_value],
|
315
|
-
|
316
|
-
# @!method Vector3Add(v1, v2)
|
317
|
-
# Vector3Add
|
318
|
-
# @param v1 [Vector3]
|
319
|
-
# @param v2 [Vector3]
|
320
|
-
# @return [Vector3]
|
321
|
-
[:Vector3Add, :Vector3Add, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
322
|
-
|
323
|
-
# @!method Vector3AddValue(v, add)
|
324
|
-
# Vector3AddValue
|
325
|
-
# @param v [Vector3]
|
326
|
-
# @param add [float]
|
327
|
-
# @return [Vector3]
|
328
|
-
[:Vector3AddValue, :Vector3AddValue, [Vector3.by_value, :float], Vector3.by_value],
|
329
|
-
|
330
|
-
# @!method Vector3Subtract(v1, v2)
|
331
|
-
# Vector3Subtract
|
332
|
-
# @param v1 [Vector3]
|
333
|
-
# @param v2 [Vector3]
|
334
|
-
# @return [Vector3]
|
335
|
-
[:Vector3Subtract, :Vector3Subtract, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
336
|
-
|
337
|
-
# @!method Vector3SubtractValue(v, sub)
|
338
|
-
# Vector3SubtractValue
|
339
|
-
# @param v [Vector3]
|
340
|
-
# @param sub [float]
|
341
|
-
# @return [Vector3]
|
342
|
-
[:Vector3SubtractValue, :Vector3SubtractValue, [Vector3.by_value, :float], Vector3.by_value],
|
343
|
-
|
344
|
-
# @!method Vector3Scale(v, scalar)
|
345
|
-
# Vector3Scale
|
346
|
-
# @param v [Vector3]
|
347
|
-
# @param scalar [float]
|
348
|
-
# @return [Vector3]
|
349
|
-
[:Vector3Scale, :Vector3Scale, [Vector3.by_value, :float], Vector3.by_value],
|
350
|
-
|
351
|
-
# @!method Vector3Multiply(v1, v2)
|
352
|
-
# Vector3Multiply
|
353
|
-
# @param v1 [Vector3]
|
354
|
-
# @param v2 [Vector3]
|
355
|
-
# @return [Vector3]
|
356
|
-
[:Vector3Multiply, :Vector3Multiply, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
357
|
-
|
358
|
-
# @!method Vector3CrossProduct(v1, v2)
|
359
|
-
# Vector3CrossProduct
|
360
|
-
# @param v1 [Vector3]
|
361
|
-
# @param v2 [Vector3]
|
362
|
-
# @return [Vector3]
|
363
|
-
[:Vector3CrossProduct, :Vector3CrossProduct, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
364
|
-
|
365
|
-
# @!method Vector3Perpendicular(v)
|
366
|
-
# Vector3Perpendicular
|
367
|
-
# @param v [Vector3]
|
368
|
-
# @return [Vector3]
|
369
|
-
[:Vector3Perpendicular, :Vector3Perpendicular, [Vector3.by_value], Vector3.by_value],
|
370
|
-
|
371
|
-
# @!method Vector3Length(v)
|
372
|
-
# Vector3Length
|
373
|
-
# @param v [const Vector3]
|
374
|
-
# @return [float]
|
375
|
-
[:Vector3Length, :Vector3Length, [Vector3.by_value], :float],
|
376
|
-
|
377
|
-
# @!method Vector3LengthSqr(v)
|
378
|
-
# Vector3LengthSqr
|
379
|
-
# @param v [const Vector3]
|
380
|
-
# @return [float]
|
381
|
-
[:Vector3LengthSqr, :Vector3LengthSqr, [Vector3.by_value], :float],
|
382
|
-
|
383
|
-
# @!method Vector3DotProduct(v1, v2)
|
384
|
-
# Vector3DotProduct
|
385
|
-
# @param v1 [Vector3]
|
386
|
-
# @param v2 [Vector3]
|
387
|
-
# @return [float]
|
388
|
-
[:Vector3DotProduct, :Vector3DotProduct, [Vector3.by_value, Vector3.by_value], :float],
|
389
|
-
|
390
|
-
# @!method Vector3Distance(v1, v2)
|
391
|
-
# Vector3Distance
|
392
|
-
# @param v1 [Vector3]
|
393
|
-
# @param v2 [Vector3]
|
394
|
-
# @return [float]
|
395
|
-
[:Vector3Distance, :Vector3Distance, [Vector3.by_value, Vector3.by_value], :float],
|
396
|
-
|
397
|
-
# @!method Vector3DistanceSqr(v1, v2)
|
398
|
-
# Vector3DistanceSqr
|
399
|
-
# @param v1 [Vector3]
|
400
|
-
# @param v2 [Vector3]
|
401
|
-
# @return [float]
|
402
|
-
[:Vector3DistanceSqr, :Vector3DistanceSqr, [Vector3.by_value, Vector3.by_value], :float],
|
403
|
-
|
404
|
-
# @!method Vector3Angle(v1, v2)
|
405
|
-
# Vector3Angle
|
406
|
-
# @param v1 [Vector3]
|
407
|
-
# @param v2 [Vector3]
|
408
|
-
# @return [float]
|
409
|
-
[:Vector3Angle, :Vector3Angle, [Vector3.by_value, Vector3.by_value], :float],
|
410
|
-
|
411
|
-
# @!method Vector3Negate(v)
|
412
|
-
# Vector3Negate
|
413
|
-
# @param v [Vector3]
|
414
|
-
# @return [Vector3]
|
415
|
-
[:Vector3Negate, :Vector3Negate, [Vector3.by_value], Vector3.by_value],
|
416
|
-
|
417
|
-
# @!method Vector3Divide(v1, v2)
|
418
|
-
# Vector3Divide
|
419
|
-
# @param v1 [Vector3]
|
420
|
-
# @param v2 [Vector3]
|
421
|
-
# @return [Vector3]
|
422
|
-
[:Vector3Divide, :Vector3Divide, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
423
|
-
|
424
|
-
# @!method Vector3Normalize(v)
|
425
|
-
# Vector3Normalize
|
426
|
-
# @param v [Vector3]
|
427
|
-
# @return [Vector3]
|
428
|
-
[:Vector3Normalize, :Vector3Normalize, [Vector3.by_value], Vector3.by_value],
|
429
|
-
|
430
|
-
# @!method Vector3Project(v1, v2)
|
431
|
-
# Vector3Project
|
432
|
-
# @param v1 [Vector3]
|
433
|
-
# @param v2 [Vector3]
|
434
|
-
# @return [Vector3]
|
435
|
-
[:Vector3Project, :Vector3Project, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
436
|
-
|
437
|
-
# @!method Vector3Reject(v1, v2)
|
438
|
-
# Vector3Reject
|
439
|
-
# @param v1 [Vector3]
|
440
|
-
# @param v2 [Vector3]
|
441
|
-
# @return [Vector3]
|
442
|
-
[:Vector3Reject, :Vector3Reject, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
443
|
-
|
444
|
-
# @!method Vector3OrthoNormalize(v1, v2)
|
445
|
-
# Vector3OrthoNormalize
|
446
|
-
# @param v1 [Vector3 *]
|
447
|
-
# @param v2 [Vector3 *]
|
448
|
-
# @return [void]
|
449
|
-
[:Vector3OrthoNormalize, :Vector3OrthoNormalize, [:pointer, :pointer], :void],
|
450
|
-
|
451
|
-
# @!method Vector3Transform(v, mat)
|
452
|
-
# Vector3Transform
|
453
|
-
# @param v [Vector3]
|
454
|
-
# @param mat [Matrix]
|
455
|
-
# @return [Vector3]
|
456
|
-
[:Vector3Transform, :Vector3Transform, [Vector3.by_value, Matrix.by_value], Vector3.by_value],
|
457
|
-
|
458
|
-
# @!method Vector3RotateByQuaternion(v, q)
|
459
|
-
# Vector3RotateByQuaternion
|
460
|
-
# @param v [Vector3]
|
461
|
-
# @param q [Quaternion]
|
462
|
-
# @return [Vector3]
|
463
|
-
[:Vector3RotateByQuaternion, :Vector3RotateByQuaternion, [Vector3.by_value, Quaternion.by_value], Vector3.by_value],
|
464
|
-
|
465
|
-
# @!method Vector3RotateByAxisAngle(v, axis, angle)
|
466
|
-
# Vector3RotateByAxisAngle
|
467
|
-
# @param v [Vector3]
|
468
|
-
# @param axis [Vector3]
|
469
|
-
# @param angle [float]
|
470
|
-
# @return [Vector3]
|
471
|
-
[:Vector3RotateByAxisAngle, :Vector3RotateByAxisAngle, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
472
|
-
|
473
|
-
# @!method Vector3MoveTowards(v, target, maxDistance)
|
474
|
-
# Vector3MoveTowards
|
475
|
-
# @param v [Vector3]
|
476
|
-
# @param target [Vector3]
|
477
|
-
# @param maxDistance [float]
|
478
|
-
# @return [Vector3]
|
479
|
-
[:Vector3MoveTowards, :Vector3MoveTowards, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
480
|
-
|
481
|
-
# @!method Vector3Lerp(v1, v2, amount)
|
482
|
-
# Vector3Lerp
|
483
|
-
# @param v1 [Vector3]
|
484
|
-
# @param v2 [Vector3]
|
485
|
-
# @param amount [float]
|
486
|
-
# @return [Vector3]
|
487
|
-
[:Vector3Lerp, :Vector3Lerp, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
488
|
-
|
489
|
-
# @!method Vector3CubicHermite(v1, tangent1, v2, tangent2, amount)
|
490
|
-
# Vector3CubicHermite
|
491
|
-
# @param v1 [Vector3]
|
492
|
-
# @param tangent1 [Vector3]
|
493
|
-
# @param v2 [Vector3]
|
494
|
-
# @param tangent2 [Vector3]
|
495
|
-
# @param amount [float]
|
496
|
-
# @return [Vector3]
|
497
|
-
[:Vector3CubicHermite, :Vector3CubicHermite, [Vector3.by_value, Vector3.by_value, Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
498
|
-
|
499
|
-
# @!method Vector3Reflect(v, normal)
|
500
|
-
# Vector3Reflect
|
501
|
-
# @param v [Vector3]
|
502
|
-
# @param normal [Vector3]
|
503
|
-
# @return [Vector3]
|
504
|
-
[:Vector3Reflect, :Vector3Reflect, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
505
|
-
|
506
|
-
# @!method Vector3Min(v1, v2)
|
507
|
-
# Vector3Min
|
508
|
-
# @param v1 [Vector3]
|
509
|
-
# @param v2 [Vector3]
|
510
|
-
# @return [Vector3]
|
511
|
-
[:Vector3Min, :Vector3Min, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
512
|
-
|
513
|
-
# @!method Vector3Max(v1, v2)
|
514
|
-
# Vector3Max
|
515
|
-
# @param v1 [Vector3]
|
516
|
-
# @param v2 [Vector3]
|
517
|
-
# @return [Vector3]
|
518
|
-
[:Vector3Max, :Vector3Max, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
519
|
-
|
520
|
-
# @!method Vector3Barycenter(p, a, b, c)
|
521
|
-
# Vector3Barycenter
|
522
|
-
# @param p [Vector3]
|
523
|
-
# @param a [Vector3]
|
524
|
-
# @param b [Vector3]
|
525
|
-
# @param c [Vector3]
|
526
|
-
# @return [Vector3]
|
527
|
-
[:Vector3Barycenter, :Vector3Barycenter, [Vector3.by_value, Vector3.by_value, Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
528
|
-
|
529
|
-
# @!method Vector3Unproject(source, projection, view)
|
530
|
-
# Vector3Unproject
|
531
|
-
# @param source [Vector3]
|
532
|
-
# @param projection [Matrix]
|
533
|
-
# @param view [Matrix]
|
534
|
-
# @return [Vector3]
|
535
|
-
[:Vector3Unproject, :Vector3Unproject, [Vector3.by_value, Matrix.by_value, Matrix.by_value], Vector3.by_value],
|
536
|
-
|
537
|
-
# @!method Vector3ToFloatV(v)
|
538
|
-
# Vector3ToFloatV
|
539
|
-
# @param v [Vector3]
|
540
|
-
# @return [float3]
|
541
|
-
[:Vector3ToFloatV, :Vector3ToFloatV, [Vector3.by_value], Float3.by_value],
|
542
|
-
|
543
|
-
# @!method Vector3Invert(v)
|
544
|
-
# Vector3Invert
|
545
|
-
# @param v [Vector3]
|
546
|
-
# @return [Vector3]
|
547
|
-
[:Vector3Invert, :Vector3Invert, [Vector3.by_value], Vector3.by_value],
|
548
|
-
|
549
|
-
# @!method Vector3Clamp(v, min, max)
|
550
|
-
# Vector3Clamp
|
551
|
-
# @param v [Vector3]
|
552
|
-
# @param min [Vector3]
|
553
|
-
# @param max [Vector3]
|
554
|
-
# @return [Vector3]
|
555
|
-
[:Vector3Clamp, :Vector3Clamp, [Vector3.by_value, Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
556
|
-
|
557
|
-
# @!method Vector3ClampValue(v, min, max)
|
558
|
-
# Vector3ClampValue
|
559
|
-
# @param v [Vector3]
|
560
|
-
# @param min [float]
|
561
|
-
# @param max [float]
|
562
|
-
# @return [Vector3]
|
563
|
-
[:Vector3ClampValue, :Vector3ClampValue, [Vector3.by_value, :float, :float], Vector3.by_value],
|
564
|
-
|
565
|
-
# @!method Vector3Equals(p, q)
|
566
|
-
# Vector3Equals
|
567
|
-
# @param p [Vector3]
|
568
|
-
# @param q [Vector3]
|
569
|
-
# @return [int]
|
570
|
-
[:Vector3Equals, :Vector3Equals, [Vector3.by_value, Vector3.by_value], :int],
|
571
|
-
|
572
|
-
# @!method Vector3Refract(v, n, r)
|
573
|
-
# Vector3Refract
|
574
|
-
# @param v [Vector3]
|
575
|
-
# @param n [Vector3]
|
576
|
-
# @param r [float]
|
577
|
-
# @return [Vector3]
|
578
|
-
[:Vector3Refract, :Vector3Refract, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
579
|
-
|
580
|
-
# @!method Vector4Zero()
|
581
|
-
# Vector4Zero
|
582
|
-
# @return [Vector4]
|
583
|
-
[:Vector4Zero, :Vector4Zero, [], Vector4.by_value],
|
584
|
-
|
585
|
-
# @!method Vector4One()
|
586
|
-
# Vector4One
|
587
|
-
# @return [Vector4]
|
588
|
-
[:Vector4One, :Vector4One, [], Vector4.by_value],
|
589
|
-
|
590
|
-
# @!method Vector4Add(v1, v2)
|
591
|
-
# Vector4Add
|
592
|
-
# @param v1 [Vector4]
|
593
|
-
# @param v2 [Vector4]
|
594
|
-
# @return [Vector4]
|
595
|
-
[:Vector4Add, :Vector4Add, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
596
|
-
|
597
|
-
# @!method Vector4AddValue(v, add)
|
598
|
-
# Vector4AddValue
|
599
|
-
# @param v [Vector4]
|
600
|
-
# @param add [float]
|
601
|
-
# @return [Vector4]
|
602
|
-
[:Vector4AddValue, :Vector4AddValue, [Vector4.by_value, :float], Vector4.by_value],
|
603
|
-
|
604
|
-
# @!method Vector4Subtract(v1, v2)
|
605
|
-
# Vector4Subtract
|
606
|
-
# @param v1 [Vector4]
|
607
|
-
# @param v2 [Vector4]
|
608
|
-
# @return [Vector4]
|
609
|
-
[:Vector4Subtract, :Vector4Subtract, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
610
|
-
|
611
|
-
# @!method Vector4SubtractValue(v, add)
|
612
|
-
# Vector4SubtractValue
|
613
|
-
# @param v [Vector4]
|
614
|
-
# @param add [float]
|
615
|
-
# @return [Vector4]
|
616
|
-
[:Vector4SubtractValue, :Vector4SubtractValue, [Vector4.by_value, :float], Vector4.by_value],
|
617
|
-
|
618
|
-
# @!method Vector4Length(v)
|
619
|
-
# Vector4Length
|
620
|
-
# @param v [Vector4]
|
621
|
-
# @return [float]
|
622
|
-
[:Vector4Length, :Vector4Length, [Vector4.by_value], :float],
|
623
|
-
|
624
|
-
# @!method Vector4LengthSqr(v)
|
625
|
-
# Vector4LengthSqr
|
626
|
-
# @param v [Vector4]
|
627
|
-
# @return [float]
|
628
|
-
[:Vector4LengthSqr, :Vector4LengthSqr, [Vector4.by_value], :float],
|
629
|
-
|
630
|
-
# @!method Vector4DotProduct(v1, v2)
|
631
|
-
# Vector4DotProduct
|
632
|
-
# @param v1 [Vector4]
|
633
|
-
# @param v2 [Vector4]
|
634
|
-
# @return [float]
|
635
|
-
[:Vector4DotProduct, :Vector4DotProduct, [Vector4.by_value, Vector4.by_value], :float],
|
636
|
-
|
637
|
-
# @!method Vector4Distance(v1, v2)
|
638
|
-
# Vector4Distance
|
639
|
-
# @param v1 [Vector4]
|
640
|
-
# @param v2 [Vector4]
|
641
|
-
# @return [float]
|
642
|
-
[:Vector4Distance, :Vector4Distance, [Vector4.by_value, Vector4.by_value], :float],
|
643
|
-
|
644
|
-
# @!method Vector4DistanceSqr(v1, v2)
|
645
|
-
# Vector4DistanceSqr
|
646
|
-
# @param v1 [Vector4]
|
647
|
-
# @param v2 [Vector4]
|
648
|
-
# @return [float]
|
649
|
-
[:Vector4DistanceSqr, :Vector4DistanceSqr, [Vector4.by_value, Vector4.by_value], :float],
|
650
|
-
|
651
|
-
# @!method Vector4Scale(v, scale)
|
652
|
-
# Vector4Scale
|
653
|
-
# @param v [Vector4]
|
654
|
-
# @param scale [float]
|
655
|
-
# @return [Vector4]
|
656
|
-
[:Vector4Scale, :Vector4Scale, [Vector4.by_value, :float], Vector4.by_value],
|
657
|
-
|
658
|
-
# @!method Vector4Multiply(v1, v2)
|
659
|
-
# Vector4Multiply
|
660
|
-
# @param v1 [Vector4]
|
661
|
-
# @param v2 [Vector4]
|
662
|
-
# @return [Vector4]
|
663
|
-
[:Vector4Multiply, :Vector4Multiply, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
664
|
-
|
665
|
-
# @!method Vector4Negate(v)
|
666
|
-
# Vector4Negate
|
667
|
-
# @param v [Vector4]
|
668
|
-
# @return [Vector4]
|
669
|
-
[:Vector4Negate, :Vector4Negate, [Vector4.by_value], Vector4.by_value],
|
670
|
-
|
671
|
-
# @!method Vector4Divide(v1, v2)
|
672
|
-
# Vector4Divide
|
673
|
-
# @param v1 [Vector4]
|
674
|
-
# @param v2 [Vector4]
|
675
|
-
# @return [Vector4]
|
676
|
-
[:Vector4Divide, :Vector4Divide, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
677
|
-
|
678
|
-
# @!method Vector4Normalize(v)
|
679
|
-
# Vector4Normalize
|
680
|
-
# @param v [Vector4]
|
681
|
-
# @return [Vector4]
|
682
|
-
[:Vector4Normalize, :Vector4Normalize, [Vector4.by_value], Vector4.by_value],
|
683
|
-
|
684
|
-
# @!method Vector4Min(v1, v2)
|
685
|
-
# Vector4Min
|
686
|
-
# @param v1 [Vector4]
|
687
|
-
# @param v2 [Vector4]
|
688
|
-
# @return [Vector4]
|
689
|
-
[:Vector4Min, :Vector4Min, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
690
|
-
|
691
|
-
# @!method Vector4Max(v1, v2)
|
692
|
-
# Vector4Max
|
693
|
-
# @param v1 [Vector4]
|
694
|
-
# @param v2 [Vector4]
|
695
|
-
# @return [Vector4]
|
696
|
-
[:Vector4Max, :Vector4Max, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
697
|
-
|
698
|
-
# @!method Vector4Lerp(v1, v2, amount)
|
699
|
-
# Vector4Lerp
|
700
|
-
# @param v1 [Vector4]
|
701
|
-
# @param v2 [Vector4]
|
702
|
-
# @param amount [float]
|
703
|
-
# @return [Vector4]
|
704
|
-
[:Vector4Lerp, :Vector4Lerp, [Vector4.by_value, Vector4.by_value, :float], Vector4.by_value],
|
705
|
-
|
706
|
-
# @!method Vector4MoveTowards(v, target, maxDistance)
|
707
|
-
# Vector4MoveTowards
|
708
|
-
# @param v [Vector4]
|
709
|
-
# @param target [Vector4]
|
710
|
-
# @param maxDistance [float]
|
711
|
-
# @return [Vector4]
|
712
|
-
[:Vector4MoveTowards, :Vector4MoveTowards, [Vector4.by_value, Vector4.by_value, :float], Vector4.by_value],
|
713
|
-
|
714
|
-
# @!method Vector4Invert(v)
|
715
|
-
# Vector4Invert
|
716
|
-
# @param v [Vector4]
|
717
|
-
# @return [Vector4]
|
718
|
-
[:Vector4Invert, :Vector4Invert, [Vector4.by_value], Vector4.by_value],
|
719
|
-
|
720
|
-
# @!method Vector4Equals(p, q)
|
721
|
-
# Vector4Equals
|
722
|
-
# @param p [Vector4]
|
723
|
-
# @param q [Vector4]
|
724
|
-
# @return [int]
|
725
|
-
[:Vector4Equals, :Vector4Equals, [Vector4.by_value, Vector4.by_value], :int],
|
726
|
-
|
727
|
-
# @!method MatrixDeterminant(mat)
|
728
|
-
# MatrixDeterminant
|
729
|
-
# @param mat [Matrix]
|
730
|
-
# @return [float]
|
731
|
-
[:MatrixDeterminant, :MatrixDeterminant, [Matrix.by_value], :float],
|
732
|
-
|
733
|
-
# @!method MatrixTrace(mat)
|
734
|
-
# MatrixTrace
|
735
|
-
# @param mat [Matrix]
|
736
|
-
# @return [float]
|
737
|
-
[:MatrixTrace, :MatrixTrace, [Matrix.by_value], :float],
|
738
|
-
|
739
|
-
# @!method MatrixTranspose(mat)
|
740
|
-
# MatrixTranspose
|
741
|
-
# @param mat [Matrix]
|
742
|
-
# @return [Matrix]
|
743
|
-
[:MatrixTranspose, :MatrixTranspose, [Matrix.by_value], Matrix.by_value],
|
744
|
-
|
745
|
-
# @!method MatrixInvert(mat)
|
746
|
-
# MatrixInvert
|
747
|
-
# @param mat [Matrix]
|
748
|
-
# @return [Matrix]
|
749
|
-
[:MatrixInvert, :MatrixInvert, [Matrix.by_value], Matrix.by_value],
|
750
|
-
|
751
|
-
# @!method MatrixIdentity()
|
752
|
-
# MatrixIdentity
|
753
|
-
# @return [Matrix]
|
754
|
-
[:MatrixIdentity, :MatrixIdentity, [], Matrix.by_value],
|
755
|
-
|
756
|
-
# @!method MatrixAdd(left, right)
|
757
|
-
# MatrixAdd
|
758
|
-
# @param left [Matrix]
|
759
|
-
# @param right [Matrix]
|
760
|
-
# @return [Matrix]
|
761
|
-
[:MatrixAdd, :MatrixAdd, [Matrix.by_value, Matrix.by_value], Matrix.by_value],
|
762
|
-
|
763
|
-
# @!method MatrixSubtract(left, right)
|
764
|
-
# MatrixSubtract
|
765
|
-
# @param left [Matrix]
|
766
|
-
# @param right [Matrix]
|
767
|
-
# @return [Matrix]
|
768
|
-
[:MatrixSubtract, :MatrixSubtract, [Matrix.by_value, Matrix.by_value], Matrix.by_value],
|
769
|
-
|
770
|
-
# @!method MatrixMultiply(left, right)
|
771
|
-
# MatrixMultiply
|
772
|
-
# @param left [Matrix]
|
773
|
-
# @param right [Matrix]
|
774
|
-
# @return [Matrix]
|
775
|
-
[:MatrixMultiply, :MatrixMultiply, [Matrix.by_value, Matrix.by_value], Matrix.by_value],
|
776
|
-
|
777
|
-
# @!method MatrixTranslate(x, y, z)
|
778
|
-
# MatrixTranslate
|
779
|
-
# @param x [float]
|
780
|
-
# @param y [float]
|
781
|
-
# @param z [float]
|
782
|
-
# @return [Matrix]
|
783
|
-
[:MatrixTranslate, :MatrixTranslate, [:float, :float, :float], Matrix.by_value],
|
784
|
-
|
785
|
-
# @!method MatrixRotate(axis, angle)
|
786
|
-
# MatrixRotate
|
787
|
-
# @param axis [Vector3]
|
788
|
-
# @param angle [float]
|
789
|
-
# @return [Matrix]
|
790
|
-
[:MatrixRotate, :MatrixRotate, [Vector3.by_value, :float], Matrix.by_value],
|
791
|
-
|
792
|
-
# @!method MatrixRotateX(angle)
|
793
|
-
# MatrixRotateX
|
794
|
-
# @param angle [float]
|
795
|
-
# @return [Matrix]
|
796
|
-
[:MatrixRotateX, :MatrixRotateX, [:float], Matrix.by_value],
|
797
|
-
|
798
|
-
# @!method MatrixRotateY(angle)
|
799
|
-
# MatrixRotateY
|
800
|
-
# @param angle [float]
|
801
|
-
# @return [Matrix]
|
802
|
-
[:MatrixRotateY, :MatrixRotateY, [:float], Matrix.by_value],
|
803
|
-
|
804
|
-
# @!method MatrixRotateZ(angle)
|
805
|
-
# MatrixRotateZ
|
806
|
-
# @param angle [float]
|
807
|
-
# @return [Matrix]
|
808
|
-
[:MatrixRotateZ, :MatrixRotateZ, [:float], Matrix.by_value],
|
809
|
-
|
810
|
-
# @!method MatrixRotateXYZ(angle)
|
811
|
-
# MatrixRotateXYZ
|
812
|
-
# @param angle [Vector3]
|
813
|
-
# @return [Matrix]
|
814
|
-
[:MatrixRotateXYZ, :MatrixRotateXYZ, [Vector3.by_value], Matrix.by_value],
|
815
|
-
|
816
|
-
# @!method MatrixRotateZYX(angle)
|
817
|
-
# MatrixRotateZYX
|
818
|
-
# @param angle [Vector3]
|
819
|
-
# @return [Matrix]
|
820
|
-
[:MatrixRotateZYX, :MatrixRotateZYX, [Vector3.by_value], Matrix.by_value],
|
821
|
-
|
822
|
-
# @!method MatrixScale(x, y, z)
|
823
|
-
# MatrixScale
|
824
|
-
# @param x [float]
|
825
|
-
# @param y [float]
|
826
|
-
# @param z [float]
|
827
|
-
# @return [Matrix]
|
828
|
-
[:MatrixScale, :MatrixScale, [:float, :float, :float], Matrix.by_value],
|
829
|
-
|
830
|
-
# @!method MatrixFrustum(left, right, bottom, top, nearPlane, farPlane)
|
831
|
-
# MatrixFrustum
|
832
|
-
# @param left [double]
|
833
|
-
# @param right [double]
|
834
|
-
# @param bottom [double]
|
835
|
-
# @param top [double]
|
836
|
-
# @param nearPlane [double]
|
837
|
-
# @param farPlane [double]
|
838
|
-
# @return [Matrix]
|
839
|
-
[:MatrixFrustum, :MatrixFrustum, [:double, :double, :double, :double, :double, :double], Matrix.by_value],
|
840
|
-
|
841
|
-
# @!method MatrixPerspective(fovY, aspect, nearPlane, farPlane)
|
842
|
-
# MatrixPerspective
|
843
|
-
# @param fovY [double]
|
844
|
-
# @param aspect [double]
|
845
|
-
# @param nearPlane [double]
|
846
|
-
# @param farPlane [double]
|
847
|
-
# @return [Matrix]
|
848
|
-
[:MatrixPerspective, :MatrixPerspective, [:double, :double, :double, :double], Matrix.by_value],
|
849
|
-
|
850
|
-
# @!method MatrixOrtho(left, right, bottom, top, nearPlane, farPlane)
|
851
|
-
# MatrixOrtho
|
852
|
-
# @param left [double]
|
853
|
-
# @param right [double]
|
854
|
-
# @param bottom [double]
|
855
|
-
# @param top [double]
|
856
|
-
# @param nearPlane [double]
|
857
|
-
# @param farPlane [double]
|
858
|
-
# @return [Matrix]
|
859
|
-
[:MatrixOrtho, :MatrixOrtho, [:double, :double, :double, :double, :double, :double], Matrix.by_value],
|
860
|
-
|
861
|
-
# @!method MatrixLookAt(eye, target, up)
|
862
|
-
# MatrixLookAt
|
863
|
-
# @param eye [Vector3]
|
864
|
-
# @param target [Vector3]
|
865
|
-
# @param up [Vector3]
|
866
|
-
# @return [Matrix]
|
867
|
-
[:MatrixLookAt, :MatrixLookAt, [Vector3.by_value, Vector3.by_value, Vector3.by_value], Matrix.by_value],
|
868
|
-
|
869
|
-
# @!method MatrixToFloatV(mat)
|
870
|
-
# MatrixToFloatV
|
871
|
-
# @param mat [Matrix]
|
872
|
-
# @return [float16]
|
873
|
-
[:MatrixToFloatV, :MatrixToFloatV, [Matrix.by_value], Float16.by_value],
|
874
|
-
|
875
|
-
# @!method QuaternionAdd(q1, q2)
|
876
|
-
# QuaternionAdd
|
877
|
-
# @param q1 [Quaternion]
|
878
|
-
# @param q2 [Quaternion]
|
879
|
-
# @return [Quaternion]
|
880
|
-
[:QuaternionAdd, :QuaternionAdd, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
881
|
-
|
882
|
-
# @!method QuaternionAddValue(q, add)
|
883
|
-
# QuaternionAddValue
|
884
|
-
# @param q [Quaternion]
|
885
|
-
# @param add [float]
|
886
|
-
# @return [Quaternion]
|
887
|
-
[:QuaternionAddValue, :QuaternionAddValue, [Quaternion.by_value, :float], Quaternion.by_value],
|
888
|
-
|
889
|
-
# @!method QuaternionSubtract(q1, q2)
|
890
|
-
# QuaternionSubtract
|
891
|
-
# @param q1 [Quaternion]
|
892
|
-
# @param q2 [Quaternion]
|
893
|
-
# @return [Quaternion]
|
894
|
-
[:QuaternionSubtract, :QuaternionSubtract, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
895
|
-
|
896
|
-
# @!method QuaternionSubtractValue(q, sub)
|
897
|
-
# QuaternionSubtractValue
|
898
|
-
# @param q [Quaternion]
|
899
|
-
# @param sub [float]
|
900
|
-
# @return [Quaternion]
|
901
|
-
[:QuaternionSubtractValue, :QuaternionSubtractValue, [Quaternion.by_value, :float], Quaternion.by_value],
|
902
|
-
|
903
|
-
# @!method QuaternionIdentity()
|
904
|
-
# QuaternionIdentity
|
905
|
-
# @return [Quaternion]
|
906
|
-
[:QuaternionIdentity, :QuaternionIdentity, [], Quaternion.by_value],
|
907
|
-
|
908
|
-
# @!method QuaternionLength(q)
|
909
|
-
# QuaternionLength
|
910
|
-
# @param q [Quaternion]
|
911
|
-
# @return [float]
|
912
|
-
[:QuaternionLength, :QuaternionLength, [Quaternion.by_value], :float],
|
913
|
-
|
914
|
-
# @!method QuaternionNormalize(q)
|
915
|
-
# QuaternionNormalize
|
916
|
-
# @param q [Quaternion]
|
917
|
-
# @return [Quaternion]
|
918
|
-
[:QuaternionNormalize, :QuaternionNormalize, [Quaternion.by_value], Quaternion.by_value],
|
919
|
-
|
920
|
-
# @!method QuaternionInvert(q)
|
921
|
-
# QuaternionInvert
|
922
|
-
# @param q [Quaternion]
|
923
|
-
# @return [Quaternion]
|
924
|
-
[:QuaternionInvert, :QuaternionInvert, [Quaternion.by_value], Quaternion.by_value],
|
925
|
-
|
926
|
-
# @!method QuaternionMultiply(q1, q2)
|
927
|
-
# QuaternionMultiply
|
928
|
-
# @param q1 [Quaternion]
|
929
|
-
# @param q2 [Quaternion]
|
930
|
-
# @return [Quaternion]
|
931
|
-
[:QuaternionMultiply, :QuaternionMultiply, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
932
|
-
|
933
|
-
# @!method QuaternionScale(q, mul)
|
934
|
-
# QuaternionScale
|
935
|
-
# @param q [Quaternion]
|
936
|
-
# @param mul [float]
|
937
|
-
# @return [Quaternion]
|
938
|
-
[:QuaternionScale, :QuaternionScale, [Quaternion.by_value, :float], Quaternion.by_value],
|
939
|
-
|
940
|
-
# @!method QuaternionDivide(q1, q2)
|
941
|
-
# QuaternionDivide
|
942
|
-
# @param q1 [Quaternion]
|
943
|
-
# @param q2 [Quaternion]
|
944
|
-
# @return [Quaternion]
|
945
|
-
[:QuaternionDivide, :QuaternionDivide, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
946
|
-
|
947
|
-
# @!method QuaternionLerp(q1, q2, amount)
|
948
|
-
# QuaternionLerp
|
949
|
-
# @param q1 [Quaternion]
|
950
|
-
# @param q2 [Quaternion]
|
951
|
-
# @param amount [float]
|
952
|
-
# @return [Quaternion]
|
953
|
-
[:QuaternionLerp, :QuaternionLerp, [Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
954
|
-
|
955
|
-
# @!method QuaternionNlerp(q1, q2, amount)
|
956
|
-
# QuaternionNlerp
|
957
|
-
# @param q1 [Quaternion]
|
958
|
-
# @param q2 [Quaternion]
|
959
|
-
# @param amount [float]
|
960
|
-
# @return [Quaternion]
|
961
|
-
[:QuaternionNlerp, :QuaternionNlerp, [Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
962
|
-
|
963
|
-
# @!method QuaternionSlerp(q1, q2, amount)
|
964
|
-
# QuaternionSlerp
|
965
|
-
# @param q1 [Quaternion]
|
966
|
-
# @param q2 [Quaternion]
|
967
|
-
# @param amount [float]
|
968
|
-
# @return [Quaternion]
|
969
|
-
[:QuaternionSlerp, :QuaternionSlerp, [Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
970
|
-
|
971
|
-
# @!method QuaternionCubicHermiteSpline(q1, outTangent1, q2, inTangent2, t)
|
972
|
-
# QuaternionCubicHermiteSpline
|
973
|
-
# @param q1 [Quaternion]
|
974
|
-
# @param outTangent1 [Quaternion]
|
975
|
-
# @param q2 [Quaternion]
|
976
|
-
# @param inTangent2 [Quaternion]
|
977
|
-
# @param t [float]
|
978
|
-
# @return [Quaternion]
|
979
|
-
[:QuaternionCubicHermiteSpline, :QuaternionCubicHermiteSpline, [Quaternion.by_value, Quaternion.by_value, Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
980
|
-
|
981
|
-
# @!method QuaternionFromVector3ToVector3(from, to)
|
982
|
-
# QuaternionFromVector3ToVector3
|
983
|
-
# @param from [Vector3]
|
984
|
-
# @param to [Vector3]
|
985
|
-
# @return [Quaternion]
|
986
|
-
[:QuaternionFromVector3ToVector3, :QuaternionFromVector3ToVector3, [Vector3.by_value, Vector3.by_value], Quaternion.by_value],
|
987
|
-
|
988
|
-
# @!method QuaternionFromMatrix(mat)
|
989
|
-
# QuaternionFromMatrix
|
990
|
-
# @param mat [Matrix]
|
991
|
-
# @return [Quaternion]
|
992
|
-
[:QuaternionFromMatrix, :QuaternionFromMatrix, [Matrix.by_value], Quaternion.by_value],
|
993
|
-
|
994
|
-
# @!method QuaternionToMatrix(q)
|
995
|
-
# QuaternionToMatrix
|
996
|
-
# @param q [Quaternion]
|
997
|
-
# @return [Matrix]
|
998
|
-
[:QuaternionToMatrix, :QuaternionToMatrix, [Quaternion.by_value], Matrix.by_value],
|
999
|
-
|
1000
|
-
# @!method QuaternionFromAxisAngle(axis, angle)
|
1001
|
-
# QuaternionFromAxisAngle
|
1002
|
-
# @param axis [Vector3]
|
1003
|
-
# @param angle [float]
|
1004
|
-
# @return [Quaternion]
|
1005
|
-
[:QuaternionFromAxisAngle, :QuaternionFromAxisAngle, [Vector3.by_value, :float], Quaternion.by_value],
|
1006
|
-
|
1007
|
-
# @!method QuaternionToAxisAngle(q, outAxis, outAngle)
|
1008
|
-
# QuaternionToAxisAngle
|
1009
|
-
# @param q [Quaternion]
|
1010
|
-
# @param outAxis [Vector3 *]
|
1011
|
-
# @param outAngle [float *]
|
1012
|
-
# @return [void]
|
1013
|
-
[:QuaternionToAxisAngle, :QuaternionToAxisAngle, [Quaternion.by_value, :pointer, :pointer], :void],
|
1014
|
-
|
1015
|
-
# @!method QuaternionFromEuler(pitch, yaw, roll)
|
1016
|
-
# QuaternionFromEuler
|
1017
|
-
# @param pitch [float]
|
1018
|
-
# @param yaw [float]
|
1019
|
-
# @param roll [float]
|
1020
|
-
# @return [Quaternion]
|
1021
|
-
[:QuaternionFromEuler, :QuaternionFromEuler, [:float, :float, :float], Quaternion.by_value],
|
1022
|
-
|
1023
|
-
# @!method QuaternionToEuler(q)
|
1024
|
-
# QuaternionToEuler
|
1025
|
-
# @param q [Quaternion]
|
1026
|
-
# @return [Vector3]
|
1027
|
-
[:QuaternionToEuler, :QuaternionToEuler, [Quaternion.by_value], Vector3.by_value],
|
1028
|
-
|
1029
|
-
# @!method QuaternionTransform(q, mat)
|
1030
|
-
# QuaternionTransform
|
1031
|
-
# @param q [Quaternion]
|
1032
|
-
# @param mat [Matrix]
|
1033
|
-
# @return [Quaternion]
|
1034
|
-
[:QuaternionTransform, :QuaternionTransform, [Quaternion.by_value, Matrix.by_value], Quaternion.by_value],
|
1035
|
-
|
1036
|
-
# @!method QuaternionEquals(p, q)
|
1037
|
-
# QuaternionEquals
|
1038
|
-
# @param p [Quaternion]
|
1039
|
-
# @param q [Quaternion]
|
1040
|
-
# @return [int]
|
1041
|
-
[:QuaternionEquals, :QuaternionEquals, [Quaternion.by_value, Quaternion.by_value], :int],
|
1042
|
-
|
1043
|
-
# @!method MatrixDecompose(mat, translation, rotation, scale)
|
1044
|
-
# MatrixDecompose
|
1045
|
-
# @param mat [Matrix]
|
1046
|
-
# @param translation [Vector3 *]
|
1047
|
-
# @param rotation [Quaternion *]
|
1048
|
-
# @param scale [Vector3 *]
|
1049
|
-
# @return [void]
|
1050
|
-
[:MatrixDecompose, :MatrixDecompose, [Matrix.by_value, :pointer, :pointer, :pointer], :void],
|
1051
|
-
]
|
1052
|
-
entries.each do |entry|
|
1053
|
-
api_name = if method_naming == :snake_case
|
1054
|
-
snake_case_name = entry[0].to_s.gsub(/([A-Z]+)([A-Z0-9][a-z])/, '\1_\2').gsub(/([a-z\d])([A-Z0-9])/, '\1_\2').downcase
|
1055
|
-
snake_case_name.gsub!('vector_3', 'vector3_') if snake_case_name.include?('vector_3')
|
1056
|
-
snake_case_name.gsub!('vector_2', 'vector2_') if snake_case_name.include?('vector_2')
|
1057
|
-
snake_case_name.chop! if snake_case_name.end_with?('_')
|
1058
|
-
snake_case_name.to_sym
|
1059
|
-
else
|
1060
|
-
entry[0]
|
1061
|
-
end
|
1062
|
-
attach_function api_name, entry[1], entry[2], entry[3]
|
1063
|
-
rescue FFI::NotFoundError => e
|
1064
|
-
warn "[Warning] Failed to import #{entry[0]} (#{e})."
|
1065
|
-
end
|
1066
|
-
end
|
1067
|
-
end
|
1
|
+
# Yet another raylib wrapper for Ruby
|
2
|
+
#
|
3
|
+
# * https://github.com/vaiorabbit/raylib-bindings
|
4
|
+
#
|
5
|
+
# [NOTICE] Autogenerated. Do not edit.
|
6
|
+
|
7
|
+
require 'ffi'
|
8
|
+
|
9
|
+
module Raylib
|
10
|
+
extend FFI::Library
|
11
|
+
|
12
|
+
# Define/Macro
|
13
|
+
|
14
|
+
EPSILON = 0.000001
|
15
|
+
|
16
|
+
# Typedef
|
17
|
+
|
18
|
+
|
19
|
+
# Struct
|
20
|
+
|
21
|
+
# NOTE: Helper types to be used instead of array return types for *ToFloat functions
|
22
|
+
class Float3 < FFI::Struct
|
23
|
+
layout(
|
24
|
+
:v, [:float, 3],
|
25
|
+
)
|
26
|
+
def v = self[:v]
|
27
|
+
def v=(v) self[:v] = v end
|
28
|
+
end
|
29
|
+
|
30
|
+
class Float16 < FFI::Struct
|
31
|
+
layout(
|
32
|
+
:v, [:float, 16],
|
33
|
+
)
|
34
|
+
def v = self[:v]
|
35
|
+
def v=(v) self[:v] = v end
|
36
|
+
end
|
37
|
+
|
38
|
+
|
39
|
+
# Function
|
40
|
+
|
41
|
+
def self.setup_raymath_symbols(method_naming: :original)
|
42
|
+
entries = [
|
43
|
+
|
44
|
+
# @!method Clamp(value, min, max)
|
45
|
+
# Clamp
|
46
|
+
# @param value [float]
|
47
|
+
# @param min [float]
|
48
|
+
# @param max [float]
|
49
|
+
# @return [float]
|
50
|
+
[:Clamp, :Clamp, [:float, :float, :float], :float],
|
51
|
+
|
52
|
+
# @!method Lerp(start, end, amount)
|
53
|
+
# Lerp
|
54
|
+
# @param start [float]
|
55
|
+
# @param end [float]
|
56
|
+
# @param amount [float]
|
57
|
+
# @return [float]
|
58
|
+
[:Lerp, :Lerp, [:float, :float, :float], :float],
|
59
|
+
|
60
|
+
# @!method Normalize(value, start, end)
|
61
|
+
# Normalize
|
62
|
+
# @param value [float]
|
63
|
+
# @param start [float]
|
64
|
+
# @param end [float]
|
65
|
+
# @return [float]
|
66
|
+
[:Normalize, :Normalize, [:float, :float, :float], :float],
|
67
|
+
|
68
|
+
# @!method Remap(value, inputStart, inputEnd, outputStart, outputEnd)
|
69
|
+
# Remap
|
70
|
+
# @param value [float]
|
71
|
+
# @param inputStart [float]
|
72
|
+
# @param inputEnd [float]
|
73
|
+
# @param outputStart [float]
|
74
|
+
# @param outputEnd [float]
|
75
|
+
# @return [float]
|
76
|
+
[:Remap, :Remap, [:float, :float, :float, :float, :float], :float],
|
77
|
+
|
78
|
+
# @!method Wrap(value, min, max)
|
79
|
+
# Wrap
|
80
|
+
# @param value [float]
|
81
|
+
# @param min [float]
|
82
|
+
# @param max [float]
|
83
|
+
# @return [float]
|
84
|
+
[:Wrap, :Wrap, [:float, :float, :float], :float],
|
85
|
+
|
86
|
+
# @!method FloatEquals(x, y)
|
87
|
+
# FloatEquals
|
88
|
+
# @param x [float]
|
89
|
+
# @param y [float]
|
90
|
+
# @return [int]
|
91
|
+
[:FloatEquals, :FloatEquals, [:float, :float], :int],
|
92
|
+
|
93
|
+
# @!method Vector2Zero()
|
94
|
+
# Vector2Zero
|
95
|
+
# @return [Vector2]
|
96
|
+
[:Vector2Zero, :Vector2Zero, [], Vector2.by_value],
|
97
|
+
|
98
|
+
# @!method Vector2One()
|
99
|
+
# Vector2One
|
100
|
+
# @return [Vector2]
|
101
|
+
[:Vector2One, :Vector2One, [], Vector2.by_value],
|
102
|
+
|
103
|
+
# @!method Vector2Add(v1, v2)
|
104
|
+
# Vector2Add
|
105
|
+
# @param v1 [Vector2]
|
106
|
+
# @param v2 [Vector2]
|
107
|
+
# @return [Vector2]
|
108
|
+
[:Vector2Add, :Vector2Add, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
109
|
+
|
110
|
+
# @!method Vector2AddValue(v, add)
|
111
|
+
# Vector2AddValue
|
112
|
+
# @param v [Vector2]
|
113
|
+
# @param add [float]
|
114
|
+
# @return [Vector2]
|
115
|
+
[:Vector2AddValue, :Vector2AddValue, [Vector2.by_value, :float], Vector2.by_value],
|
116
|
+
|
117
|
+
# @!method Vector2Subtract(v1, v2)
|
118
|
+
# Vector2Subtract
|
119
|
+
# @param v1 [Vector2]
|
120
|
+
# @param v2 [Vector2]
|
121
|
+
# @return [Vector2]
|
122
|
+
[:Vector2Subtract, :Vector2Subtract, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
123
|
+
|
124
|
+
# @!method Vector2SubtractValue(v, sub)
|
125
|
+
# Vector2SubtractValue
|
126
|
+
# @param v [Vector2]
|
127
|
+
# @param sub [float]
|
128
|
+
# @return [Vector2]
|
129
|
+
[:Vector2SubtractValue, :Vector2SubtractValue, [Vector2.by_value, :float], Vector2.by_value],
|
130
|
+
|
131
|
+
# @!method Vector2Length(v)
|
132
|
+
# Vector2Length
|
133
|
+
# @param v [Vector2]
|
134
|
+
# @return [float]
|
135
|
+
[:Vector2Length, :Vector2Length, [Vector2.by_value], :float],
|
136
|
+
|
137
|
+
# @!method Vector2LengthSqr(v)
|
138
|
+
# Vector2LengthSqr
|
139
|
+
# @param v [Vector2]
|
140
|
+
# @return [float]
|
141
|
+
[:Vector2LengthSqr, :Vector2LengthSqr, [Vector2.by_value], :float],
|
142
|
+
|
143
|
+
# @!method Vector2DotProduct(v1, v2)
|
144
|
+
# Vector2DotProduct
|
145
|
+
# @param v1 [Vector2]
|
146
|
+
# @param v2 [Vector2]
|
147
|
+
# @return [float]
|
148
|
+
[:Vector2DotProduct, :Vector2DotProduct, [Vector2.by_value, Vector2.by_value], :float],
|
149
|
+
|
150
|
+
# @!method Vector2CrossProduct(v1, v2)
|
151
|
+
# Vector2CrossProduct
|
152
|
+
# @param v1 [Vector2]
|
153
|
+
# @param v2 [Vector2]
|
154
|
+
# @return [float]
|
155
|
+
[:Vector2CrossProduct, :Vector2CrossProduct, [Vector2.by_value, Vector2.by_value], :float],
|
156
|
+
|
157
|
+
# @!method Vector2Distance(v1, v2)
|
158
|
+
# Vector2Distance
|
159
|
+
# @param v1 [Vector2]
|
160
|
+
# @param v2 [Vector2]
|
161
|
+
# @return [float]
|
162
|
+
[:Vector2Distance, :Vector2Distance, [Vector2.by_value, Vector2.by_value], :float],
|
163
|
+
|
164
|
+
# @!method Vector2DistanceSqr(v1, v2)
|
165
|
+
# Vector2DistanceSqr
|
166
|
+
# @param v1 [Vector2]
|
167
|
+
# @param v2 [Vector2]
|
168
|
+
# @return [float]
|
169
|
+
[:Vector2DistanceSqr, :Vector2DistanceSqr, [Vector2.by_value, Vector2.by_value], :float],
|
170
|
+
|
171
|
+
# @!method Vector2Angle(v1, v2)
|
172
|
+
# Vector2Angle
|
173
|
+
# @param v1 [Vector2]
|
174
|
+
# @param v2 [Vector2]
|
175
|
+
# @return [float]
|
176
|
+
[:Vector2Angle, :Vector2Angle, [Vector2.by_value, Vector2.by_value], :float],
|
177
|
+
|
178
|
+
# @!method Vector2LineAngle(start, end)
|
179
|
+
# Vector2LineAngle
|
180
|
+
# @param start [Vector2]
|
181
|
+
# @param end [Vector2]
|
182
|
+
# @return [float]
|
183
|
+
[:Vector2LineAngle, :Vector2LineAngle, [Vector2.by_value, Vector2.by_value], :float],
|
184
|
+
|
185
|
+
# @!method Vector2Scale(v, scale)
|
186
|
+
# Vector2Scale
|
187
|
+
# @param v [Vector2]
|
188
|
+
# @param scale [float]
|
189
|
+
# @return [Vector2]
|
190
|
+
[:Vector2Scale, :Vector2Scale, [Vector2.by_value, :float], Vector2.by_value],
|
191
|
+
|
192
|
+
# @!method Vector2Multiply(v1, v2)
|
193
|
+
# Vector2Multiply
|
194
|
+
# @param v1 [Vector2]
|
195
|
+
# @param v2 [Vector2]
|
196
|
+
# @return [Vector2]
|
197
|
+
[:Vector2Multiply, :Vector2Multiply, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
198
|
+
|
199
|
+
# @!method Vector2Negate(v)
|
200
|
+
# Vector2Negate
|
201
|
+
# @param v [Vector2]
|
202
|
+
# @return [Vector2]
|
203
|
+
[:Vector2Negate, :Vector2Negate, [Vector2.by_value], Vector2.by_value],
|
204
|
+
|
205
|
+
# @!method Vector2Divide(v1, v2)
|
206
|
+
# Vector2Divide
|
207
|
+
# @param v1 [Vector2]
|
208
|
+
# @param v2 [Vector2]
|
209
|
+
# @return [Vector2]
|
210
|
+
[:Vector2Divide, :Vector2Divide, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
211
|
+
|
212
|
+
# @!method Vector2Normalize(v)
|
213
|
+
# Vector2Normalize
|
214
|
+
# @param v [Vector2]
|
215
|
+
# @return [Vector2]
|
216
|
+
[:Vector2Normalize, :Vector2Normalize, [Vector2.by_value], Vector2.by_value],
|
217
|
+
|
218
|
+
# @!method Vector2Transform(v, mat)
|
219
|
+
# Vector2Transform
|
220
|
+
# @param v [Vector2]
|
221
|
+
# @param mat [Matrix]
|
222
|
+
# @return [Vector2]
|
223
|
+
[:Vector2Transform, :Vector2Transform, [Vector2.by_value, Matrix.by_value], Vector2.by_value],
|
224
|
+
|
225
|
+
# @!method Vector2Lerp(v1, v2, amount)
|
226
|
+
# Vector2Lerp
|
227
|
+
# @param v1 [Vector2]
|
228
|
+
# @param v2 [Vector2]
|
229
|
+
# @param amount [float]
|
230
|
+
# @return [Vector2]
|
231
|
+
[:Vector2Lerp, :Vector2Lerp, [Vector2.by_value, Vector2.by_value, :float], Vector2.by_value],
|
232
|
+
|
233
|
+
# @!method Vector2Reflect(v, normal)
|
234
|
+
# Vector2Reflect
|
235
|
+
# @param v [Vector2]
|
236
|
+
# @param normal [Vector2]
|
237
|
+
# @return [Vector2]
|
238
|
+
[:Vector2Reflect, :Vector2Reflect, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
239
|
+
|
240
|
+
# @!method Vector2Min(v1, v2)
|
241
|
+
# Vector2Min
|
242
|
+
# @param v1 [Vector2]
|
243
|
+
# @param v2 [Vector2]
|
244
|
+
# @return [Vector2]
|
245
|
+
[:Vector2Min, :Vector2Min, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
246
|
+
|
247
|
+
# @!method Vector2Max(v1, v2)
|
248
|
+
# Vector2Max
|
249
|
+
# @param v1 [Vector2]
|
250
|
+
# @param v2 [Vector2]
|
251
|
+
# @return [Vector2]
|
252
|
+
[:Vector2Max, :Vector2Max, [Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
253
|
+
|
254
|
+
# @!method Vector2Rotate(v, angle)
|
255
|
+
# Vector2Rotate
|
256
|
+
# @param v [Vector2]
|
257
|
+
# @param angle [float]
|
258
|
+
# @return [Vector2]
|
259
|
+
[:Vector2Rotate, :Vector2Rotate, [Vector2.by_value, :float], Vector2.by_value],
|
260
|
+
|
261
|
+
# @!method Vector2MoveTowards(v, target, maxDistance)
|
262
|
+
# Vector2MoveTowards
|
263
|
+
# @param v [Vector2]
|
264
|
+
# @param target [Vector2]
|
265
|
+
# @param maxDistance [float]
|
266
|
+
# @return [Vector2]
|
267
|
+
[:Vector2MoveTowards, :Vector2MoveTowards, [Vector2.by_value, Vector2.by_value, :float], Vector2.by_value],
|
268
|
+
|
269
|
+
# @!method Vector2Invert(v)
|
270
|
+
# Vector2Invert
|
271
|
+
# @param v [Vector2]
|
272
|
+
# @return [Vector2]
|
273
|
+
[:Vector2Invert, :Vector2Invert, [Vector2.by_value], Vector2.by_value],
|
274
|
+
|
275
|
+
# @!method Vector2Clamp(v, min, max)
|
276
|
+
# Vector2Clamp
|
277
|
+
# @param v [Vector2]
|
278
|
+
# @param min [Vector2]
|
279
|
+
# @param max [Vector2]
|
280
|
+
# @return [Vector2]
|
281
|
+
[:Vector2Clamp, :Vector2Clamp, [Vector2.by_value, Vector2.by_value, Vector2.by_value], Vector2.by_value],
|
282
|
+
|
283
|
+
# @!method Vector2ClampValue(v, min, max)
|
284
|
+
# Vector2ClampValue
|
285
|
+
# @param v [Vector2]
|
286
|
+
# @param min [float]
|
287
|
+
# @param max [float]
|
288
|
+
# @return [Vector2]
|
289
|
+
[:Vector2ClampValue, :Vector2ClampValue, [Vector2.by_value, :float, :float], Vector2.by_value],
|
290
|
+
|
291
|
+
# @!method Vector2Equals(p, q)
|
292
|
+
# Vector2Equals
|
293
|
+
# @param p [Vector2]
|
294
|
+
# @param q [Vector2]
|
295
|
+
# @return [int]
|
296
|
+
[:Vector2Equals, :Vector2Equals, [Vector2.by_value, Vector2.by_value], :int],
|
297
|
+
|
298
|
+
# @!method Vector2Refract(v, n, r)
|
299
|
+
# Vector2Refract
|
300
|
+
# @param v [Vector2]
|
301
|
+
# @param n [Vector2]
|
302
|
+
# @param r [float]
|
303
|
+
# @return [Vector2]
|
304
|
+
[:Vector2Refract, :Vector2Refract, [Vector2.by_value, Vector2.by_value, :float], Vector2.by_value],
|
305
|
+
|
306
|
+
# @!method Vector3Zero()
|
307
|
+
# Vector3Zero
|
308
|
+
# @return [Vector3]
|
309
|
+
[:Vector3Zero, :Vector3Zero, [], Vector3.by_value],
|
310
|
+
|
311
|
+
# @!method Vector3One()
|
312
|
+
# Vector3One
|
313
|
+
# @return [Vector3]
|
314
|
+
[:Vector3One, :Vector3One, [], Vector3.by_value],
|
315
|
+
|
316
|
+
# @!method Vector3Add(v1, v2)
|
317
|
+
# Vector3Add
|
318
|
+
# @param v1 [Vector3]
|
319
|
+
# @param v2 [Vector3]
|
320
|
+
# @return [Vector3]
|
321
|
+
[:Vector3Add, :Vector3Add, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
322
|
+
|
323
|
+
# @!method Vector3AddValue(v, add)
|
324
|
+
# Vector3AddValue
|
325
|
+
# @param v [Vector3]
|
326
|
+
# @param add [float]
|
327
|
+
# @return [Vector3]
|
328
|
+
[:Vector3AddValue, :Vector3AddValue, [Vector3.by_value, :float], Vector3.by_value],
|
329
|
+
|
330
|
+
# @!method Vector3Subtract(v1, v2)
|
331
|
+
# Vector3Subtract
|
332
|
+
# @param v1 [Vector3]
|
333
|
+
# @param v2 [Vector3]
|
334
|
+
# @return [Vector3]
|
335
|
+
[:Vector3Subtract, :Vector3Subtract, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
336
|
+
|
337
|
+
# @!method Vector3SubtractValue(v, sub)
|
338
|
+
# Vector3SubtractValue
|
339
|
+
# @param v [Vector3]
|
340
|
+
# @param sub [float]
|
341
|
+
# @return [Vector3]
|
342
|
+
[:Vector3SubtractValue, :Vector3SubtractValue, [Vector3.by_value, :float], Vector3.by_value],
|
343
|
+
|
344
|
+
# @!method Vector3Scale(v, scalar)
|
345
|
+
# Vector3Scale
|
346
|
+
# @param v [Vector3]
|
347
|
+
# @param scalar [float]
|
348
|
+
# @return [Vector3]
|
349
|
+
[:Vector3Scale, :Vector3Scale, [Vector3.by_value, :float], Vector3.by_value],
|
350
|
+
|
351
|
+
# @!method Vector3Multiply(v1, v2)
|
352
|
+
# Vector3Multiply
|
353
|
+
# @param v1 [Vector3]
|
354
|
+
# @param v2 [Vector3]
|
355
|
+
# @return [Vector3]
|
356
|
+
[:Vector3Multiply, :Vector3Multiply, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
357
|
+
|
358
|
+
# @!method Vector3CrossProduct(v1, v2)
|
359
|
+
# Vector3CrossProduct
|
360
|
+
# @param v1 [Vector3]
|
361
|
+
# @param v2 [Vector3]
|
362
|
+
# @return [Vector3]
|
363
|
+
[:Vector3CrossProduct, :Vector3CrossProduct, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
364
|
+
|
365
|
+
# @!method Vector3Perpendicular(v)
|
366
|
+
# Vector3Perpendicular
|
367
|
+
# @param v [Vector3]
|
368
|
+
# @return [Vector3]
|
369
|
+
[:Vector3Perpendicular, :Vector3Perpendicular, [Vector3.by_value], Vector3.by_value],
|
370
|
+
|
371
|
+
# @!method Vector3Length(v)
|
372
|
+
# Vector3Length
|
373
|
+
# @param v [const Vector3]
|
374
|
+
# @return [float]
|
375
|
+
[:Vector3Length, :Vector3Length, [Vector3.by_value], :float],
|
376
|
+
|
377
|
+
# @!method Vector3LengthSqr(v)
|
378
|
+
# Vector3LengthSqr
|
379
|
+
# @param v [const Vector3]
|
380
|
+
# @return [float]
|
381
|
+
[:Vector3LengthSqr, :Vector3LengthSqr, [Vector3.by_value], :float],
|
382
|
+
|
383
|
+
# @!method Vector3DotProduct(v1, v2)
|
384
|
+
# Vector3DotProduct
|
385
|
+
# @param v1 [Vector3]
|
386
|
+
# @param v2 [Vector3]
|
387
|
+
# @return [float]
|
388
|
+
[:Vector3DotProduct, :Vector3DotProduct, [Vector3.by_value, Vector3.by_value], :float],
|
389
|
+
|
390
|
+
# @!method Vector3Distance(v1, v2)
|
391
|
+
# Vector3Distance
|
392
|
+
# @param v1 [Vector3]
|
393
|
+
# @param v2 [Vector3]
|
394
|
+
# @return [float]
|
395
|
+
[:Vector3Distance, :Vector3Distance, [Vector3.by_value, Vector3.by_value], :float],
|
396
|
+
|
397
|
+
# @!method Vector3DistanceSqr(v1, v2)
|
398
|
+
# Vector3DistanceSqr
|
399
|
+
# @param v1 [Vector3]
|
400
|
+
# @param v2 [Vector3]
|
401
|
+
# @return [float]
|
402
|
+
[:Vector3DistanceSqr, :Vector3DistanceSqr, [Vector3.by_value, Vector3.by_value], :float],
|
403
|
+
|
404
|
+
# @!method Vector3Angle(v1, v2)
|
405
|
+
# Vector3Angle
|
406
|
+
# @param v1 [Vector3]
|
407
|
+
# @param v2 [Vector3]
|
408
|
+
# @return [float]
|
409
|
+
[:Vector3Angle, :Vector3Angle, [Vector3.by_value, Vector3.by_value], :float],
|
410
|
+
|
411
|
+
# @!method Vector3Negate(v)
|
412
|
+
# Vector3Negate
|
413
|
+
# @param v [Vector3]
|
414
|
+
# @return [Vector3]
|
415
|
+
[:Vector3Negate, :Vector3Negate, [Vector3.by_value], Vector3.by_value],
|
416
|
+
|
417
|
+
# @!method Vector3Divide(v1, v2)
|
418
|
+
# Vector3Divide
|
419
|
+
# @param v1 [Vector3]
|
420
|
+
# @param v2 [Vector3]
|
421
|
+
# @return [Vector3]
|
422
|
+
[:Vector3Divide, :Vector3Divide, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
423
|
+
|
424
|
+
# @!method Vector3Normalize(v)
|
425
|
+
# Vector3Normalize
|
426
|
+
# @param v [Vector3]
|
427
|
+
# @return [Vector3]
|
428
|
+
[:Vector3Normalize, :Vector3Normalize, [Vector3.by_value], Vector3.by_value],
|
429
|
+
|
430
|
+
# @!method Vector3Project(v1, v2)
|
431
|
+
# Vector3Project
|
432
|
+
# @param v1 [Vector3]
|
433
|
+
# @param v2 [Vector3]
|
434
|
+
# @return [Vector3]
|
435
|
+
[:Vector3Project, :Vector3Project, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
436
|
+
|
437
|
+
# @!method Vector3Reject(v1, v2)
|
438
|
+
# Vector3Reject
|
439
|
+
# @param v1 [Vector3]
|
440
|
+
# @param v2 [Vector3]
|
441
|
+
# @return [Vector3]
|
442
|
+
[:Vector3Reject, :Vector3Reject, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
443
|
+
|
444
|
+
# @!method Vector3OrthoNormalize(v1, v2)
|
445
|
+
# Vector3OrthoNormalize
|
446
|
+
# @param v1 [Vector3 *]
|
447
|
+
# @param v2 [Vector3 *]
|
448
|
+
# @return [void]
|
449
|
+
[:Vector3OrthoNormalize, :Vector3OrthoNormalize, [:pointer, :pointer], :void],
|
450
|
+
|
451
|
+
# @!method Vector3Transform(v, mat)
|
452
|
+
# Vector3Transform
|
453
|
+
# @param v [Vector3]
|
454
|
+
# @param mat [Matrix]
|
455
|
+
# @return [Vector3]
|
456
|
+
[:Vector3Transform, :Vector3Transform, [Vector3.by_value, Matrix.by_value], Vector3.by_value],
|
457
|
+
|
458
|
+
# @!method Vector3RotateByQuaternion(v, q)
|
459
|
+
# Vector3RotateByQuaternion
|
460
|
+
# @param v [Vector3]
|
461
|
+
# @param q [Quaternion]
|
462
|
+
# @return [Vector3]
|
463
|
+
[:Vector3RotateByQuaternion, :Vector3RotateByQuaternion, [Vector3.by_value, Quaternion.by_value], Vector3.by_value],
|
464
|
+
|
465
|
+
# @!method Vector3RotateByAxisAngle(v, axis, angle)
|
466
|
+
# Vector3RotateByAxisAngle
|
467
|
+
# @param v [Vector3]
|
468
|
+
# @param axis [Vector3]
|
469
|
+
# @param angle [float]
|
470
|
+
# @return [Vector3]
|
471
|
+
[:Vector3RotateByAxisAngle, :Vector3RotateByAxisAngle, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
472
|
+
|
473
|
+
# @!method Vector3MoveTowards(v, target, maxDistance)
|
474
|
+
# Vector3MoveTowards
|
475
|
+
# @param v [Vector3]
|
476
|
+
# @param target [Vector3]
|
477
|
+
# @param maxDistance [float]
|
478
|
+
# @return [Vector3]
|
479
|
+
[:Vector3MoveTowards, :Vector3MoveTowards, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
480
|
+
|
481
|
+
# @!method Vector3Lerp(v1, v2, amount)
|
482
|
+
# Vector3Lerp
|
483
|
+
# @param v1 [Vector3]
|
484
|
+
# @param v2 [Vector3]
|
485
|
+
# @param amount [float]
|
486
|
+
# @return [Vector3]
|
487
|
+
[:Vector3Lerp, :Vector3Lerp, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
488
|
+
|
489
|
+
# @!method Vector3CubicHermite(v1, tangent1, v2, tangent2, amount)
|
490
|
+
# Vector3CubicHermite
|
491
|
+
# @param v1 [Vector3]
|
492
|
+
# @param tangent1 [Vector3]
|
493
|
+
# @param v2 [Vector3]
|
494
|
+
# @param tangent2 [Vector3]
|
495
|
+
# @param amount [float]
|
496
|
+
# @return [Vector3]
|
497
|
+
[:Vector3CubicHermite, :Vector3CubicHermite, [Vector3.by_value, Vector3.by_value, Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
498
|
+
|
499
|
+
# @!method Vector3Reflect(v, normal)
|
500
|
+
# Vector3Reflect
|
501
|
+
# @param v [Vector3]
|
502
|
+
# @param normal [Vector3]
|
503
|
+
# @return [Vector3]
|
504
|
+
[:Vector3Reflect, :Vector3Reflect, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
505
|
+
|
506
|
+
# @!method Vector3Min(v1, v2)
|
507
|
+
# Vector3Min
|
508
|
+
# @param v1 [Vector3]
|
509
|
+
# @param v2 [Vector3]
|
510
|
+
# @return [Vector3]
|
511
|
+
[:Vector3Min, :Vector3Min, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
512
|
+
|
513
|
+
# @!method Vector3Max(v1, v2)
|
514
|
+
# Vector3Max
|
515
|
+
# @param v1 [Vector3]
|
516
|
+
# @param v2 [Vector3]
|
517
|
+
# @return [Vector3]
|
518
|
+
[:Vector3Max, :Vector3Max, [Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
519
|
+
|
520
|
+
# @!method Vector3Barycenter(p, a, b, c)
|
521
|
+
# Vector3Barycenter
|
522
|
+
# @param p [Vector3]
|
523
|
+
# @param a [Vector3]
|
524
|
+
# @param b [Vector3]
|
525
|
+
# @param c [Vector3]
|
526
|
+
# @return [Vector3]
|
527
|
+
[:Vector3Barycenter, :Vector3Barycenter, [Vector3.by_value, Vector3.by_value, Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
528
|
+
|
529
|
+
# @!method Vector3Unproject(source, projection, view)
|
530
|
+
# Vector3Unproject
|
531
|
+
# @param source [Vector3]
|
532
|
+
# @param projection [Matrix]
|
533
|
+
# @param view [Matrix]
|
534
|
+
# @return [Vector3]
|
535
|
+
[:Vector3Unproject, :Vector3Unproject, [Vector3.by_value, Matrix.by_value, Matrix.by_value], Vector3.by_value],
|
536
|
+
|
537
|
+
# @!method Vector3ToFloatV(v)
|
538
|
+
# Vector3ToFloatV
|
539
|
+
# @param v [Vector3]
|
540
|
+
# @return [float3]
|
541
|
+
[:Vector3ToFloatV, :Vector3ToFloatV, [Vector3.by_value], Float3.by_value],
|
542
|
+
|
543
|
+
# @!method Vector3Invert(v)
|
544
|
+
# Vector3Invert
|
545
|
+
# @param v [Vector3]
|
546
|
+
# @return [Vector3]
|
547
|
+
[:Vector3Invert, :Vector3Invert, [Vector3.by_value], Vector3.by_value],
|
548
|
+
|
549
|
+
# @!method Vector3Clamp(v, min, max)
|
550
|
+
# Vector3Clamp
|
551
|
+
# @param v [Vector3]
|
552
|
+
# @param min [Vector3]
|
553
|
+
# @param max [Vector3]
|
554
|
+
# @return [Vector3]
|
555
|
+
[:Vector3Clamp, :Vector3Clamp, [Vector3.by_value, Vector3.by_value, Vector3.by_value], Vector3.by_value],
|
556
|
+
|
557
|
+
# @!method Vector3ClampValue(v, min, max)
|
558
|
+
# Vector3ClampValue
|
559
|
+
# @param v [Vector3]
|
560
|
+
# @param min [float]
|
561
|
+
# @param max [float]
|
562
|
+
# @return [Vector3]
|
563
|
+
[:Vector3ClampValue, :Vector3ClampValue, [Vector3.by_value, :float, :float], Vector3.by_value],
|
564
|
+
|
565
|
+
# @!method Vector3Equals(p, q)
|
566
|
+
# Vector3Equals
|
567
|
+
# @param p [Vector3]
|
568
|
+
# @param q [Vector3]
|
569
|
+
# @return [int]
|
570
|
+
[:Vector3Equals, :Vector3Equals, [Vector3.by_value, Vector3.by_value], :int],
|
571
|
+
|
572
|
+
# @!method Vector3Refract(v, n, r)
|
573
|
+
# Vector3Refract
|
574
|
+
# @param v [Vector3]
|
575
|
+
# @param n [Vector3]
|
576
|
+
# @param r [float]
|
577
|
+
# @return [Vector3]
|
578
|
+
[:Vector3Refract, :Vector3Refract, [Vector3.by_value, Vector3.by_value, :float], Vector3.by_value],
|
579
|
+
|
580
|
+
# @!method Vector4Zero()
|
581
|
+
# Vector4Zero
|
582
|
+
# @return [Vector4]
|
583
|
+
[:Vector4Zero, :Vector4Zero, [], Vector4.by_value],
|
584
|
+
|
585
|
+
# @!method Vector4One()
|
586
|
+
# Vector4One
|
587
|
+
# @return [Vector4]
|
588
|
+
[:Vector4One, :Vector4One, [], Vector4.by_value],
|
589
|
+
|
590
|
+
# @!method Vector4Add(v1, v2)
|
591
|
+
# Vector4Add
|
592
|
+
# @param v1 [Vector4]
|
593
|
+
# @param v2 [Vector4]
|
594
|
+
# @return [Vector4]
|
595
|
+
[:Vector4Add, :Vector4Add, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
596
|
+
|
597
|
+
# @!method Vector4AddValue(v, add)
|
598
|
+
# Vector4AddValue
|
599
|
+
# @param v [Vector4]
|
600
|
+
# @param add [float]
|
601
|
+
# @return [Vector4]
|
602
|
+
[:Vector4AddValue, :Vector4AddValue, [Vector4.by_value, :float], Vector4.by_value],
|
603
|
+
|
604
|
+
# @!method Vector4Subtract(v1, v2)
|
605
|
+
# Vector4Subtract
|
606
|
+
# @param v1 [Vector4]
|
607
|
+
# @param v2 [Vector4]
|
608
|
+
# @return [Vector4]
|
609
|
+
[:Vector4Subtract, :Vector4Subtract, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
610
|
+
|
611
|
+
# @!method Vector4SubtractValue(v, add)
|
612
|
+
# Vector4SubtractValue
|
613
|
+
# @param v [Vector4]
|
614
|
+
# @param add [float]
|
615
|
+
# @return [Vector4]
|
616
|
+
[:Vector4SubtractValue, :Vector4SubtractValue, [Vector4.by_value, :float], Vector4.by_value],
|
617
|
+
|
618
|
+
# @!method Vector4Length(v)
|
619
|
+
# Vector4Length
|
620
|
+
# @param v [Vector4]
|
621
|
+
# @return [float]
|
622
|
+
[:Vector4Length, :Vector4Length, [Vector4.by_value], :float],
|
623
|
+
|
624
|
+
# @!method Vector4LengthSqr(v)
|
625
|
+
# Vector4LengthSqr
|
626
|
+
# @param v [Vector4]
|
627
|
+
# @return [float]
|
628
|
+
[:Vector4LengthSqr, :Vector4LengthSqr, [Vector4.by_value], :float],
|
629
|
+
|
630
|
+
# @!method Vector4DotProduct(v1, v2)
|
631
|
+
# Vector4DotProduct
|
632
|
+
# @param v1 [Vector4]
|
633
|
+
# @param v2 [Vector4]
|
634
|
+
# @return [float]
|
635
|
+
[:Vector4DotProduct, :Vector4DotProduct, [Vector4.by_value, Vector4.by_value], :float],
|
636
|
+
|
637
|
+
# @!method Vector4Distance(v1, v2)
|
638
|
+
# Vector4Distance
|
639
|
+
# @param v1 [Vector4]
|
640
|
+
# @param v2 [Vector4]
|
641
|
+
# @return [float]
|
642
|
+
[:Vector4Distance, :Vector4Distance, [Vector4.by_value, Vector4.by_value], :float],
|
643
|
+
|
644
|
+
# @!method Vector4DistanceSqr(v1, v2)
|
645
|
+
# Vector4DistanceSqr
|
646
|
+
# @param v1 [Vector4]
|
647
|
+
# @param v2 [Vector4]
|
648
|
+
# @return [float]
|
649
|
+
[:Vector4DistanceSqr, :Vector4DistanceSqr, [Vector4.by_value, Vector4.by_value], :float],
|
650
|
+
|
651
|
+
# @!method Vector4Scale(v, scale)
|
652
|
+
# Vector4Scale
|
653
|
+
# @param v [Vector4]
|
654
|
+
# @param scale [float]
|
655
|
+
# @return [Vector4]
|
656
|
+
[:Vector4Scale, :Vector4Scale, [Vector4.by_value, :float], Vector4.by_value],
|
657
|
+
|
658
|
+
# @!method Vector4Multiply(v1, v2)
|
659
|
+
# Vector4Multiply
|
660
|
+
# @param v1 [Vector4]
|
661
|
+
# @param v2 [Vector4]
|
662
|
+
# @return [Vector4]
|
663
|
+
[:Vector4Multiply, :Vector4Multiply, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
664
|
+
|
665
|
+
# @!method Vector4Negate(v)
|
666
|
+
# Vector4Negate
|
667
|
+
# @param v [Vector4]
|
668
|
+
# @return [Vector4]
|
669
|
+
[:Vector4Negate, :Vector4Negate, [Vector4.by_value], Vector4.by_value],
|
670
|
+
|
671
|
+
# @!method Vector4Divide(v1, v2)
|
672
|
+
# Vector4Divide
|
673
|
+
# @param v1 [Vector4]
|
674
|
+
# @param v2 [Vector4]
|
675
|
+
# @return [Vector4]
|
676
|
+
[:Vector4Divide, :Vector4Divide, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
677
|
+
|
678
|
+
# @!method Vector4Normalize(v)
|
679
|
+
# Vector4Normalize
|
680
|
+
# @param v [Vector4]
|
681
|
+
# @return [Vector4]
|
682
|
+
[:Vector4Normalize, :Vector4Normalize, [Vector4.by_value], Vector4.by_value],
|
683
|
+
|
684
|
+
# @!method Vector4Min(v1, v2)
|
685
|
+
# Vector4Min
|
686
|
+
# @param v1 [Vector4]
|
687
|
+
# @param v2 [Vector4]
|
688
|
+
# @return [Vector4]
|
689
|
+
[:Vector4Min, :Vector4Min, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
690
|
+
|
691
|
+
# @!method Vector4Max(v1, v2)
|
692
|
+
# Vector4Max
|
693
|
+
# @param v1 [Vector4]
|
694
|
+
# @param v2 [Vector4]
|
695
|
+
# @return [Vector4]
|
696
|
+
[:Vector4Max, :Vector4Max, [Vector4.by_value, Vector4.by_value], Vector4.by_value],
|
697
|
+
|
698
|
+
# @!method Vector4Lerp(v1, v2, amount)
|
699
|
+
# Vector4Lerp
|
700
|
+
# @param v1 [Vector4]
|
701
|
+
# @param v2 [Vector4]
|
702
|
+
# @param amount [float]
|
703
|
+
# @return [Vector4]
|
704
|
+
[:Vector4Lerp, :Vector4Lerp, [Vector4.by_value, Vector4.by_value, :float], Vector4.by_value],
|
705
|
+
|
706
|
+
# @!method Vector4MoveTowards(v, target, maxDistance)
|
707
|
+
# Vector4MoveTowards
|
708
|
+
# @param v [Vector4]
|
709
|
+
# @param target [Vector4]
|
710
|
+
# @param maxDistance [float]
|
711
|
+
# @return [Vector4]
|
712
|
+
[:Vector4MoveTowards, :Vector4MoveTowards, [Vector4.by_value, Vector4.by_value, :float], Vector4.by_value],
|
713
|
+
|
714
|
+
# @!method Vector4Invert(v)
|
715
|
+
# Vector4Invert
|
716
|
+
# @param v [Vector4]
|
717
|
+
# @return [Vector4]
|
718
|
+
[:Vector4Invert, :Vector4Invert, [Vector4.by_value], Vector4.by_value],
|
719
|
+
|
720
|
+
# @!method Vector4Equals(p, q)
|
721
|
+
# Vector4Equals
|
722
|
+
# @param p [Vector4]
|
723
|
+
# @param q [Vector4]
|
724
|
+
# @return [int]
|
725
|
+
[:Vector4Equals, :Vector4Equals, [Vector4.by_value, Vector4.by_value], :int],
|
726
|
+
|
727
|
+
# @!method MatrixDeterminant(mat)
|
728
|
+
# MatrixDeterminant
|
729
|
+
# @param mat [Matrix]
|
730
|
+
# @return [float]
|
731
|
+
[:MatrixDeterminant, :MatrixDeterminant, [Matrix.by_value], :float],
|
732
|
+
|
733
|
+
# @!method MatrixTrace(mat)
|
734
|
+
# MatrixTrace
|
735
|
+
# @param mat [Matrix]
|
736
|
+
# @return [float]
|
737
|
+
[:MatrixTrace, :MatrixTrace, [Matrix.by_value], :float],
|
738
|
+
|
739
|
+
# @!method MatrixTranspose(mat)
|
740
|
+
# MatrixTranspose
|
741
|
+
# @param mat [Matrix]
|
742
|
+
# @return [Matrix]
|
743
|
+
[:MatrixTranspose, :MatrixTranspose, [Matrix.by_value], Matrix.by_value],
|
744
|
+
|
745
|
+
# @!method MatrixInvert(mat)
|
746
|
+
# MatrixInvert
|
747
|
+
# @param mat [Matrix]
|
748
|
+
# @return [Matrix]
|
749
|
+
[:MatrixInvert, :MatrixInvert, [Matrix.by_value], Matrix.by_value],
|
750
|
+
|
751
|
+
# @!method MatrixIdentity()
|
752
|
+
# MatrixIdentity
|
753
|
+
# @return [Matrix]
|
754
|
+
[:MatrixIdentity, :MatrixIdentity, [], Matrix.by_value],
|
755
|
+
|
756
|
+
# @!method MatrixAdd(left, right)
|
757
|
+
# MatrixAdd
|
758
|
+
# @param left [Matrix]
|
759
|
+
# @param right [Matrix]
|
760
|
+
# @return [Matrix]
|
761
|
+
[:MatrixAdd, :MatrixAdd, [Matrix.by_value, Matrix.by_value], Matrix.by_value],
|
762
|
+
|
763
|
+
# @!method MatrixSubtract(left, right)
|
764
|
+
# MatrixSubtract
|
765
|
+
# @param left [Matrix]
|
766
|
+
# @param right [Matrix]
|
767
|
+
# @return [Matrix]
|
768
|
+
[:MatrixSubtract, :MatrixSubtract, [Matrix.by_value, Matrix.by_value], Matrix.by_value],
|
769
|
+
|
770
|
+
# @!method MatrixMultiply(left, right)
|
771
|
+
# MatrixMultiply
|
772
|
+
# @param left [Matrix]
|
773
|
+
# @param right [Matrix]
|
774
|
+
# @return [Matrix]
|
775
|
+
[:MatrixMultiply, :MatrixMultiply, [Matrix.by_value, Matrix.by_value], Matrix.by_value],
|
776
|
+
|
777
|
+
# @!method MatrixTranslate(x, y, z)
|
778
|
+
# MatrixTranslate
|
779
|
+
# @param x [float]
|
780
|
+
# @param y [float]
|
781
|
+
# @param z [float]
|
782
|
+
# @return [Matrix]
|
783
|
+
[:MatrixTranslate, :MatrixTranslate, [:float, :float, :float], Matrix.by_value],
|
784
|
+
|
785
|
+
# @!method MatrixRotate(axis, angle)
|
786
|
+
# MatrixRotate
|
787
|
+
# @param axis [Vector3]
|
788
|
+
# @param angle [float]
|
789
|
+
# @return [Matrix]
|
790
|
+
[:MatrixRotate, :MatrixRotate, [Vector3.by_value, :float], Matrix.by_value],
|
791
|
+
|
792
|
+
# @!method MatrixRotateX(angle)
|
793
|
+
# MatrixRotateX
|
794
|
+
# @param angle [float]
|
795
|
+
# @return [Matrix]
|
796
|
+
[:MatrixRotateX, :MatrixRotateX, [:float], Matrix.by_value],
|
797
|
+
|
798
|
+
# @!method MatrixRotateY(angle)
|
799
|
+
# MatrixRotateY
|
800
|
+
# @param angle [float]
|
801
|
+
# @return [Matrix]
|
802
|
+
[:MatrixRotateY, :MatrixRotateY, [:float], Matrix.by_value],
|
803
|
+
|
804
|
+
# @!method MatrixRotateZ(angle)
|
805
|
+
# MatrixRotateZ
|
806
|
+
# @param angle [float]
|
807
|
+
# @return [Matrix]
|
808
|
+
[:MatrixRotateZ, :MatrixRotateZ, [:float], Matrix.by_value],
|
809
|
+
|
810
|
+
# @!method MatrixRotateXYZ(angle)
|
811
|
+
# MatrixRotateXYZ
|
812
|
+
# @param angle [Vector3]
|
813
|
+
# @return [Matrix]
|
814
|
+
[:MatrixRotateXYZ, :MatrixRotateXYZ, [Vector3.by_value], Matrix.by_value],
|
815
|
+
|
816
|
+
# @!method MatrixRotateZYX(angle)
|
817
|
+
# MatrixRotateZYX
|
818
|
+
# @param angle [Vector3]
|
819
|
+
# @return [Matrix]
|
820
|
+
[:MatrixRotateZYX, :MatrixRotateZYX, [Vector3.by_value], Matrix.by_value],
|
821
|
+
|
822
|
+
# @!method MatrixScale(x, y, z)
|
823
|
+
# MatrixScale
|
824
|
+
# @param x [float]
|
825
|
+
# @param y [float]
|
826
|
+
# @param z [float]
|
827
|
+
# @return [Matrix]
|
828
|
+
[:MatrixScale, :MatrixScale, [:float, :float, :float], Matrix.by_value],
|
829
|
+
|
830
|
+
# @!method MatrixFrustum(left, right, bottom, top, nearPlane, farPlane)
|
831
|
+
# MatrixFrustum
|
832
|
+
# @param left [double]
|
833
|
+
# @param right [double]
|
834
|
+
# @param bottom [double]
|
835
|
+
# @param top [double]
|
836
|
+
# @param nearPlane [double]
|
837
|
+
# @param farPlane [double]
|
838
|
+
# @return [Matrix]
|
839
|
+
[:MatrixFrustum, :MatrixFrustum, [:double, :double, :double, :double, :double, :double], Matrix.by_value],
|
840
|
+
|
841
|
+
# @!method MatrixPerspective(fovY, aspect, nearPlane, farPlane)
|
842
|
+
# MatrixPerspective
|
843
|
+
# @param fovY [double]
|
844
|
+
# @param aspect [double]
|
845
|
+
# @param nearPlane [double]
|
846
|
+
# @param farPlane [double]
|
847
|
+
# @return [Matrix]
|
848
|
+
[:MatrixPerspective, :MatrixPerspective, [:double, :double, :double, :double], Matrix.by_value],
|
849
|
+
|
850
|
+
# @!method MatrixOrtho(left, right, bottom, top, nearPlane, farPlane)
|
851
|
+
# MatrixOrtho
|
852
|
+
# @param left [double]
|
853
|
+
# @param right [double]
|
854
|
+
# @param bottom [double]
|
855
|
+
# @param top [double]
|
856
|
+
# @param nearPlane [double]
|
857
|
+
# @param farPlane [double]
|
858
|
+
# @return [Matrix]
|
859
|
+
[:MatrixOrtho, :MatrixOrtho, [:double, :double, :double, :double, :double, :double], Matrix.by_value],
|
860
|
+
|
861
|
+
# @!method MatrixLookAt(eye, target, up)
|
862
|
+
# MatrixLookAt
|
863
|
+
# @param eye [Vector3]
|
864
|
+
# @param target [Vector3]
|
865
|
+
# @param up [Vector3]
|
866
|
+
# @return [Matrix]
|
867
|
+
[:MatrixLookAt, :MatrixLookAt, [Vector3.by_value, Vector3.by_value, Vector3.by_value], Matrix.by_value],
|
868
|
+
|
869
|
+
# @!method MatrixToFloatV(mat)
|
870
|
+
# MatrixToFloatV
|
871
|
+
# @param mat [Matrix]
|
872
|
+
# @return [float16]
|
873
|
+
[:MatrixToFloatV, :MatrixToFloatV, [Matrix.by_value], Float16.by_value],
|
874
|
+
|
875
|
+
# @!method QuaternionAdd(q1, q2)
|
876
|
+
# QuaternionAdd
|
877
|
+
# @param q1 [Quaternion]
|
878
|
+
# @param q2 [Quaternion]
|
879
|
+
# @return [Quaternion]
|
880
|
+
[:QuaternionAdd, :QuaternionAdd, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
881
|
+
|
882
|
+
# @!method QuaternionAddValue(q, add)
|
883
|
+
# QuaternionAddValue
|
884
|
+
# @param q [Quaternion]
|
885
|
+
# @param add [float]
|
886
|
+
# @return [Quaternion]
|
887
|
+
[:QuaternionAddValue, :QuaternionAddValue, [Quaternion.by_value, :float], Quaternion.by_value],
|
888
|
+
|
889
|
+
# @!method QuaternionSubtract(q1, q2)
|
890
|
+
# QuaternionSubtract
|
891
|
+
# @param q1 [Quaternion]
|
892
|
+
# @param q2 [Quaternion]
|
893
|
+
# @return [Quaternion]
|
894
|
+
[:QuaternionSubtract, :QuaternionSubtract, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
895
|
+
|
896
|
+
# @!method QuaternionSubtractValue(q, sub)
|
897
|
+
# QuaternionSubtractValue
|
898
|
+
# @param q [Quaternion]
|
899
|
+
# @param sub [float]
|
900
|
+
# @return [Quaternion]
|
901
|
+
[:QuaternionSubtractValue, :QuaternionSubtractValue, [Quaternion.by_value, :float], Quaternion.by_value],
|
902
|
+
|
903
|
+
# @!method QuaternionIdentity()
|
904
|
+
# QuaternionIdentity
|
905
|
+
# @return [Quaternion]
|
906
|
+
[:QuaternionIdentity, :QuaternionIdentity, [], Quaternion.by_value],
|
907
|
+
|
908
|
+
# @!method QuaternionLength(q)
|
909
|
+
# QuaternionLength
|
910
|
+
# @param q [Quaternion]
|
911
|
+
# @return [float]
|
912
|
+
[:QuaternionLength, :QuaternionLength, [Quaternion.by_value], :float],
|
913
|
+
|
914
|
+
# @!method QuaternionNormalize(q)
|
915
|
+
# QuaternionNormalize
|
916
|
+
# @param q [Quaternion]
|
917
|
+
# @return [Quaternion]
|
918
|
+
[:QuaternionNormalize, :QuaternionNormalize, [Quaternion.by_value], Quaternion.by_value],
|
919
|
+
|
920
|
+
# @!method QuaternionInvert(q)
|
921
|
+
# QuaternionInvert
|
922
|
+
# @param q [Quaternion]
|
923
|
+
# @return [Quaternion]
|
924
|
+
[:QuaternionInvert, :QuaternionInvert, [Quaternion.by_value], Quaternion.by_value],
|
925
|
+
|
926
|
+
# @!method QuaternionMultiply(q1, q2)
|
927
|
+
# QuaternionMultiply
|
928
|
+
# @param q1 [Quaternion]
|
929
|
+
# @param q2 [Quaternion]
|
930
|
+
# @return [Quaternion]
|
931
|
+
[:QuaternionMultiply, :QuaternionMultiply, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
932
|
+
|
933
|
+
# @!method QuaternionScale(q, mul)
|
934
|
+
# QuaternionScale
|
935
|
+
# @param q [Quaternion]
|
936
|
+
# @param mul [float]
|
937
|
+
# @return [Quaternion]
|
938
|
+
[:QuaternionScale, :QuaternionScale, [Quaternion.by_value, :float], Quaternion.by_value],
|
939
|
+
|
940
|
+
# @!method QuaternionDivide(q1, q2)
|
941
|
+
# QuaternionDivide
|
942
|
+
# @param q1 [Quaternion]
|
943
|
+
# @param q2 [Quaternion]
|
944
|
+
# @return [Quaternion]
|
945
|
+
[:QuaternionDivide, :QuaternionDivide, [Quaternion.by_value, Quaternion.by_value], Quaternion.by_value],
|
946
|
+
|
947
|
+
# @!method QuaternionLerp(q1, q2, amount)
|
948
|
+
# QuaternionLerp
|
949
|
+
# @param q1 [Quaternion]
|
950
|
+
# @param q2 [Quaternion]
|
951
|
+
# @param amount [float]
|
952
|
+
# @return [Quaternion]
|
953
|
+
[:QuaternionLerp, :QuaternionLerp, [Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
954
|
+
|
955
|
+
# @!method QuaternionNlerp(q1, q2, amount)
|
956
|
+
# QuaternionNlerp
|
957
|
+
# @param q1 [Quaternion]
|
958
|
+
# @param q2 [Quaternion]
|
959
|
+
# @param amount [float]
|
960
|
+
# @return [Quaternion]
|
961
|
+
[:QuaternionNlerp, :QuaternionNlerp, [Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
962
|
+
|
963
|
+
# @!method QuaternionSlerp(q1, q2, amount)
|
964
|
+
# QuaternionSlerp
|
965
|
+
# @param q1 [Quaternion]
|
966
|
+
# @param q2 [Quaternion]
|
967
|
+
# @param amount [float]
|
968
|
+
# @return [Quaternion]
|
969
|
+
[:QuaternionSlerp, :QuaternionSlerp, [Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
970
|
+
|
971
|
+
# @!method QuaternionCubicHermiteSpline(q1, outTangent1, q2, inTangent2, t)
|
972
|
+
# QuaternionCubicHermiteSpline
|
973
|
+
# @param q1 [Quaternion]
|
974
|
+
# @param outTangent1 [Quaternion]
|
975
|
+
# @param q2 [Quaternion]
|
976
|
+
# @param inTangent2 [Quaternion]
|
977
|
+
# @param t [float]
|
978
|
+
# @return [Quaternion]
|
979
|
+
[:QuaternionCubicHermiteSpline, :QuaternionCubicHermiteSpline, [Quaternion.by_value, Quaternion.by_value, Quaternion.by_value, Quaternion.by_value, :float], Quaternion.by_value],
|
980
|
+
|
981
|
+
# @!method QuaternionFromVector3ToVector3(from, to)
|
982
|
+
# QuaternionFromVector3ToVector3
|
983
|
+
# @param from [Vector3]
|
984
|
+
# @param to [Vector3]
|
985
|
+
# @return [Quaternion]
|
986
|
+
[:QuaternionFromVector3ToVector3, :QuaternionFromVector3ToVector3, [Vector3.by_value, Vector3.by_value], Quaternion.by_value],
|
987
|
+
|
988
|
+
# @!method QuaternionFromMatrix(mat)
|
989
|
+
# QuaternionFromMatrix
|
990
|
+
# @param mat [Matrix]
|
991
|
+
# @return [Quaternion]
|
992
|
+
[:QuaternionFromMatrix, :QuaternionFromMatrix, [Matrix.by_value], Quaternion.by_value],
|
993
|
+
|
994
|
+
# @!method QuaternionToMatrix(q)
|
995
|
+
# QuaternionToMatrix
|
996
|
+
# @param q [Quaternion]
|
997
|
+
# @return [Matrix]
|
998
|
+
[:QuaternionToMatrix, :QuaternionToMatrix, [Quaternion.by_value], Matrix.by_value],
|
999
|
+
|
1000
|
+
# @!method QuaternionFromAxisAngle(axis, angle)
|
1001
|
+
# QuaternionFromAxisAngle
|
1002
|
+
# @param axis [Vector3]
|
1003
|
+
# @param angle [float]
|
1004
|
+
# @return [Quaternion]
|
1005
|
+
[:QuaternionFromAxisAngle, :QuaternionFromAxisAngle, [Vector3.by_value, :float], Quaternion.by_value],
|
1006
|
+
|
1007
|
+
# @!method QuaternionToAxisAngle(q, outAxis, outAngle)
|
1008
|
+
# QuaternionToAxisAngle
|
1009
|
+
# @param q [Quaternion]
|
1010
|
+
# @param outAxis [Vector3 *]
|
1011
|
+
# @param outAngle [float *]
|
1012
|
+
# @return [void]
|
1013
|
+
[:QuaternionToAxisAngle, :QuaternionToAxisAngle, [Quaternion.by_value, :pointer, :pointer], :void],
|
1014
|
+
|
1015
|
+
# @!method QuaternionFromEuler(pitch, yaw, roll)
|
1016
|
+
# QuaternionFromEuler
|
1017
|
+
# @param pitch [float]
|
1018
|
+
# @param yaw [float]
|
1019
|
+
# @param roll [float]
|
1020
|
+
# @return [Quaternion]
|
1021
|
+
[:QuaternionFromEuler, :QuaternionFromEuler, [:float, :float, :float], Quaternion.by_value],
|
1022
|
+
|
1023
|
+
# @!method QuaternionToEuler(q)
|
1024
|
+
# QuaternionToEuler
|
1025
|
+
# @param q [Quaternion]
|
1026
|
+
# @return [Vector3]
|
1027
|
+
[:QuaternionToEuler, :QuaternionToEuler, [Quaternion.by_value], Vector3.by_value],
|
1028
|
+
|
1029
|
+
# @!method QuaternionTransform(q, mat)
|
1030
|
+
# QuaternionTransform
|
1031
|
+
# @param q [Quaternion]
|
1032
|
+
# @param mat [Matrix]
|
1033
|
+
# @return [Quaternion]
|
1034
|
+
[:QuaternionTransform, :QuaternionTransform, [Quaternion.by_value, Matrix.by_value], Quaternion.by_value],
|
1035
|
+
|
1036
|
+
# @!method QuaternionEquals(p, q)
|
1037
|
+
# QuaternionEquals
|
1038
|
+
# @param p [Quaternion]
|
1039
|
+
# @param q [Quaternion]
|
1040
|
+
# @return [int]
|
1041
|
+
[:QuaternionEquals, :QuaternionEquals, [Quaternion.by_value, Quaternion.by_value], :int],
|
1042
|
+
|
1043
|
+
# @!method MatrixDecompose(mat, translation, rotation, scale)
|
1044
|
+
# MatrixDecompose
|
1045
|
+
# @param mat [Matrix]
|
1046
|
+
# @param translation [Vector3 *]
|
1047
|
+
# @param rotation [Quaternion *]
|
1048
|
+
# @param scale [Vector3 *]
|
1049
|
+
# @return [void]
|
1050
|
+
[:MatrixDecompose, :MatrixDecompose, [Matrix.by_value, :pointer, :pointer, :pointer], :void],
|
1051
|
+
]
|
1052
|
+
entries.each do |entry|
|
1053
|
+
api_name = if method_naming == :snake_case
|
1054
|
+
snake_case_name = entry[0].to_s.gsub(/([A-Z]+)([A-Z0-9][a-z])/, '\1_\2').gsub(/([a-z\d])([A-Z0-9])/, '\1_\2').downcase
|
1055
|
+
snake_case_name.gsub!('vector_3', 'vector3_') if snake_case_name.include?('vector_3')
|
1056
|
+
snake_case_name.gsub!('vector_2', 'vector2_') if snake_case_name.include?('vector_2')
|
1057
|
+
snake_case_name.chop! if snake_case_name.end_with?('_')
|
1058
|
+
snake_case_name.to_sym
|
1059
|
+
else
|
1060
|
+
entry[0]
|
1061
|
+
end
|
1062
|
+
attach_function api_name, entry[1], entry[2], entry[3]
|
1063
|
+
rescue FFI::NotFoundError => e
|
1064
|
+
warn "[Warning] Failed to import #{entry[0]} (#{e})."
|
1065
|
+
end
|
1066
|
+
end
|
1067
|
+
end
|