Pixel-Composer/scripts/node_path_array/node_path_array.gml

141 lines
4.0 KiB
Plaintext
Raw Normal View History

2023-03-07 14:29:47 +01:00
function Node_Path_Array(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
name = "Path Array";
w = 96;
2023-03-07 14:29:47 +01:00
2023-08-05 14:00:33 +02:00
setIsDynamicInput(1);
cached_pos = ds_map_create();
2023-03-07 14:29:47 +01:00
outputs[| 0] = nodeValue("Path array", self, JUNCTION_CONNECT.output, VALUE_TYPE.pathnode, self);
2023-10-11 02:20:03 +02:00
static createNewInput = function() { #region
2023-03-07 14:29:47 +01:00
var index = ds_list_size(inputs);
inputs[| index] = nodeValue("Path", self, JUNCTION_CONNECT.input, VALUE_TYPE.pathnode, noone )
.setVisible(true, true);
return inputs[| index];
2023-10-11 02:20:03 +02:00
} if(!LOADING && !APPENDING) createNewInput(); #endregion
2023-03-07 14:29:47 +01:00
2023-10-11 02:20:03 +02:00
static refreshDynamicInput = function() { #region
2023-03-07 14:29:47 +01:00
var _l = ds_list_create();
2023-03-11 01:40:17 +01:00
for( var i = 0; i < input_fix_len; i++ )
2023-03-07 14:29:47 +01:00
_l[| i] = inputs[| i];
2023-03-11 01:40:17 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs); i += data_length ) {
2023-03-07 14:29:47 +01:00
if(inputs[| i].value_from)
ds_list_add(_l, inputs[| i]);
else
delete inputs[| i];
}
for( var i = 0; i < ds_list_size(_l); i++ )
_l[| i].index = i;
ds_list_destroy(inputs);
inputs = _l;
createNewInput();
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-07 14:29:47 +01:00
2023-10-11 02:20:03 +02:00
static onValueFromUpdate = function(index) { #region
2023-03-07 14:29:47 +01:00
if(LOADING || APPENDING) return;
refreshDynamicInput();
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-07 14:29:47 +01:00
2023-10-11 02:20:03 +02:00
static getLineCount = function() { #region
2023-03-07 14:29:47 +01:00
var l = 0;
2023-03-11 01:40:17 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
2023-03-07 14:29:47 +01:00
l += struct_has(_path, "getLineCount")? _path.getLineCount() : 1;
}
return l;
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-07 14:29:47 +01:00
2023-10-11 02:20:03 +02:00
static getSegmentCount = function(ind = 0) { #region
2023-03-19 09:17:39 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
2023-03-19 09:17:39 +01:00
var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1;
2023-08-02 19:11:57 +02:00
if(ind < lc) return _path.getSegmentCount(ind);
2023-03-19 09:17:39 +01:00
ind -= lc;
}
return 0;
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-19 09:17:39 +01:00
2023-10-11 02:20:03 +02:00
static getLength = function(ind = 0) { #region
2023-03-19 09:17:39 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
2023-03-19 09:17:39 +01:00
var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1;
2023-08-02 19:11:57 +02:00
if(ind < lc) return _path.getLength(ind);
2023-03-19 09:17:39 +01:00
ind -= lc;
}
return 0;
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-19 09:17:39 +01:00
2023-10-11 02:20:03 +02:00
static getAccuLength = function(ind = 0) { #region
2023-03-19 09:17:39 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
2023-03-19 09:17:39 +01:00
var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1;
2023-03-29 15:02:03 +02:00
if(ind < lc) return _path.getAccuLength(ind);
2023-03-19 09:17:39 +01:00
ind -= lc;
}
return 0;
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-19 09:17:39 +01:00
2023-11-28 06:50:54 +01:00
static getPointRatio = function(_rat, ind = 0) { #region
2023-03-19 09:17:39 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
2023-08-02 19:11:57 +02:00
var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1;
2023-03-19 09:17:39 +01:00
2023-11-28 06:50:54 +01:00
if(ind < lc) return _path.getPointRatio(_rat, ind).clone();
2023-03-19 09:17:39 +01:00
ind -= lc;
}
return new __vec2();
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-07 14:29:47 +01:00
2023-11-28 06:50:54 +01:00
static getPointDistance = function(_dist, ind = 0) { #region
2023-03-11 01:40:17 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
2023-03-07 14:29:47 +01:00
var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1;
2023-11-28 06:50:54 +01:00
if(ind < lc) return _path.getPointDistance(_dist, ind).clone();
2023-03-19 09:17:39 +01:00
ind -= lc;
}
return new __vec2();
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-19 09:17:39 +01:00
2023-10-11 02:20:03 +02:00
static getBoundary = function(ind = 0) { #region
2023-03-19 09:17:39 +01:00
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
2023-08-02 19:11:57 +02:00
var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1;
2023-03-19 09:17:39 +01:00
2023-08-02 19:11:57 +02:00
if(ind < lc) return _path.getBoundary(ind);
2023-03-07 14:29:47 +01:00
ind -= lc;
}
2023-08-02 19:11:57 +02:00
return 0;
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-07 14:29:47 +01:00
2023-11-28 06:50:54 +01:00
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) { #region
for( var i = input_fix_len; i < ds_list_size(inputs) - 1; i += data_length ) {
var _path = getInputData(i);
if(!struct_has(_path, "drawOverlay")) continue;
_path.drawOverlay(active, _x, _y, _s, _mx, _my, _snx, _sny);
}
} #endregion
2023-10-11 02:20:03 +02:00
static update = function(frame = CURRENT_FRAME) { #region
ds_map_clear(cached_pos);
2023-03-07 14:29:47 +01:00
outputs[| 0].setValue(self);
2023-10-11 02:20:03 +02:00
} #endregion
2023-03-07 14:29:47 +01:00
}