src/scene.c

Sun, 01 Jun 2025 16:35:23 +0200

author
Mike Becker <universe@uap-core.de>
date
Sun, 01 Jun 2025 16:35:23 +0200
changeset 137
f8e6e0ae61a8
parent 136
768e6eac1ab0
permissions
-rw-r--r--

remove pre-defined dummy textures by introducing conditional compilation for shaders

and by the way resolves #645

21
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 * Copyright 2023 Mike Becker. All rights reserved.
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 *
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 * Redistribution and use in source and binary forms, with or without
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * modification, are permitted provided that the following conditions are met:
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 *
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 * 1. Redistributions of source code must retain the above copyright
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * notice, this list of conditions and the following disclaimer.
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 *
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 * 2. Redistributions in binary form must reproduce the above copyright
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * notice, this list of conditions and the following disclaimer in the
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * documentation and/or other materials provided with the distribution.
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 *
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * POSSIBILITY OF SUCH DAMAGE.
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 */
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27
106
895f92cff6b8 bring back error.h to reduce compile dependencies
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
28 #include "ascension/error.h"
895f92cff6b8 bring back error.h to reduce compile dependencies
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
29 #include "ascension/context.h"
21
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30 #include "ascension/scene.h"
108
d619bf7dd87b add AscBehavior - prepares resolution of issue #646
Mike Becker <universe@uap-core.de>
parents: 106
diff changeset
31 #include "ascension/behavior.h"
106
895f92cff6b8 bring back error.h to reduce compile dependencies
Mike Becker <universe@uap-core.de>
parents: 105
diff changeset
32 #include "ascension/shader.h"
82
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 76
diff changeset
33 #include "ascension/2d.h"
4e1e698f4b0d add generic mesh draw function and move sprite draw function to separate unit
Mike Becker <universe@uap-core.de>
parents: 76
diff changeset
34
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
35 #include <cx/tree.h>
47
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
36 #include <cx/array_list.h>
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
38 #include <GL/glew.h>
29
1d001eb694dc bring first scene graph to live
Mike Becker <universe@uap-core.de>
parents: 27
diff changeset
39
21
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
40 #include <assert.h>
1a47c57666f5 add first draft of a scene graph structure
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41
121
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
42 void asc_scene_init_(AscScene *scene, struct asc_camera_init_args args) {
96
9e25f080a33e add scenes, but they don't draw yet
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
43 if (scene->root != NULL) {
9e25f080a33e add scenes, but they don't draw yet
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
44 asc_wprintf("Scene %"PRIxPTR" is already initialized - initialization skipped.", (uintptr_t) scene);
9e25f080a33e add scenes, but they don't draw yet
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
45 return;
9e25f080a33e add scenes, but they don't draw yet
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
46 }
121
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
47 asc_camera_init_(&scene->camera, args);
100
5231da78831e change asc_scene_init() to also request parameters for camera initialization
Mike Becker <universe@uap-core.de>
parents: 99
diff changeset
48 scene->root = asc_scene_node_empty();
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
49 for (unsigned i = 0 ; i < ASC_RENDER_GROUP_COUNT ; i++) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
50 scene->internal.render_groups[i] = cxArrayListCreateSimple(CX_STORE_POINTERS, 32);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
51 }
100
5231da78831e change asc_scene_init() to also request parameters for camera initialization
Mike Becker <universe@uap-core.de>
parents: 99
diff changeset
52
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
53 asc_dprintf("Initialized scene %"PRIxPTR, (uintptr_t) scene);
75
0ce353485509 revert introduction of high level ucx trees and stick to the low level API
Mike Becker <universe@uap-core.de>
parents: 73
diff changeset
54 }
0ce353485509 revert introduction of high level ucx trees and stick to the low level API
Mike Becker <universe@uap-core.de>
parents: 73
diff changeset
55
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
56 void asc_scene_destroy(AscScene *scene) {
96
9e25f080a33e add scenes, but they don't draw yet
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
57 if (scene->root == NULL) return;
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
58 for (unsigned i = 0 ; i < ASC_RENDER_GROUP_COUNT ; i++) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
59 cxListFree(scene->internal.render_groups[i]);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
60 scene->internal.render_groups[i] = NULL;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
61 }
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
62 asc_dprintf("Destroyed scene %"PRIxPTR, (uintptr_t) scene);
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
63 asc_scene_node_free(scene->root);
75
0ce353485509 revert introduction of high level ucx trees and stick to the low level API
Mike Becker <universe@uap-core.de>
parents: 73
diff changeset
64 }
0ce353485509 revert introduction of high level ucx trees and stick to the low level API
Mike Becker <universe@uap-core.de>
parents: 73
diff changeset
65
112
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
66 void asc_scene_execute_behaviors(AscScene *scene) {
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
67 CxTreeVisitor iter = cx_tree_visitor(scene->root,
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
68 offsetof(AscSceneNode, children),
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
69 offsetof(AscSceneNode, next)
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
70 );
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
71 cx_foreach(AscSceneNode*, node, iter) {
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
72 CxIterator behavior_iter = cxListIterator(node->behaviors);
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
73 cx_foreach(AscBehavior*, behavior, behavior_iter) {
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
74 if (behavior->enabled) {
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
75 behavior->func(behavior);
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
76 }
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
77 }
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
78 }
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
79 }
3e956c96dd6c extract execution of behaviors from draw function
Mike Becker <universe@uap-core.de>
parents: 108
diff changeset
80
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
81 void asc_scene_draw_sprites(
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
82 const AscScene *scene,
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
83 const CxList *opaque_rect,
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
84 const CxList *opaque_uv,
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
85 const CxList *blend_rect,
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
86 const CxList *blend_uv
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
87 ) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
88 // render opaque sprites from front to back
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
89 CxIterator iter_opaque_rect = cxListBackwardsIterator(opaque_rect);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
90 CxIterator iter_opaque_uv = cxListBackwardsIterator(opaque_uv);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
91
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
92 // render sprites with alpha value from back to front
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
93 CxIterator iter_blend_rect = cxListIterator(blend_rect);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
94 CxIterator iter_blend_uv = cxListIterator(blend_uv);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
95
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
96 // TODO: implement interleaving by depth
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
97 if (cxIteratorValid(iter_opaque_rect)) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
98 glDisable(GL_BLEND);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
99 AscShaderSprite *shader = ASC_SHADER_SPRITE_RECT;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
100 asc_shader_program_use(&shader->program, &scene->camera);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
101 cx_foreach(const AscSprite*, node, iter_opaque_rect) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
102 asc_sprite_draw(shader, node);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
103 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
104 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
105 if (cxIteratorValid(iter_opaque_uv)) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
106 glDisable(GL_BLEND);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
107 AscShaderSprite *shader = ASC_SHADER_SPRITE_UV;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
108 asc_shader_program_use(&shader->program, &scene->camera);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
109 cx_foreach(const AscSprite*, node, iter_opaque_uv) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
110 asc_sprite_draw(shader, node);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
111 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
112 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
113 if (cxIteratorValid(iter_blend_rect)) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
114 glEnable(GL_BLEND);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
115 glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
116 AscShaderSprite *shader = ASC_SHADER_SPRITE_RECT;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
117 asc_shader_program_use(&shader->program, &scene->camera);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
118 cx_foreach(const AscSprite*, node, iter_blend_rect) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
119 asc_sprite_draw(shader, node);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
120 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
121 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
122 if (cxIteratorValid(iter_blend_uv)) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
123 glEnable(GL_BLEND);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
124 glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
125 AscShaderSprite *shader = ASC_SHADER_SPRITE_UV;
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
126 asc_shader_program_use(&shader->program, &scene->camera);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
127 cx_foreach(const AscSprite*, node, iter_blend_uv) {
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
128 asc_sprite_draw(shader, node);
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
129 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
130 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
131 }
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
132
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
133 void asc_scene_draw(AscScene *scene) {
96
9e25f080a33e add scenes, but they don't draw yet
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
134 if (scene->root == NULL) return;
9e25f080a33e add scenes, but they don't draw yet
Mike Becker <universe@uap-core.de>
parents: 95
diff changeset
135
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
136 // if the window resized, we must update the viewport
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
137 if (asc_active_window->resized) {
105
2b7f92ff2c15 improve datatypes
Mike Becker <universe@uap-core.de>
parents: 102
diff changeset
138 asc_vec2u window_size = asc_active_window->dimensions;
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
139 if (scene->camera.viewport_update_func == NULL) {
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
140 // this assumes the viewport was initialized with zeros!
101
febf3dc10011 add backdrop scene
Mike Becker <universe@uap-core.de>
parents: 100
diff changeset
141 scene->camera.viewport.size = window_size;
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
142 } else {
101
febf3dc10011 add backdrop scene
Mike Becker <universe@uap-core.de>
parents: 100
diff changeset
143 scene->camera.viewport = scene->camera.viewport_update_func(window_size);
febf3dc10011 add backdrop scene
Mike Becker <universe@uap-core.de>
parents: 100
diff changeset
144 }
febf3dc10011 add backdrop scene
Mike Becker <universe@uap-core.de>
parents: 100
diff changeset
145 if (scene->camera.projection_update_func != NULL) {
febf3dc10011 add backdrop scene
Mike Becker <universe@uap-core.de>
parents: 100
diff changeset
146 scene->camera.projection_update_func(&scene->camera, window_size);
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
147 }
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
148 }
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
149
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
150 // reset render groups
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
151 CxList **render_group = scene->internal.render_groups;
126
77c13e14a65f update to most recent ucx 3.2 preview
Mike Becker <universe@uap-core.de>
parents: 121
diff changeset
152 for (unsigned i = 0 ; i < ASC_RENDER_GROUP_COUNT ; i++) {
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
153 cxListClear(render_group[i]);
47
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
154 }
32
86468a71dd73 add transformation matrix
Mike Becker <universe@uap-core.de>
parents: 31
diff changeset
155
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
156 // update the scene graph and add nodes to their render groups
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
157 CxTreeVisitor iter = cx_tree_visitor(scene->root,
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
158 offsetof(AscSceneNode, children),
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
159 offsetof(AscSceneNode, next)
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
160 );
30
fceda550ebcb apply new CxTreeIterator from ucx 3.1 preview
Mike Becker <universe@uap-core.de>
parents: 29
diff changeset
161 cx_foreach(AscSceneNode*, node, iter) {
55
6b61b4899587 make hidden flag a general attribute of nodes
Mike Becker <universe@uap-core.de>
parents: 51
diff changeset
162 // skip hidden nodes (and all their children)
61
b7954818a6b7 merge different bools of AscSceneNode into flags
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
163 if (asc_test_flag(node->flags, ASC_SCENE_NODE_HIDDEN)) {
55
6b61b4899587 make hidden flag a general attribute of nodes
Mike Becker <universe@uap-core.de>
parents: 51
diff changeset
164 cxTreeVisitorContinue(iter);
6b61b4899587 make hidden flag a general attribute of nodes
Mike Becker <universe@uap-core.de>
parents: 51
diff changeset
165 }
6b61b4899587 make hidden flag a general attribute of nodes
Mike Becker <universe@uap-core.de>
parents: 51
diff changeset
166
47
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
167 // TODO: implement culling
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
168
33
e7ddb52facd3 add behavior nodes + restructure test program
Mike Becker <universe@uap-core.de>
parents: 32
diff changeset
169 // check if geometry needs update
69
86d545f490e4 fix that update_transform flag was never cleared
Mike Becker <universe@uap-core.de>
parents: 65
diff changeset
170 asc_clear_flag(node->flags,
86d545f490e4 fix that update_transform flag was never cleared
Mike Becker <universe@uap-core.de>
parents: 65
diff changeset
171 ASC_SCENE_NODE_GRAPHICS_UPDATED
86d545f490e4 fix that update_transform flag was never cleared
Mike Becker <universe@uap-core.de>
parents: 65
diff changeset
172 | ASC_SCENE_NODE_TRANSFORM_UPDATED);
61
b7954818a6b7 merge different bools of AscSceneNode into flags
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
173 if (asc_test_flag(node->flags, ASC_SCENE_NODE_UPDATE_GRAPHICS)) {
69
86d545f490e4 fix that update_transform flag was never cleared
Mike Becker <universe@uap-core.de>
parents: 65
diff changeset
174 asc_set_flag(node->flags, ASC_SCENE_NODE_GRAPHICS_UPDATED);
86d545f490e4 fix that update_transform flag was never cleared
Mike Becker <universe@uap-core.de>
parents: 65
diff changeset
175 asc_clear_flag(node->flags, ASC_SCENE_NODE_UPDATE_GRAPHICS);
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
176 assert(node->update_func != NULL);
32
86468a71dd73 add transformation matrix
Mike Becker <universe@uap-core.de>
parents: 31
diff changeset
177 node->update_func(node);
86468a71dd73 add transformation matrix
Mike Becker <universe@uap-core.de>
parents: 31
diff changeset
178 }
61
b7954818a6b7 merge different bools of AscSceneNode into flags
Mike Becker <universe@uap-core.de>
parents: 55
diff changeset
179 if (asc_test_flag(node->flags, ASC_SCENE_NODE_UPDATE_TRANSFORM)) {
69
86d545f490e4 fix that update_transform flag was never cleared
Mike Becker <universe@uap-core.de>
parents: 65
diff changeset
180 asc_set_flag(node->flags, ASC_SCENE_NODE_TRANSFORM_UPDATED);
86d545f490e4 fix that update_transform flag was never cleared
Mike Becker <universe@uap-core.de>
parents: 65
diff changeset
181 asc_clear_flag(node->flags, ASC_SCENE_NODE_UPDATE_TRANSFORM);
133
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
182
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
183 // Only recalculate from components if not using custom transform
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
184 if (!asc_test_flag(node->flags, ASC_SCENE_NODE_CUSTOM_TRANSFORM)) {
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
185 asc_transform_from_vec3f(
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
186 node->transform,
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
187 node->position,
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
188 node->scale,
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
189 node->rotation
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
190 );
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
191 }
823626940dc9 add possibility to modify the node's transformation matrix
Mike Becker <universe@uap-core.de>
parents: 130
diff changeset
192
45
18de2af03531 simplify how transforms work
Mike Becker <universe@uap-core.de>
parents: 44
diff changeset
193 asc_mat4f_mulst(
18de2af03531 simplify how transforms work
Mike Becker <universe@uap-core.de>
parents: 44
diff changeset
194 node->world_transform,
18de2af03531 simplify how transforms work
Mike Becker <universe@uap-core.de>
parents: 44
diff changeset
195 node->transform,
75
0ce353485509 revert introduction of high level ucx trees and stick to the low level API
Mike Becker <universe@uap-core.de>
parents: 73
diff changeset
196 node->parent->world_transform
45
18de2af03531 simplify how transforms work
Mike Becker <universe@uap-core.de>
parents: 44
diff changeset
197 );
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
198 }
33
e7ddb52facd3 add behavior nodes + restructure test program
Mike Becker <universe@uap-core.de>
parents: 32
diff changeset
199
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
200 // add to render group
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
201 if (node->render_group >= 0) {
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
202 cxListAdd(render_group[node->render_group], node);
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
203 }
29
1d001eb694dc bring first scene graph to live
Mike Becker <universe@uap-core.de>
parents: 27
diff changeset
204 }
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
205
136
768e6eac1ab0 fix incorrect flip of viewport y-axis
Mike Becker <universe@uap-core.de>
parents: 133
diff changeset
206 // set the viewport
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
207 glViewport(
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
208 scene->camera.viewport.pos.x,
136
768e6eac1ab0 fix incorrect flip of viewport y-axis
Mike Becker <universe@uap-core.de>
parents: 133
diff changeset
209 scene->camera.viewport.pos.y,
99
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
210 scene->camera.viewport.size.width,
ac143db979dc add aspect-ration independent rendering
Mike Becker <universe@uap-core.de>
parents: 96
diff changeset
211 scene->camera.viewport.size.height
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
212 );
121
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
213 if (scene->camera.viewport_clear) {
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
214 glScissor(
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
215 scene->camera.viewport.pos.x,
136
768e6eac1ab0 fix incorrect flip of viewport y-axis
Mike Becker <universe@uap-core.de>
parents: 133
diff changeset
216 scene->camera.viewport.pos.y,
121
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
217 scene->camera.viewport.size.width,
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
218 scene->camera.viewport.size.height
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
219 );
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
220 glEnable(GL_SCISSOR_TEST);
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
221 const asc_col4f col = scene->camera.clear_color;
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
222 glClearColor(col.red, col.green, col.blue, col.alpha);
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
223 glClear(GL_COLOR_BUFFER_BIT);
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
224 glDisable(GL_SCISSOR_TEST);
ede9a9e92ff9 add viewport_clear flag to camera settings
Mike Becker <universe@uap-core.de>
parents: 112
diff changeset
225 }
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
226
47
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
227 // -------------------------
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
228 // process the render groups
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
229 // -------------------------
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
230
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
231 // 2D Elements
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
232 // ===========
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
233 glEnable(GL_DEPTH_TEST);
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
234 glClear(GL_DEPTH_BUFFER_BIT);
37
8a8cc6725b48 add camera and render groups
Mike Becker <universe@uap-core.de>
parents: 33
diff changeset
235
47
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
236 // Sprites
44457f6cb0a2 remove unnecessary scene container
Mike Becker <universe@uap-core.de>
parents: 45
diff changeset
237 // -------
137
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
238 asc_scene_draw_sprites(scene,
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
239 render_group[ASC_RENDER_GROUP_SPRITE_OPAQUE_RECT],
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
240 render_group[ASC_RENDER_GROUP_SPRITE_OPAQUE_UV],
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
241 render_group[ASC_RENDER_GROUP_SPRITE_BLEND_RECT],
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
242 render_group[ASC_RENDER_GROUP_SPRITE_BLEND_UV]
f8e6e0ae61a8 remove pre-defined dummy textures by introducing conditional compilation for shaders
Mike Becker <universe@uap-core.de>
parents: 136
diff changeset
243 );
29
1d001eb694dc bring first scene graph to live
Mike Becker <universe@uap-core.de>
parents: 27
diff changeset
244 }
1d001eb694dc bring first scene graph to live
Mike Becker <universe@uap-core.de>
parents: 27
diff changeset
245
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
246 void asc_scene_add_node(AscScene *scene, AscSceneNode *node) {
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
247 asc_scene_node_link(scene->root, node);
29
1d001eb694dc bring first scene graph to live
Mike Becker <universe@uap-core.de>
parents: 27
diff changeset
248 }
1d001eb694dc bring first scene graph to live
Mike Becker <universe@uap-core.de>
parents: 27
diff changeset
249
95
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
250 void asc_scene_remove_node(AscSceneNode *node) {
622887f7e954 in preparation of more scenes, bring back AscScene struct
Mike Becker <universe@uap-core.de>
parents: 90
diff changeset
251 asc_scene_node_unlink(node);
33
e7ddb52facd3 add behavior nodes + restructure test program
Mike Becker <universe@uap-core.de>
parents: 32
diff changeset
252 }

mercurial