path mask bigs

This commit is contained in:
Tanasart 2024-06-03 19:59:18 +07:00
parent fd70ca9292
commit 35cf8d023c
2 changed files with 105 additions and 92 deletions

View file

@ -104,6 +104,8 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
y1 = _y + y1 * _s; y1 = _y + y1 * _s;
draw_line(x0, y0, x1, y1); draw_line(x0, y0, x1, y1);
draw_circle(x0, y0, 4, false);
} }
} }
} #endregion } #endregion
@ -230,8 +232,7 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
var _prog_next = 0; var _prog_next = 0;
var _prog = _prog_curr + 1; //Record previous position to delete from _total var _prog = _prog_curr + 1; //Record previous position to delete from _total
var _prog_total = 0; //Record the distance the pointer has moved so far var _prog_total = 0; //Record the distance the pointer has moved so far
var points = is_array(lines[i])? lines[i] : []; var points = [];
var pointArrLen = array_length(points);
var pointAmo = 0; var pointAmo = 0;
var wght; var wght;
var _pathPng; var _pathPng;
@ -296,6 +297,7 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
_nx = p.x; _nx = p.x;
_ny = p.y; _ny = p.y;
// print($"{_nx}, {_ny}");
if(_total < _pathEnd) { //Do not wiggle the last point. if(_total < _pathEnd) { //Do not wiggle the last point.
var _d = point_direction(_ox, _oy, _nx, _ny); var _d = point_direction(_ox, _oy, _nx, _ny);
@ -304,26 +306,13 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
} }
if(_prog_total >= _pathStr) { //Do not add point before range start. Do this instead of starting at _rtStr to prevent wiggle. if(_prog_total >= _pathStr) { //Do not add point before range start. Do this instead of starting at _rtStr to prevent wiggle.
var _pntData; points[pointAmo++] = {
if(pointAmo < pointArrLen && is_struct(points[pointAmo])) { x: _nx,
_pntData = points[pointAmo]; y: _ny,
_pntData.x = _nx; prog: (_prog_total - _pathStr) / (_pathEnd - _pathStr),
_pntData.y = _ny; progCrop: _prog_curr / _pathLength,
_pntData.prog = (_prog_total - _pathStr) / (_pathEnd - _pathStr); weight: wght
_pntData.progCrop = _prog_curr / _pathLength; }
_pntData.weight = wght;
} else {
_pntData = {
x: _nx,
y: _ny,
prog: (_prog_total - _pathStr) / (_pathEnd - _pathStr),
progCrop: _prog_curr / _pathLength,
weight: wght
}
points[pointAmo] = _pntData;
}
pointAmo++;
} }
if(_total <= 0) break; if(_total <= 0) break;
@ -346,6 +335,7 @@ function Node_Line(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) cons
} }
array_resize(points, pointAmo); array_resize(points, pointAmo);
lines[_lineAmo++] = points; lines[_lineAmo++] = points;
} }

View file

@ -27,37 +27,45 @@ function Node_Path_From_Mask(_x, _y, _group = noone) : Node(_x, _y, _group) cons
static getSegmentCount = function() { return 1; } static getSegmentCount = function() { return 1; }
static getLineCount = function() { return 1; } static getLineCount = function() { return 1; }
static getPointDistance = function(_seg, _ind = 0, out = undefined) { #region static getPointDistance = function(_dist, _ind = 0, out = undefined) { #region
if(out == undefined) out = new __vec2(); else { out.x = 0; out.y = 0; } if(out == undefined) out = new __vec2(); else { out.x = 0; out.y = 0; }
var _cKey = $"{_seg},{_ind}"; var _cKey = $"{_dist},{_ind}";
if(ds_map_exists(cached_pos, _cKey)) { if(ds_map_exists(cached_pos, _cKey)) {
var _p = cached_pos[? _cKey]; var _p = cached_pos[? _cKey];
out.x = _p.x; out.x = _p.x;
out.y = _p.y; out.y = _p.y;
// print($"Getting cache {_cKey} : {_dist} > {out}");
return out; return out;
} }
var _aid = 0; var _aid = 0;
var _dst = _seg; var _dst = _dist;
for( var i = 0, n = array_length(lengthAccs); i < n; i++ ) { for( var i = 0, n = array_length(lengthAccs); i < n; i++ ) {
if(_seg == lengthAccs[i]) { if(_dist == lengthAccs[i]) {
out.x = anchors[i][0]; out.x = anchors[i + 1][0];
out.y = anchors[i][1]; out.y = anchors[i + 1][1];
return out; return out;
} }
if(_seg < lengthAccs[i]) { if(_dist < lengthAccs[i]) {
_aid = i; _aid = i;
if(i) _dst = _seg - lengthAccs[i - 1]; if(i) _dst = _dist - lengthAccs[i - 1];
break; break;
} }
} }
out.x = lerp(anchors[i][0], anchors[i + 1][0], _dst / lengths[_aid]); var _a0 = anchors[i];
out.y = lerp(anchors[i][1], anchors[i + 1][1], _dst / lengths[_aid]); var _a1 = anchors[i + 1];
var _rat = _dst / lengths[_aid];
out.x = lerp(_a0[0], _a1[0], _rat);
out.y = lerp(_a0[1], _a1[1], _rat);
// print($"Getting position {_cKey} : {_dist} - {i} > {out}");
cached_pos[? _cKey] = out.clone(); cached_pos[? _cKey] = out.clone();
@ -99,43 +107,44 @@ function Node_Path_From_Mask(_x, _y, _group = noone) : Node(_x, _y, _group) cons
anchors = []; anchors = [];
if(!is_surface(_surf)) return; if(!is_surface(_surf)) return;
var _dim = surface_get_dimension(_surf); #region content extract
var _sca = min(1, attributes.maximum_dim / _dim[0], attributes.maximum_dim / _dim[1]); var _dim = surface_get_dimension(_surf);
_dim[0] *= _sca; var _sca = min(1, attributes.maximum_dim / _dim[0], attributes.maximum_dim / _dim[1]);
_dim[1] *= _sca; _dim[0] *= _sca;
_dim[1] *= _sca;
temp_surface[0] = surface_verify(temp_surface[0], _dim[0], _dim[1]);
temp_surface[0] = surface_verify(temp_surface[0], _dim[0], _dim[1]);
surface_set_shader(temp_surface[0], sh_image_trace);
shader_set_f("dimension", _dim); surface_set_shader(temp_surface[0], sh_image_trace);
draw_surface_stretched(_surf, 0, 0, _dim[0], _dim[1]); shader_set_f("dimension", _dim);
surface_reset_shader(); draw_surface_stretched(_surf, 0, 0, _dim[0], _dim[1]);
surface_reset_shader();
var _w = _dim[0], _h = _dim[1];
var _x = 0, _y = 0; var _w = _dim[0], _h = _dim[1];
var _x = 0, _y = 0;
var _buff = buffer_from_surface(temp_surface[0], false);
var _emp = true; var _buff = buffer_from_surface(temp_surface[0], false);
var _ind = 0; var _emp = true;
var _ind = 0;
buffer_seek(_buff, buffer_seek_start, 0);
repeat(_w * _h) { buffer_seek(_buff, buffer_seek_start, 0);
var _b = buffer_read(_buff, buffer_u32); repeat(_w * _h) {
if(_b > 0) { var _b = buffer_read(_buff, buffer_u32);
_emp = false; if(_b > 0) {
_x = _ind % _w; _emp = false;
_y = floor(_ind / _w); _x = _ind % _w;
break; _y = floor(_ind / _w);
break;
}
_ind++;
} }
_ind++; #endregion
}
if(_emp) { print("Empty surface"); return; } if(_emp) { print("Empty surface"); return; }
var _sx = _x; var _sx = _x, _sy = _y;
var _sy = _y; var _px = _x, _py = _y;
var _px = _x; var _nx = _x, _ny = _y;
var _py = _y;
var _amo = _w * _h; var _amo = _w * _h;
var _rep = 0; var _rep = 0;
@ -144,8 +153,17 @@ function Node_Path_From_Mask(_x, _y, _group = noone) : Node(_x, _y, _group) cons
do { do {
buffer_write_at(_buff, (_y * _w + _x) * 4, buffer_u32, 0); buffer_write_at(_buff, (_y * _w + _x) * 4, buffer_u32, 0);
_a[_ind++] = _x / _sca + 0.5;
_a[_ind++] = _y / _sca + 0.5; _nx = _x / _sca + 0.5;
_ny = _y / _sca + 0.5;
if(_ind == 0 || _px != _nx || _py != _ny) {
_a[_ind++] = _nx;
_a[_ind++] = _ny;
}
_px = _nx;
_py = _ny;
if(_x < _w - 1 && buffer_read_at(_buff, ((_y ) * _w + _x + 1) * 4, buffer_u32)) { _x++; } if(_x < _w - 1 && buffer_read_at(_buff, ((_y ) * _w + _x + 1) * 4, buffer_u32)) { _x++; }
else if(_y < _h - 1 && buffer_read_at(_buff, ((_y + 1) * _w + _x ) * 4, buffer_u32)) { _y++; } else if(_y < _h - 1 && buffer_read_at(_buff, ((_y + 1) * _w + _x ) * 4, buffer_u32)) { _y++; }
@ -165,44 +183,44 @@ function Node_Path_From_Mask(_x, _y, _group = noone) : Node(_x, _y, _group) cons
anchors = array_verify(anchors, _ind / 2); anchors = array_verify(anchors, _ind / 2);
var _aind = 0; var _aind = 0;
var lx = _a[0]; var ox, oy, cx, cy, nx, ny;
var ly = _a[1]; var a0, a1;
var ox, oy, nx, ny;
for( var i = 0; i < _ind; i += 2 ) { var _aamo = _ind / 2;
nx = _a[i + 0]; if(_aamo <= 2) return;
ny = _a[i + 1];
for( var i = 0; i < _aamo; i++ ) {
ox = _a[(i - 1 + _aamo) % _aamo * 2 + 0];
oy = _a[(i - 1 + _aamo) % _aamo * 2 + 1];
cx = _a[i * 2 + 0];
cy = _a[i * 2 + 1];
nx = _a[(i + 1 + _aamo) % _aamo * 2 + 0];
ny = _a[(i + 1 + _aamo) % _aamo * 2 + 1];
if(i) { a0 = point_direction(ox, oy, cx, cy);
var na = point_direction(ox, oy, nx, ny); a1 = point_direction(cx, cy, nx, ny);
var la = point_direction(lx, ly, nx, ny);
if(abs(angle_difference(a0, a1)) > _smt)
if(abs(angle_difference(na, la)) > _smt) { anchors[_aind++] = [ cx, cy ];
lx = ox;
ly = oy;
anchors[_aind++] = [ ox, oy ];
}
}
ox = nx;
oy = ny;
} }
anchors[_aind++] = [ _a[0], _a[1] ]; anchors[_aind++] = [ _a[0], _a[1] ];
array_resize(anchors, _aind);
var _ancAmo = _aind;
array_resize(anchors, _ancAmo);
var ox, oy, nx, ny; var ox, oy, nx, ny;
lengthTotal = 0; lengthTotal = 0;
lengths = array_verify(lengths, (_ind / 2) - 1); lengths = array_verify(lengths, _ancAmo - 1);
lengthAccs = array_verify(lengthAccs, (_ind / 2) - 1); lengthAccs = array_verify(lengthAccs, _ancAmo - 1);
boundary = new BoundingBox(); boundary = new BoundingBox();
var _lind = 0; var _lind = 0;
for( var i = 0; i < _ind; i += 2 ) { for( var i = 0; i < _ancAmo; i++ ) {
nx = _a[i + 0]; nx = anchors[i][0];
ny = _a[i + 1]; ny = anchors[i][1];
boundary.addPoint(nx, ny); boundary.addPoint(nx, ny);
@ -218,6 +236,11 @@ function Node_Path_From_Mask(_x, _y, _group = noone) : Node(_x, _y, _group) cons
ox = nx; ox = nx;
oy = ny; oy = ny;
} }
// print($"\n=========== Path ===========");
// print($"Anchors : {anchors}");
// print($"Lengths : {lengths}");
// print($"Len Accs : {lengthAccs}");
} #endregion } #endregion
static getGraphPreviewSurface = function() { return /*temp_surface[0]*/ getInputData(0); } static getGraphPreviewSurface = function() { return /*temp_surface[0]*/ getInputData(0); }