mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2024-12-25 14:36:13 +01:00
130 lines
No EOL
3.5 KiB
Text
130 lines
No EOL
3.5 KiB
Text
function Node_Switch(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|
name = "Switch";
|
|
previewable = false;
|
|
|
|
w = 96;
|
|
|
|
|
|
inputs[| 0] = nodeValue("Index", self, JUNCTION_CONNECT.input, VALUE_TYPE.text, "" )
|
|
.setVisible(true, true)
|
|
.rejectArray();
|
|
|
|
inputs[| 1] = nodeValue("Default value", self, JUNCTION_CONNECT.input, VALUE_TYPE.any, 0 )
|
|
.setVisible(false, true);
|
|
|
|
static createNewInput = function() {
|
|
var index = ds_list_size(inputs);
|
|
inputs[| index + 0] = nodeValue("Case", self, JUNCTION_CONNECT.input, VALUE_TYPE.text, "" );
|
|
|
|
inputs[| index + 1] = nodeValue("value", self, JUNCTION_CONNECT.input, VALUE_TYPE.any, 0 )
|
|
.setVisible(false, true);
|
|
|
|
array_push(input_display_list, index + 0);
|
|
array_push(input_display_list, index + 1);
|
|
}
|
|
|
|
outputs[| 0] = nodeValue("Result", self, JUNCTION_CONNECT.output, VALUE_TYPE.any, 0);
|
|
|
|
input_display_list = [ 0,
|
|
["Inputs", false], 1
|
|
]
|
|
|
|
setIsDynamicInput(2);
|
|
|
|
if(!LOADING && !APPENDING) createNewInput();
|
|
|
|
static refreshDynamicInput = function() {
|
|
var _in = ds_list_create();
|
|
|
|
for( var i = 0; i < input_fix_len; i++ )
|
|
ds_list_add(_in, inputs[| i]);
|
|
|
|
array_resize(input_display_list, input_display_len);
|
|
|
|
for( var i = input_fix_len; i < ds_list_size(inputs); i += data_length ) {
|
|
if(inputs[| i].getValue() != "") {
|
|
ds_list_add(_in, inputs[| i + 0]);
|
|
ds_list_add(_in, inputs[| i + 1]);
|
|
|
|
array_push(input_display_list, i + 0);
|
|
array_push(input_display_list, i + 1);
|
|
} else {
|
|
delete inputs[| i + 0];
|
|
delete inputs[| i + 1];
|
|
}
|
|
}
|
|
|
|
for( var i = 0; i < ds_list_size(_in); i++ )
|
|
_in[| i].index = i;
|
|
|
|
ds_list_destroy(inputs);
|
|
inputs = _in;
|
|
|
|
createNewInput();
|
|
}
|
|
|
|
static onValueFromUpdate = function(index) {
|
|
if(LOADING || APPENDING) return;
|
|
|
|
inputs[| 1].type = inputs[| 1].value_from? inputs[| 1].value_from.type : VALUE_TYPE.any;
|
|
|
|
for( var i = input_fix_len; i < ds_list_size(inputs); i += data_length ) {
|
|
inputs[| i + 1].type = VALUE_TYPE.any;
|
|
if(inputs[| i + 1].value_from != noone)
|
|
inputs[| i + 1].type = inputs[| i + 1].value_from.type;
|
|
}
|
|
}
|
|
|
|
static onValueUpdate = function(index = 0) {
|
|
if(index < input_fix_len) return;
|
|
if(LOADING || APPENDING) return;
|
|
|
|
if(safe_mod(index - input_fix_len, data_length) == 0) { //Variable name
|
|
inputs[| index + 1].name = inputs[| index].getValue() + " value";
|
|
}
|
|
|
|
refreshDynamicInput();
|
|
}
|
|
|
|
static update = function(frame = PROJECT.animator.current_frame) {
|
|
var sele = inputs[| 0].getValue();
|
|
var _res = inputs[| 1].getValue();
|
|
|
|
outputs[| 0].type = inputs[| 1].value_from? inputs[| 1].value_from.type : VALUE_TYPE.any;
|
|
|
|
for( var i = input_fix_len; i < ds_list_size(inputs) - data_length; i += data_length ) {
|
|
var _cas = inputs[| i + 0].getValue();
|
|
var _val = inputs[| i + 1].getValue();
|
|
|
|
if(sele == _cas) {
|
|
_res = _val;
|
|
outputs[| 0].type = inputs[| i + 1].type;
|
|
}
|
|
}
|
|
|
|
outputs[| 0].setValue(_res);
|
|
}
|
|
|
|
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) {
|
|
var frm = inputs[| 1];
|
|
var sele = inputs[| 0].getValue();
|
|
var _res = inputs[| 1].getValue();
|
|
|
|
for( var i = input_fix_len; i < ds_list_size(inputs) - data_length; i += data_length ) {
|
|
var _cas = inputs[| i + 0].getValue();
|
|
if(sele == _cas) frm = inputs[| i + 1];
|
|
}
|
|
|
|
var to = outputs[| 0];
|
|
var c0 = value_color(frm.type);
|
|
|
|
draw_set_color(c0);
|
|
draw_set_alpha(0.5);
|
|
draw_line_width(frm.x, frm.y, to.x, to.y, _s * 4);
|
|
draw_set_alpha(1);
|
|
}
|
|
|
|
static doApplyDeserialize = function() {
|
|
refreshDynamicInput();
|
|
}
|
|
} |