mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2024-12-26 06:56:45 +01:00
151 lines
No EOL
4.2 KiB
Text
151 lines
No EOL
4.2 KiB
Text
function Node_Path_Builder(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|
name = "Path Builder";
|
|
previewable = false;
|
|
|
|
w = 96;
|
|
length = 0;
|
|
lengthAcc = [];
|
|
|
|
inputs[| 0] = nodeValue("Point array", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [])
|
|
.setVisible(true, true)
|
|
.setArrayDepth(2);
|
|
|
|
inputs[| 1] = nodeValue("Connected", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false, "If set to true, will draw a single path from one point to another. If not set will treat each pair of points as an individual line.");
|
|
|
|
outputs[| 0] = nodeValue("Path", self, JUNCTION_CONNECT.output, VALUE_TYPE.pathnode, self);
|
|
|
|
static drawOverlay = function(active, _x, _y, _s, _mx, _my, _snx, _sny) {
|
|
var _lines = inputs[| 0].getValue();
|
|
var _conn = inputs[| 1].getValue();
|
|
|
|
draw_set_color(COLORS._main_accent);
|
|
|
|
if(_conn) {
|
|
for( var i = 1, n = array_length(_lines); i < n; i++ ) {
|
|
var p0 = _lines[i - 1];
|
|
var p1 = _lines[i - 0];
|
|
|
|
draw_line(_x + p0[0] * _s, _y + p0[1] * _s,
|
|
_x + p1[0] * _s, _y + p1[1] * _s);
|
|
}
|
|
} else {
|
|
var len = floor(array_length(_lines) / 2) * 2;
|
|
|
|
for( var i = 0; i < len; i += 2 ) {
|
|
var p0 = _lines[i + 0];
|
|
var p1 = _lines[i + 1];
|
|
|
|
draw_line(_x + p0[0] * _s, _y + p0[1] * _s,
|
|
_x + p1[0] * _s, _y + p1[1] * _s);
|
|
}
|
|
}
|
|
}
|
|
|
|
static getLineCount = function() {
|
|
var _lines = inputs[| 0].getValue();
|
|
var _conn = inputs[| 1].getValue();
|
|
|
|
return _conn? 1 : floor(array_length(_lines) / 2);
|
|
}
|
|
|
|
static getSegmentCount = function() {
|
|
var _lines = inputs[| 0].getValue();
|
|
var _conn = inputs[| 1].getValue();
|
|
|
|
return _conn? array_length(_lines) - 1 : 1;
|
|
}
|
|
|
|
static getLength = function(index) { return is_array(length)? array_safe_get(length, index) : length; }
|
|
|
|
static getAccuLength = function(index) { return array_safe_get(lengthAcc, index, []); }
|
|
|
|
static getPointRatio = function(_rat, _ind = 0) {
|
|
var _lines = inputs[| 0].getValue();
|
|
var _conn = inputs[| 1].getValue();
|
|
var _p0, _p1;
|
|
var _x, _y;
|
|
|
|
if(_conn) {
|
|
var _st = _rat * (array_length(_lines) - 1);
|
|
_p0 = array_safe_get(_lines, floor(_st) + 0,, ARRAY_OVERFLOW._default);
|
|
_p1 = array_safe_get(_lines, floor(_st) + 1,, ARRAY_OVERFLOW._default);
|
|
|
|
if(!is_array(_p0)) return new __vec2();
|
|
if(!is_array(_p1)) return new __vec2();
|
|
|
|
_x = lerp(_p0[0], _p1[0], frac(_st));
|
|
_y = lerp(_p0[1], _p1[1], frac(_st));
|
|
|
|
return new __vec2( _x, _y );
|
|
} else {
|
|
_p0 = array_safe_get(_lines, _ind * 2 + 0,, ARRAY_OVERFLOW._default);
|
|
_p1 = array_safe_get(_lines, _ind * 2 + 1,, ARRAY_OVERFLOW._default);
|
|
|
|
if(!is_array(_p0)) return new __vec2();
|
|
if(!is_array(_p1)) return new __vec2();
|
|
|
|
_x = lerp(_p0[0], _p1[0], _rat);
|
|
_y = lerp(_p0[1], _p1[1], _rat);
|
|
|
|
return new __vec2( _x, _y );
|
|
}
|
|
}
|
|
|
|
static getPointDistance = function(_dist, ind = 0) {
|
|
var _conn = inputs[| 1].getValue();
|
|
|
|
if(_conn) return getPointRatio(_dist / length);
|
|
else return getPointRatio(_dist / length[ind], ind);
|
|
}
|
|
|
|
static getBoundary = function() {
|
|
var boundary = new BoundingBox();
|
|
var _lines = inputs[| 0].getValue();
|
|
for( var i = 0, n = array_length(_lines); i < n; i++ )
|
|
boundary.addPoint(_lines[i][0], _lines[i][1]);
|
|
|
|
return boundary;
|
|
}
|
|
|
|
function update() {
|
|
var _lines = inputs[| 0].getValue();
|
|
var _conn = inputs[| 1].getValue();
|
|
|
|
if(_conn) {
|
|
length = 0;
|
|
lengthAcc = [];
|
|
|
|
for( var i = 1, n = array_length(_lines); i < n; i++ ) {
|
|
var p0 = _lines[i - 1];
|
|
var p1 = _lines[i - 0];
|
|
|
|
var dist = point_distance(p0[0], p0[1], p1[0], p1[1]);
|
|
|
|
length += dist;
|
|
array_push(lengthAcc, length);
|
|
}
|
|
} else {
|
|
length = [];
|
|
lengthAcc = [];
|
|
|
|
var len = floor(array_length(_lines) / 2) * 2;
|
|
|
|
for( var i = 0; i < len; i += 2 ) {
|
|
var p0 = _lines[i + 0];
|
|
var p1 = _lines[i + 1];
|
|
|
|
var dist = point_distance(p0[0], p0[1], p1[0], p1[1]);
|
|
|
|
array_push(length, dist);
|
|
array_push(lengthAcc, [ dist ]);
|
|
}
|
|
}
|
|
|
|
outputs[| 0].setValue(self);
|
|
}
|
|
|
|
static onDrawNode = function(xx, yy, _mx, _my, _s, _hover, _focus) {
|
|
var bbox = drawGetBbox(xx, yy, _s);
|
|
draw_sprite_fit(s_node_path_builder, 0, bbox.xc, bbox.yc, bbox.w, bbox.h);
|
|
}
|
|
} |