mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-11 23:06:51 +01:00
path mask bigs
This commit is contained in:
parent
fd70ca9292
commit
35cf8d023c
2 changed files with 105 additions and 92 deletions
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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); }
|
||||||
|
|
Loading…
Reference in a new issue