mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-25 20:38:07 +01:00
229 lines
No EOL
5.1 KiB
Text
229 lines
No EOL
5.1 KiB
Text
enum COLLECTION_TAG {
|
|
group = 1,
|
|
loop = 2
|
|
}
|
|
|
|
function Node_Collection(_x, _y, _group = -1) : Node(_x, _y, _group) constructor {
|
|
nodes = ds_list_create();
|
|
ungroupable = true;
|
|
|
|
custom_input_index = 0;
|
|
custom_output_index = 0;
|
|
|
|
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
|
for(var i = custom_input_index; i < ds_list_size(inputs); i++) {
|
|
var _in = inputs[| i];
|
|
var _show = _in.from.inputs[| 6].getValue();
|
|
|
|
if(!_show) continue;
|
|
_in.drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
|
|
}
|
|
}
|
|
|
|
static getNextNodes = function() {
|
|
for(var i = custom_input_index; i < ds_list_size(inputs); i++) {
|
|
var _in = inputs[| i].from;
|
|
|
|
ds_queue_enqueue(RENDER_QUEUE, _in);
|
|
printIf(global.RENDER_LOG, "Push group input " + _in.name + " to stack");
|
|
}
|
|
}
|
|
|
|
static setRenderStatus = function(result) {
|
|
rendered = result;
|
|
|
|
if(result) {
|
|
var siz = ds_list_size(outputs);
|
|
for( var i = custom_output_index; i < siz; i++ ) {
|
|
var _o = outputs[| i];
|
|
if(_o.node.rendered) continue;
|
|
|
|
rendered = false;
|
|
break;
|
|
}
|
|
}
|
|
|
|
if(!result && group != -1)
|
|
group.setRenderStatus(result);
|
|
}
|
|
|
|
function add(_node) {
|
|
ds_list_add(nodes, _node);
|
|
var list = _node.group == -1? PANEL_GRAPH.nodes_list : _node.group.nodes;
|
|
var _pos = ds_list_find_index(list, _node);
|
|
ds_list_delete(list, _pos);
|
|
|
|
recordAction(ACTION_TYPE.group_added, self, _node);
|
|
_node.group = self;
|
|
}
|
|
|
|
function remove(_node) {
|
|
var _pos = ds_list_find_index(nodes, _node);
|
|
ds_list_delete(nodes, _pos);
|
|
var list = group == -1? PANEL_GRAPH.nodes_list : group.nodes;
|
|
ds_list_add(list, _node);
|
|
|
|
recordAction(ACTION_TYPE.group_removed, self, _node);
|
|
|
|
switch(instanceof(_node)) {
|
|
case "Node_Group_Input" :
|
|
case "Node_Group_Output" :
|
|
case "Node_Iterator_Input" :
|
|
case "Node_Iterator_Output" :
|
|
case "Node_Iterator_Index" :
|
|
nodeDelete(_node);
|
|
break;
|
|
default :
|
|
_node.group = group;
|
|
}
|
|
|
|
_node.x += x;
|
|
_node.y += y;
|
|
}
|
|
|
|
static clearCache = function() {
|
|
for(var i = 0; i < ds_list_size(nodes); i++) {
|
|
nodes[| i].clearCache();
|
|
}
|
|
}
|
|
|
|
static inspectorGroupUpdate = function() {
|
|
for(var i = 0; i < ds_list_size(nodes); i++) {
|
|
var _node = nodes[| i];
|
|
if(_node.inspectorUpdate == noone) continue;
|
|
|
|
_node.inspectorUpdate();
|
|
}
|
|
}
|
|
|
|
static stepBegin = function() {
|
|
use_cache = false;
|
|
inspectorUpdate = noone;
|
|
|
|
array_safe_set(cache_result, ANIMATOR.current_frame, true);
|
|
|
|
for(var i = 0; i < ds_list_size(nodes); i++) {
|
|
var n = nodes[| i];
|
|
n.stepBegin();
|
|
if(n.inspectorUpdate != noone)
|
|
inspectorUpdate = inspectorGroupUpdate;
|
|
if(!n.use_cache) continue;
|
|
|
|
use_cache = true;
|
|
if(!array_safe_get(n.cache_result, ANIMATOR.current_frame))
|
|
array_safe_set(cache_result, ANIMATOR.current_frame, false);
|
|
}
|
|
|
|
var out_surf = false;
|
|
|
|
for( var i = 0; i < ds_list_size(outputs); i++) {
|
|
if(outputs[| i].type == VALUE_TYPE.surface)
|
|
out_surf = true;
|
|
}
|
|
|
|
if(out_surf) {
|
|
w = 128;
|
|
min_h = 128;
|
|
} else {
|
|
w = 96;
|
|
|
|
}
|
|
|
|
setHeight();
|
|
doStepBegin();
|
|
}
|
|
|
|
static step = function() {
|
|
render_time = 0;
|
|
for(var i = 0; i < ds_list_size(nodes); i++) {
|
|
nodes[| i].step();
|
|
render_time += nodes[| i].render_time;
|
|
}
|
|
|
|
if(PANEL_GRAPH.node_focus == self && panelFocus(PANEL_GRAPH) && DOUBLE_CLICK) {
|
|
PANEL_GRAPH.addContext(self);
|
|
DOUBLE_CLICK = false;
|
|
}
|
|
|
|
onStep();
|
|
}
|
|
|
|
static onStep = function() {}
|
|
|
|
static triggerRender = function() {
|
|
for(var i = custom_input_index; i < ds_list_size(inputs); i++) {
|
|
var jun_node = inputs[| i].from;
|
|
jun_node.triggerRender();
|
|
}
|
|
}
|
|
|
|
static preConnect = function() {
|
|
sortIO();
|
|
deserialize(load_map, load_scale);
|
|
}
|
|
|
|
static sortIO = function() {
|
|
var siz = ds_list_size(inputs);
|
|
var ar = ds_priority_create();
|
|
|
|
for( var i = custom_input_index; i < siz; i++ ) {
|
|
var _in = inputs[| i];
|
|
var _or = _in.from.inputs[| 5].getValue();
|
|
|
|
ds_priority_add(ar, _in, _or);
|
|
}
|
|
|
|
for( var i = siz - 1; i >= custom_input_index; i-- ) {
|
|
ds_list_delete(inputs, i);
|
|
}
|
|
|
|
for( var i = custom_input_index; i < siz; i++ ) {
|
|
var _jin = ds_priority_delete_min(ar);
|
|
_jin.index = i;
|
|
ds_list_add(inputs, _jin);
|
|
}
|
|
|
|
ds_priority_destroy(ar);
|
|
|
|
var siz = ds_list_size(outputs);
|
|
var ar = ds_priority_create();
|
|
|
|
for( var i = custom_output_index; i < siz; i++ ) {
|
|
var _out = outputs[| i];
|
|
var _or = _out.from.inputs[| 1].getValue();
|
|
|
|
ds_priority_add(ar, _out, _or);
|
|
}
|
|
|
|
for( var i = siz - 1; i >= custom_output_index; i-- ) {
|
|
ds_list_delete(outputs, i);
|
|
}
|
|
|
|
for( var i = custom_output_index; i < siz; i++ ) {
|
|
var _jout = ds_priority_delete_min(ar);
|
|
_jout.index = i;
|
|
ds_list_add(outputs, _jout);
|
|
}
|
|
|
|
ds_priority_destroy(ar);
|
|
}
|
|
|
|
static onDestroy = function() {
|
|
for( var i = 0; i < ds_list_size(nodes); i++ ) {
|
|
nodes[| i].destroy();
|
|
}
|
|
}
|
|
|
|
static resetAllRenderStatus = function() {
|
|
for( var i = 0; i < ds_list_size(nodes); i++ ) {
|
|
nodes[| i].setRenderStatus(false);
|
|
if(variable_struct_exists(nodes[| i], "nodes"))
|
|
nodes[| i].resetAllRenderStatus();
|
|
}
|
|
}
|
|
|
|
static preConnect = function() {
|
|
sortIO();
|
|
applyDeserialize();
|
|
}
|
|
} |