Pixel-Composer/scripts/render_data/render_data.gml

322 lines
9.8 KiB
Plaintext
Raw Normal View History

enum RENDER_TYPE {
none = 0,
partial = 1,
full = 2
}
2023-03-28 06:58:28 +02:00
#region globalvar
2023-10-02 10:45:30 +02:00
globalvar UPDATE, RENDER_QUEUE, RENDER_ORDER, UPDATE_RENDER_ORDER;
UPDATE_RENDER_ORDER = false;
global.FLAG.render = 0;
2023-03-28 06:58:28 +02:00
global.group_inputs = [ "Node_Group_Input", "Node_Feedback_Input", "Node_Iterator_Input", "Node_Iterator_Each_Input" ];
2023-10-02 10:45:30 +02:00
#macro RENDER_ALL_REORDER UPDATE_RENDER_ORDER = true; UPDATE |= RENDER_TYPE.full;
#macro RENDER_ALL UPDATE |= RENDER_TYPE.full;
#macro RENDER_PARTIAL UPDATE |= RENDER_TYPE.partial;
2023-03-28 06:58:28 +02:00
#endregion
2022-12-13 09:20:36 +01:00
2023-10-02 10:45:30 +02:00
function __nodeLeafList(_list) { #region
2023-03-28 06:58:28 +02:00
var nodes = [];
2023-06-01 10:32:21 +02:00
var nodeNames = [];
2023-03-28 06:58:28 +02:00
2023-08-01 19:21:51 +02:00
for( var i = 0, n = ds_list_size(_list); i < n; i++ ) {
2022-01-24 02:21:25 +01:00
var _node = _list[| i];
2022-12-13 09:20:36 +01:00
if(!_node.active) continue;
2023-06-17 14:30:49 +02:00
if(!_node.isRenderActive()) continue;
2022-12-13 09:20:36 +01:00
2023-03-26 07:13:36 +02:00
var _startNode = _node.isRenderable();
2022-12-13 09:20:36 +01:00
if(_startNode) {
2023-03-28 06:58:28 +02:00
array_push(nodes, _node);
2023-06-01 10:32:21 +02:00
array_push(nodeNames, _node.internalName);
2022-01-24 02:21:25 +01:00
}
}
2023-03-28 06:58:28 +02:00
LOG_LINE_IF(global.FLAG.render == 1, $"Push node {nodeNames} to queue");
2023-03-28 06:58:28 +02:00
return nodes;
2023-10-02 10:45:30 +02:00
} #endregion
2022-01-24 02:21:25 +01:00
2023-10-02 10:45:30 +02:00
function __nodeIsLoop(_node) { #region
2023-02-14 11:40:24 +01:00
switch(instanceof(_node)) {
case "Node_Iterate" :
case "Node_Iterate_Each" :
2023-03-24 05:55:34 +01:00
case "Node_Iterate_Filter" :
case "Node_Iterate_Sort" :
2023-02-14 11:40:24 +01:00
return true;
}
return false;
2023-10-02 10:45:30 +02:00
} #endregion
2023-02-14 11:40:24 +01:00
2023-10-02 10:45:30 +02:00
function __nodeInLoop(_node) { #region
2022-12-16 09:18:09 +01:00
var gr = _node.group;
2023-02-28 09:43:01 +01:00
while(gr != noone) {
2023-02-14 11:40:24 +01:00
if(__nodeIsLoop(gr)) return true;
2022-12-16 09:18:09 +01:00
gr = gr.group;
}
return false;
2023-10-02 10:45:30 +02:00
} #endregion
function ResetAllNodesRender() { #region
LOG_IF(global.FLAG.render == 1, $"XXXXXXXXXXXXXXXXXXXX RESETTING ALL NODES [frame {PROJECT.animator.current_frame}] XXXXXXXXXXXXXXXXXXXX");
2023-10-02 10:45:30 +02:00
var _key = ds_map_find_first(PROJECT.nodeMap);
var amo = ds_map_size(PROJECT.nodeMap);
repeat(amo) {
var _node = PROJECT.nodeMap[? _key];
_node.setRenderStatus(false);
for( var i = 0, n = ds_list_size(_node.inputs); i < n; i++ )
_node.inputs[| i].resetCache();
2023-10-02 10:45:30 +02:00
_key = ds_map_find_next(PROJECT.nodeMap, _key);
}
} #endregion
2022-12-16 09:18:09 +01:00
2023-10-02 10:45:30 +02:00
function Render(partial = false, runAction = false) { #region
LOG_BLOCK_START();
2023-10-02 14:41:44 +02:00
LOG_IF(global.FLAG.render, $"============================== RENDER START [{partial? "PARTIAL" : "FULL"}] [frame {PROJECT.animator.current_frame}] ==============================");
2023-03-28 06:58:28 +02:00
2023-02-14 02:51:14 +01:00
try {
var t = get_timer();
var t1 = get_timer();
var _render_time = 0;
var _leaf_time = 0;
2023-02-14 02:51:14 +01:00
var rendering = noone;
2023-06-01 10:32:21 +02:00
var error = 0;
var reset_all = !partial || ALWAYS_FULL;
2023-03-28 06:58:28 +02:00
2023-06-01 10:32:21 +02:00
if(reset_all) {
2023-07-06 19:49:16 +02:00
var _key = ds_map_find_first(PROJECT.nodeMap);
var amo = ds_map_size(PROJECT.nodeMap);
2022-12-16 09:18:09 +01:00
2023-02-14 02:51:14 +01:00
repeat(amo) {
2023-07-06 19:49:16 +02:00
var _node = PROJECT.nodeMap[? _key];
2023-02-14 02:51:14 +01:00
_node.setRenderStatus(false);
2023-07-06 19:49:16 +02:00
_key = ds_map_find_next(PROJECT.nodeMap, _key);
2023-02-14 02:51:14 +01:00
}
2022-12-10 05:06:01 +01:00
}
2023-10-02 10:45:30 +02:00
2023-02-14 02:51:14 +01:00
// get leaf node
2023-06-01 10:32:21 +02:00
RENDER_QUEUE.clear();
2023-07-06 19:49:16 +02:00
var key = ds_map_find_first(PROJECT.nodeMap);
var amo = ds_map_size(PROJECT.nodeMap);
2023-02-14 02:51:14 +01:00
repeat(amo) {
2023-07-06 19:49:16 +02:00
var _node = PROJECT.nodeMap[? key];
key = ds_map_find_next(PROJECT.nodeMap, key);
2023-10-02 14:41:44 +02:00
if(is_undefined(_node)) { LOG_IF(global.FLAG.render == 1, $"Skip undefiend {_node}"); continue; }
if(!is_struct(_node)) { LOG_IF(global.FLAG.render == 1, $"Skip non-struct {_node}"); continue; }
if(array_exists(global.group_inputs, instanceof(_node))) {
LOG_IF(global.FLAG.render == 1, $"Skip group IO {_node.internalName}");
continue;
}
2023-10-02 14:41:44 +02:00
_node.render_time = 0;
if(!_node.active) { LOG_IF(global.FLAG.render == 1, $"Skip inactive {_node.internalName}"); continue; }
if(!_node.isRenderActive()) { LOG_IF(global.FLAG.render == 1, $"Skip non-renderActive {_node.internalName}"); continue; }
2023-10-06 11:51:11 +02:00
if(!_node.attributes.update_graph) { LOG_IF(global.FLAG.render == 1, $"Skip non-auto update {_node.internalName}"); continue; }
2023-10-02 14:41:44 +02:00
if(_node.rendered && !_node.isAnimated()) {
2023-10-03 11:27:36 +02:00
_node.anim_last_step = false;
LOG_IF(global.FLAG.render == 1, $"Skip rendered {_node.internalName}");
2023-03-29 15:02:03 +02:00
continue;
}
if(__nodeInLoop(_node)) { LOG_IF(global.FLAG.render == 1, $"Skip in-loop {_node.internalName}"); continue; }
2023-03-29 15:02:03 +02:00
LOG_BLOCK_START();
2023-05-22 20:31:55 +02:00
var _startNode = _node.isRenderable(global.FLAG.render);
2023-03-28 06:58:28 +02:00
if(_startNode) {
LOG_IF(global.FLAG.render == 1, $"Found leaf {_node.internalName}");
//if(!reset_all) _node.resetRenderForward();
2023-06-01 10:32:21 +02:00
RENDER_QUEUE.enqueue(_node);
2023-03-29 15:02:03 +02:00
} else
LOG_IF(global.FLAG.render == 1, $"Skip non-leaf {_node.internalName}");
LOG_BLOCK_END();
2022-12-10 05:06:01 +01:00
}
_leaf_time = get_timer() - t;
LOG_IF(global.FLAG.render >= 1, $"Get leaf complete: found {RENDER_QUEUE.size()} leaves in {(get_timer() - t) / 1000} ms."); t = get_timer();
LOG_IF(global.FLAG.render == 1, "================== Start rendering ==================");
2023-02-14 02:51:14 +01:00
// render forward
2023-06-01 10:32:21 +02:00
while(!RENDER_QUEUE.empty()) {
LOG_BLOCK_START();
LOG_IF(global.FLAG.render == 1, $"➤➤➤➤➤➤ CURRENT RENDER QUEUE {RENDER_QUEUE} [{RENDER_QUEUE.size()}] ");
2023-06-01 10:32:21 +02:00
rendering = RENDER_QUEUE.dequeue();
2023-04-04 13:44:37 +02:00
var renderable = rendering.isRenderable();
LOG_IF(global.FLAG.render == 1, $"Rendering {rendering.internalName} ({rendering.display_name}) : {renderable? "Update" : "Pass"}");
2023-03-29 15:02:03 +02:00
2023-04-04 13:44:37 +02:00
if(renderable) {
var _render_pt = get_timer();
2023-03-02 07:59:14 +01:00
rendering.doUpdate();
_render_time += get_timer() - _render_pt;
2023-03-02 07:59:14 +01:00
2023-03-28 06:58:28 +02:00
var nextNodes = rendering.getNextNodes();
2023-10-02 10:45:30 +02:00
for( var i = 0, n = array_length(nextNodes); i < n; i++ ) {
2023-06-01 10:32:21 +02:00
RENDER_QUEUE.enqueue(nextNodes[i]);
2023-10-02 10:45:30 +02:00
}
2023-03-02 07:59:14 +01:00
2023-03-28 06:58:28 +02:00
if(runAction && rendering.hasInspector1Update())
rendering.inspector1Update();
2023-06-13 14:42:06 +02:00
}
2023-03-29 15:02:03 +02:00
LOG_BLOCK_END();
2023-03-02 07:59:14 +01:00
}
_render_time /= 1000;
LOG_IF(global.FLAG.render >= 1, $"=== RENDER COMPLETE IN {(get_timer() - t1) / 1000} ms ===\n");
LOG_IF(global.FLAG.render > 1, $"=== RENDER SUMMARY STA ===");
LOG_IF(global.FLAG.render > 1, $" total time: {(get_timer() - t1) / 1000} ms");
LOG_IF(global.FLAG.render > 1, $" leaf: {_leaf_time / 1000} ms");
LOG_IF(global.FLAG.render > 1, $" render loop: {(get_timer() - t) / 1000} ms");
LOG_IF(global.FLAG.render > 1, $" render only: {_render_time} ms");
LOG_IF(global.FLAG.render > 1, $"=== RENDER SUMMARY END ===");
2023-05-08 10:50:42 +02:00
} catch(e) {
2023-03-02 07:59:14 +01:00
noti_warning(exception_print(e));
2023-05-08 10:50:42 +02:00
}
2023-03-28 06:58:28 +02:00
LOG_END();
2023-10-02 10:45:30 +02:00
} #endregion
2023-03-02 07:59:14 +01:00
2023-10-02 10:45:30 +02:00
function __renderListReset(list) { #region
2023-03-02 07:59:14 +01:00
for( var i = 0; i < ds_list_size(list); i++ ) {
list[| i].setRenderStatus(false);
2023-03-24 05:55:34 +01:00
2023-03-02 07:59:14 +01:00
if(struct_has(list[| i], "nodes"))
__renderListReset(list[| i].nodes);
}
2023-10-02 10:45:30 +02:00
} #endregion
2023-03-02 07:59:14 +01:00
2023-10-02 10:45:30 +02:00
function RenderList(list) { #region
2023-04-23 16:47:33 +02:00
LOG_BLOCK_START();
LOG_IF(global.FLAG.render == 1, "=============== RENDER LIST START ===============");
2023-04-23 16:47:33 +02:00
var queue = ds_queue_create();
try {
var rendering = noone;
var error = 0;
var t = current_time;
__renderListReset(list);
// get leaf node
for( var i = 0; i < ds_list_size(list); i++ ) {
var _node = list[| i];
if(is_undefined(_node)) continue;
2023-06-17 14:30:49 +02:00
if(!is_struct(_node)) continue;
2023-04-23 16:47:33 +02:00
2023-06-17 14:30:49 +02:00
if(!_node.active) continue;
if(!_node.isRenderActive()) continue;
if(_node.rendered) continue;
2023-04-23 16:47:33 +02:00
if(_node.isRenderable())
ds_queue_enqueue(queue, _node);
}
LOG_IF(global.FLAG.render == 1, "Get leaf complete: found " + string(ds_queue_size(queue)) + " leaves.");
LOG_IF(global.FLAG.render == 1, "=== Start rendering ===");
2023-04-23 16:47:33 +02:00
// render forward
while(!ds_queue_empty(queue)) {
2023-06-13 14:42:06 +02:00
LOG_BLOCK_START();
LOG_IF(global.FLAG.render == 1, $"➤➤➤➤➤➤ CURRENT RENDER QUEUE {RENDER_QUEUE}");
2023-06-13 14:42:06 +02:00
rendering = RENDER_QUEUE.dequeue();
if(!ds_list_exist(list, rendering)) continue;
var renderable = rendering.isRenderable();
LOG_IF(global.FLAG.render == 1, $"Rendering {rendering.internalName} ({rendering.display_name}) : {renderable? "Update" : "Pass"}");
2023-04-23 16:47:33 +02:00
2023-06-13 14:42:06 +02:00
if(renderable) {
rendering.doUpdate();
2023-04-23 16:47:33 +02:00
2023-06-13 14:42:06 +02:00
var nextNodes = rendering.getNextNodes();
2023-07-25 20:12:40 +02:00
for( var i = 0, n = array_length(nextNodes); i < n; i++ )
2023-06-13 14:42:06 +02:00
RENDER_QUEUE.enqueue(nextNodes[i]);
2023-04-23 16:47:33 +02:00
2023-06-13 14:42:06 +02:00
if(runAction && rendering.hasInspector1Update())
rendering.inspector1Update();
2023-06-17 14:30:49 +02:00
} else if(rendering.isRenderActive()) {
2023-06-13 14:42:06 +02:00
RENDER_QUEUE.enqueue(rendering);
}
LOG_BLOCK_END();
2023-04-23 16:47:33 +02:00
}
2023-05-08 10:50:42 +02:00
} catch(e) {
2023-04-23 16:47:33 +02:00
noti_warning(exception_print(e));
2023-05-08 10:50:42 +02:00
}
2023-04-23 16:47:33 +02:00
LOG_IF(global.FLAG.render == 1, "=== RENDER COMPLETE ===\n");
2023-04-23 16:47:33 +02:00
LOG_END();
ds_queue_destroy(queue);
2023-10-02 10:45:30 +02:00
} #endregion
2023-04-23 16:47:33 +02:00
2023-10-02 10:45:30 +02:00
function RenderListAction(list, context = PANEL_GRAPH.getCurrentContext()) { #region
2023-07-06 19:49:16 +02:00
printIf(global.FLAG.render, "=== RENDER LIST ACTION START [frame " + string(PROJECT.animator.current_frame) + "] ===");
2023-03-24 05:55:34 +01:00
2023-03-02 07:59:14 +01:00
try {
var rendering = noone;
2023-03-24 05:55:34 +01:00
var error = 0;
var t = current_time;
2023-03-02 07:59:14 +01:00
__renderListReset(list);
// get leaf node
2023-06-01 10:32:21 +02:00
RENDER_QUEUE.clear();
2023-03-02 07:59:14 +01:00
for( var i = 0; i < ds_list_size(list); i++ ) {
var _node = list[| i];
if(is_undefined(_node)) continue;
2023-06-17 14:30:49 +02:00
if(!is_struct(_node)) continue;
2023-03-02 07:59:14 +01:00
2023-06-17 14:30:49 +02:00
if(!_node.active) continue;
if(!_node.isRenderActive()) continue;
if(_node.rendered) continue;
2023-03-02 07:59:14 +01:00
2023-03-24 05:55:34 +01:00
if(_node.isRenderable()) {
2023-06-01 10:32:21 +02:00
RENDER_QUEUE.enqueue(_node);
2023-10-02 14:41:44 +02:00
printIf(global.FLAG.render, $" > Push {_node.internalName} node to queue");
2023-03-02 07:59:14 +01:00
}
}
// render forward
2023-06-01 10:32:21 +02:00
while(!RENDER_QUEUE.empty()) {
2023-06-13 14:42:06 +02:00
LOG_BLOCK_START();
LOG_IF(global.FLAG.render == 1, $"➤➤➤➤➤➤ CURRENT RENDER QUEUE {RENDER_QUEUE}");
2023-06-01 10:32:21 +02:00
rendering = RENDER_QUEUE.dequeue();
2023-06-13 14:42:06 +02:00
if(!ds_list_exist(list, rendering)) continue;
var renderable = rendering.isRenderable();
2023-03-02 07:59:14 +01:00
LOG_IF(global.FLAG.render == 1, $"Rendering {rendering.internalName} ({rendering.display_name}) : {renderable? "Update" : "Pass"}");
2023-03-29 15:02:03 +02:00
2023-06-13 14:42:06 +02:00
if(renderable) {
2023-02-14 02:51:14 +01:00
rendering.doUpdate();
2023-03-28 06:58:28 +02:00
var nextNodes = rendering.getNextNodes();
2023-07-25 20:12:40 +02:00
for( var i = 0, n = array_length(nextNodes); i < n; i++ )
2023-06-01 10:32:21 +02:00
RENDER_QUEUE.enqueue(nextNodes[i]);
2023-06-13 14:42:06 +02:00
if(runAction && rendering.hasInspector1Update())
rendering.inspector1Update();
2023-06-17 14:30:49 +02:00
} else if(rendering.isRenderActive()) {
2023-06-13 14:42:06 +02:00
RENDER_QUEUE.enqueue(rendering);
2023-02-14 02:51:14 +01:00
}
2023-03-29 15:02:03 +02:00
2023-06-13 14:42:06 +02:00
LOG_BLOCK_END();
2022-01-13 05:24:03 +01:00
}
2022-12-12 09:08:03 +01:00
2023-05-22 20:31:55 +02:00
printIf(global.FLAG.render, "=== RENDER COMPLETE IN {" + string(current_time - t) + "ms} ===\n");
2023-05-08 10:50:42 +02:00
} catch(e) {
2023-07-14 20:34:35 +02:00
noti_warning(exception_print(e));
2023-05-08 10:50:42 +02:00
}
2023-10-02 10:45:30 +02:00
} #endregion