7d4cd227b3d3124e35638fdbffe6c8c12a39ab9e
[retroray] / src / scene.h
1 /*
2 RetroRay - integrated standalone vintage modeller/renderer
3 Copyright (C) 2023  John Tsiombikas <nuclear@mutantstargoat.com>
4
5 This program is free software: you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation, either version 3 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License
16 along with this program.  If not, see <https://www.gnu.org/licenses/>.
17 */
18 #ifndef SCENE_H_
19 #define SCENE_H_
20
21 #include "cgmath/cgmath.h"
22
23 enum {
24         OBJ_NULL,
25         OBJ_SPHERE,
26         OBJ_CSG
27 };
28
29 #define OBJ_COMMON_ATTR \
30         int type; \
31         char *name; \
32         cgm_vec3 pos, scale, pivot; \
33         cgm_quat rot; \
34         float xform[16], inv_xform[16]; \
35         int xform_valid
36
37 struct object {
38         OBJ_COMMON_ATTR;
39 };
40
41 struct sphere {
42         OBJ_COMMON_ATTR;
43         float rad;
44 };
45
46 struct csgnode {
47         OBJ_COMMON_ATTR;
48         int op;
49         struct object *subobj;  /* darr */
50 };
51
52 struct scene {
53         struct object **objects;        /* darr */
54 };
55
56 struct rayhit;  /* declared in rt.h */
57
58 struct scene *create_scene(void);
59 void free_scene(struct scene *scn);
60
61 int scn_add_object(struct scene *scn, struct object *obj);
62 int scn_rm_object(struct scene *scn, int idx);
63 int scn_num_objects(const struct scene *scn);
64 int scn_object_index(const struct scene *scn, const struct object *obj);
65
66 int scn_intersect(const struct scene *scn, const cgm_ray *ray, struct rayhit *hit);
67
68 struct object *create_object(int type);
69 void free_object(struct object *obj);
70
71 int set_object_name(struct object *obj, const char *name);
72
73 void calc_object_matrix(struct object *obj);
74
75 #endif  /* SCENE_H_ */