Sat, 03 May 2025 13:49:24 +0200
improve datatypes
32 | 1 | /* |
2 | * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. | |
3 | * Copyright 2023 Mike Becker. All rights reserved. | |
4 | * | |
5 | * Redistribution and use in source and binary forms, with or without | |
6 | * modification, are permitted provided that the following conditions are met: | |
7 | * | |
8 | * 1. Redistributions of source code must retain the above copyright | |
9 | * notice, this list of conditions and the following disclaimer. | |
10 | * | |
11 | * 2. Redistributions in binary form must reproduce the above copyright | |
12 | * notice, this list of conditions and the following disclaimer in the | |
13 | * documentation and/or other materials provided with the distribution. | |
14 | * | |
15 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | |
16 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
17 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | |
18 | * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE | |
19 | * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | |
20 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | |
21 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | |
22 | * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | |
23 | * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | |
24 | * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | |
25 | * POSSIBILITY OF SUCH DAMAGE. | |
26 | */ | |
27 | ||
28 | #ifndef ASCENSION_TRANSFORM_H | |
29 | #define ASCENSION_TRANSFORM_H | |
30 | ||
31 | #include "datatypes.h" | |
32 | ||
33 | typedef asc_mat4f asc_transform; | |
34 | ||
35 | #define ASC_TRANSFORM_SIZE (sizeof(float)*16) | |
36 | ||
37 | #ifdef __GNUC__ | |
38 | #define ASC_TRANFORM_FUNC_ATTRIBUTES \ | |
39 | __attribute__((__nonnull__, __always_inline__)) | |
40 | #else | |
41 | #define ASC_TRANFORM_FUNC_ATTRIBUTES | |
42 | #endif | |
43 | #define ASC_TRANFORM_FUNC ASC_TRANFORM_FUNC_ATTRIBUTES static inline | |
44 | ||
45 | ||
46 | ASC_TRANFORM_FUNC void asc_transform_identity(asc_transform transform) { | |
47 | memset(transform, 0, ASC_TRANSFORM_SIZE); | |
48 | transform[asc_mat4_index(0, 0)] = 1; | |
49 | transform[asc_mat4_index(1, 1)] = 1; | |
50 | transform[asc_mat4_index(2, 2)] = 1; | |
51 | transform[asc_mat4_index(3, 3)] = 1; | |
52 | } | |
53 | ||
54 | ASC_TRANFORM_FUNC void asc_transform_copy(asc_transform dest, asc_transform src) { | |
55 | memcpy(dest, src, ASC_TRANSFORM_SIZE); | |
56 | } | |
57 | ||
58 | ASC_TRANFORM_FUNC void asc_transform_translate( | |
59 | asc_transform transform, | |
45
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
60 | asc_vec3f vec |
32 | 61 | ) { |
45
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
62 | transform[asc_mat4_index(3, 0)] += vec.x; |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
63 | transform[asc_mat4_index(3, 1)] += vec.y; |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
64 | transform[asc_mat4_index(3, 2)] += vec.z; |
32 | 65 | } |
66 | ||
67 | ASC_TRANFORM_FUNC void asc_transform_scale( | |
68 | asc_transform transform, | |
45
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
69 | asc_vec3f vec |
32 | 70 | ) { |
71 | for (unsigned i = 0 ; i < 3 ; i++) { | |
45
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
72 | transform[asc_mat4_index(0, i)] *= vec.width; |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
73 | transform[asc_mat4_index(1, i)] *= vec.height; |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
74 | transform[asc_mat4_index(2, i)] *= vec.depth; |
32 | 75 | } |
76 | } | |
77 | ||
45
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
78 | ASC_TRANFORM_FUNC void asc_transform_rotate( |
105 | 79 | __attribute__((__unused__)) asc_transform transform, |
80 | __attribute__((__unused__)) asc_vec3f vec | |
32 | 81 | ) { |
45
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
82 | // TODO: implement |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
83 | } |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
84 | |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
85 | ASC_TRANFORM_FUNC void asc_transform_from_parts( |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
86 | asc_transform transform, |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
87 | asc_vec3f position, |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
88 | asc_vec3f scale, |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
89 | asc_vec3f rotation |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
90 | ) { |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
91 | asc_transform_identity(transform); |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
92 | asc_transform_scale(transform, scale); |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
93 | asc_transform_translate(transform, position); |
18de2af03531
simplify how transforms work
Mike Becker <universe@uap-core.de>
parents:
32
diff
changeset
|
94 | asc_transform_rotate(transform, rotation); |
32 | 95 | } |
96 | ||
97 | #endif //ASCENSION_TRANSFORM_H |