function Node_Path_Array(_x, _y, _group = noone) : Node(_x, _y, _group) constructor { name = "Path Combine"; setDimension(96, 48); cached_pos = ds_map_create(); outputs[0] = nodeValue_Output("Combined Path", self, VALUE_TYPE.pathnode, self); static createNewInput = function() { var index = array_length(inputs); newInput(index, nodeValue_PathNode("Path", self, noone )) .setVisible(true, true); return inputs[index]; } setDynamicInput(1, true, VALUE_TYPE.pathnode); static getLineCount = function() { var l = 0; for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); l += struct_has(_path, "getLineCount")? _path.getLineCount() : 1; } return l; } static getSegmentCount = function(ind = 0) { for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1; if(ind < lc) return _path.getSegmentCount(ind); ind -= lc; } return 0; } static getLength = function(ind = 0) { for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1; if(ind < lc) return _path.getLength(ind); ind -= lc; } return 0; } static getAccuLength = function(ind = 0) { for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1; if(ind < lc) return _path.getAccuLength(ind); ind -= lc; } return 0; } static getPointRatio = function(_rat, ind = 0) { for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1; if(ind < lc) return _path.getPointRatio(_rat, ind).clone(); ind -= lc; } return new __vec2(); } static getPointDistance = function(_dist, ind = 0) { for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1; if(ind < lc) return _path.getPointDistance(_dist, ind).clone(); ind -= lc; } return new __vec2(); } static getBoundary = function(ind = 0) { for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); var lc = struct_has(_path, "getLineCount")? _path.getLineCount() : 1; if(ind < lc) return _path.getBoundary(ind); ind -= lc; } return 0; } static drawOverlay = function(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) { for( var i = input_fix_len; i < array_length(inputs); i += data_length ) { var _path = getInputData(i); if(!struct_has(_path, "drawOverlay")) continue; if(_path && struct_has(_path, "drawOverlay")) _path.drawOverlay(hover, active, _x, _y, _s, _mx, _my, _snx, _sny); } } static update = function(frame = CURRENT_FRAME) { ds_map_clear(cached_pos); outputs[0].setValue(self); } }