- [Path] Fix path change shape when updating later nodes.

This commit is contained in:
Tanasart 2023-09-20 15:32:36 +02:00
parent d07b2ab601
commit b22d506a61
2 changed files with 34 additions and 28 deletions

View file

@ -212,14 +212,14 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
if(_useDistance) { if(_useDistance) {
_pathStr *= _pathLength; _pathStr *= _pathLength;
_pathEnd *= _pathLength; _pathEnd *= _pathLength;
_stepLen = min(_segL, _pathEnd); //TODO: Change this to node input _stepLen = min(_segL, _pathEnd);
_total *= _pathLength; _total *= _pathLength;
_total_prev = _total; _total_prev = _total;
_prog_curr *= _pathLength; _prog_curr *= _pathLength;
} }
while(_total >= 0) { while(_total >= 0) {
if(_useDistance) { if(_useDistance) {
var segmentLength = array_safe_get(_segLength, _segIndex, 99999); var segmentLength = array_safe_get(_segLength, _segIndex, 99999);
@ -242,13 +242,13 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
if(struct_has(_pat, "getWeightRatio")) if(struct_has(_pat, "getWeightRatio"))
wght = _pat.getWeightRatio(_prog_curr, i); wght = _pat.getWeightRatio(_prog_curr, i);
} else if(!_useDistance) { } else {
p = _pat.getPointRatio(_prog_curr, i); p = _pat.getPointRatio(_prog_curr, i);
if(struct_has(_pat, "getWeightDistance")) if(struct_has(_pat, "getWeightDistance"))
wght = _pat.getWeightDistance(_prog_curr, i); wght = _pat.getWeightDistance(_prog_curr, i);
} }
_nx = p.x; _nx = p.x;
_ny = p.y; _ny = p.y;
@ -280,7 +280,7 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
if(_total_prev == _total && ++_freeze > 16) break; if(_total_prev == _total && ++_freeze > 16) break;
_total_prev = _total; _total_prev = _total;
} }
array_push(lines, points); array_push(lines, points);
} }
} else { } else {

View file

@ -161,10 +161,10 @@ function Node_Path(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
var dy = my - transform_my; var dy = my - transform_my;
for( var i = input_fix_len; i < ds_list_size(inputs); i++ ) { for( var i = input_fix_len; i < ds_list_size(inputs); i++ ) {
var p = inputs[| i].getValue(); var _p = inputs[| i].getValue();
p = [ var p = [
p[0] + dx / _s, _p[0] + dx / _s,
p[1] + dy / _s _p[1] + dy / _s
]; ];
if(inputs[| i].setValue(p)) if(inputs[| i].setValue(p))
@ -833,9 +833,9 @@ function Node_Path(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
var sample = PREF_MAP[? "path_resolution"]; var sample = PREF_MAP[? "path_resolution"];
var con = loop? ansize : ansize - 1; var con = loop? ansize : ansize - 1;
lengths = []; lengths = [];
lengthAccs = []; lengthAccs = [];
array_resize(anchors, ansize); anchors = array_create(ansize);
for(var i = 0; i < con; i++) { for(var i = 0; i < con; i++) {
var index_0 = input_fix_len + i; var index_0 = input_fix_len + i;
@ -844,14 +844,17 @@ function Node_Path(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
var _a0 = array_clone(inputs[| index_0].getValue()); var _a0 = array_clone(inputs[| index_0].getValue());
var _a1 = array_clone(inputs[| index_1].getValue()); var _a1 = array_clone(inputs[| index_1].getValue());
anchors[i + 0] = _a0;
anchors[i + 1] = _a1;
if(rond) { if(rond) {
_a0[0] = round(_a0[0]); _a0[1] = round(_a0[1]); _a0[0] = round(_a0[0]);
_a1[0] = round(_a1[0]); _a1[1] = round(_a1[1]); _a0[1] = round(_a0[1]);
_a1[0] = round(_a1[0]);
_a1[1] = round(_a1[1]);
} }
anchors[i + 0] = array_clone(_a0);
anchors[i + 1] = array_clone(_a1);
var l = 0, _ox = 0, _oy = 0, _nx = 0, _ny = 0, p = 0; var l = 0, _ox = 0, _oy = 0, _nx = 0, _ny = 0, p = 0;
for(var j = 0; j < sample; j++) { for(var j = 0; j < sample; j++) {
p = eval_bezier(j / sample, _a0[0], _a0[1], _a1[0], _a1[1], _a0[0] + _a0[4], _a0[1] + _a0[5], _a1[0] + _a1[2], _a1[1] + _a1[3]); p = eval_bezier(j / sample, _a0[0], _a0[1], _a1[0], _a1[1], _a0[0] + _a0[4], _a0[1] + _a0[5], _a1[0] + _a1[2], _a1[1] + _a1[3]);
@ -880,8 +883,9 @@ function Node_Path(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
static getPointDistance = function(_dist) { #region static getPointDistance = function(_dist) { #region
if(ds_map_exists(cached_pos, _dist)) if(ds_map_exists(cached_pos, _dist))
return cached_pos[? _dist]; return cached_pos[? _dist].clone();
var _oDist = _dist;
var loop = inputs[| 1].getValue(); var loop = inputs[| 1].getValue();
var rond = inputs[| 3].getValue(); var rond = inputs[| 3].getValue();
if(!is_real(rond)) rond = false; if(!is_real(rond)) rond = false;
@ -894,13 +898,18 @@ function Node_Path(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
var _a0, _a1; var _a0, _a1;
for(var i = 0; i < ansize; i++) { for(var i = 0; i < ansize; i++) {
_a0 = anchors[safe_mod(i + 0, amo)]; _a0 = array_clone(anchors[safe_mod(i + 0, amo)]);
_a1 = anchors[safe_mod(i + 1, amo)]; _a1 = array_clone(anchors[safe_mod(i + 1, amo)]);
if(!is_array(_a0) || !is_array(_a1))
return new __vec2();
if(rond) { if(rond) {
_a0[0] = round(_a0[0]); _a0[1] = round(_a0[1]); _a0[0] = round(_a0[0]);
_a1[0] = round(_a1[0]); _a1[1] = round(_a1[1]); _a0[1] = round(_a0[1]);
} _a1[0] = round(_a1[0]);
_a1[1] = round(_a1[1]);
}
if(_dist > lengths[i]) { if(_dist > lengths[i]) {
_dist -= lengths[i]; _dist -= lengths[i];
@ -908,13 +917,10 @@ function Node_Path(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
} }
var _t = _dist / lengths[i]; var _t = _dist / lengths[i];
var _p = eval_bezier(_t, _a0[0], _a0[1], _a1[0], _a1[1], _a0[0] + _a0[4], _a0[1] + _a0[5], _a1[0] + _a1[2], _a1[1] + _a1[3]);
if(!is_array(_a0) || !is_array(_a1))
return new __vec2();
var _p = eval_bezier(_t, _a0[0], _a0[1], _a1[0], _a1[1], _a0[0] + _a0[4], _a0[1] + _a0[5], _a1[0] + _a1[2], _a1[1] + _a1[3]);
var _point = new __vec2(_p); var _point = new __vec2(_p);
cached_pos[? _dist] = _point;
cached_pos[? _oDist] = _point.clone();
return _point; return _point;
} }