- [Mesh Warp] Fix general error.

This commit is contained in:
Tanasart 2024-07-05 12:06:49 +07:00
parent 414b356f4b
commit 1979d57c83
7 changed files with 137 additions and 186 deletions

View file

@ -68,8 +68,10 @@ function canvas_tool_shape_iso(brush, shape) : canvas_tool() constructor {
break; break;
} }
if(mouse_press(mb_right, active)) if(key_press(vk_escape)) {
mouse_holding = 0; mouse_holding = 0;
surface_clear(drawing_surface);
}
} }
function drawPreview(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) { function drawPreview(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) {
@ -88,6 +90,7 @@ function canvas_tool_shape_iso(brush, shape) : canvas_tool() constructor {
function canvas_draw_iso_cube(brush, _p, _fill = false) { function canvas_draw_iso_cube(brush, _p, _fill = false) {
var p0x = _p[0][0], p0y = _p[0][1]; var p0x = _p[0][0], p0y = _p[0][1];
var p1x = _p[1][0], p1y = _p[1][1]; var p1x = _p[1][0], p1y = _p[1][1];
var ww = p1x - p0x;
if(p1x < p0x) { if(p1x < p0x) {
var tx = p0x, ty = p0y; var tx = p0x, ty = p0y;
@ -109,41 +112,31 @@ function canvas_draw_iso_cube(brush, _p, _fill = false) {
var p1py = p1y - h1; var p1py = p1y - h1;
var _simp = true; var _simp = true;
var cc = draw_get_color();
if(w > 0) { if(w > 0) {
if(round(h2) < 0) { if(round(h2) < 0) {
if(round(w1) > 0) { if(round(w1) > 0) {
if(p1px < p0px) {
p0x = floor(p1px); p0x = floor(p1px);
p0y = floor(p1py); p0y = floor(p1py);
p1x = ceil(p0px) + 1; p1x = ceil(p0px) + 1;
p1y = ceil(p0py); p1y = ceil(p0py);
} else {
p0x = floor(p0px);
p0y = floor(p0py);
p1x = ceil(p1px) + 1;
p1y = ceil(p1py);
}
if(ww < 0) { p0x--; p1x--; }
_simp = false; _simp = false;
} }
} else if(round(h2) > 0) { } else if(round(h2) > 0) {
if(round(w1) < 0) { if(round(w1) < 0) {
if(p1px < p0px) {
p0x = floor(p1px);
p0y = floor(p1py);
p1x = ceil(p0px) + 1;
p1y = ceil(p0py);
} else {
p0x = floor(p0px); p0x = floor(p0px);
p0y = floor(p0py); p0y = floor(p0py);
p1x = ceil(p1px) + 1; p1x = ceil(p1px) + 1;
p1y = ceil(p1py); p1y = ceil(p1py);
}
if(frac(p0py) >= 0.5) { p0x--; }
if(ww < 0 && frac(p0px) == 0 && frac(p0py) == 0) { p0x--; p1x--; }
_simp = false; _simp = false;
} else if(round(w1) > 0) { } else if(round(w1) > 0) {
@ -196,6 +189,8 @@ function canvas_draw_iso_cube(brush, _p, _fill = false) {
d = -d; d = -d;
} }
draw_set_color(cc);
if(_fill == 2) { if(_fill == 2) {
if(d == 0) { if(d == 0) {
canvas_draw_line(p0x, p0y, p0px - 1, p0py); canvas_draw_line(p0x, p0y, p0px - 1, p0py);
@ -207,7 +202,6 @@ function canvas_draw_iso_cube(brush, _p, _fill = false) {
canvas_draw_triangle(p1x - 1, p1y, p1px, p1py - 1, p0x, p0y, false); canvas_draw_triangle(p1x - 1, p1y, p1px, p1py - 1, p0x, p0y, false);
} else { } else {
var cc = draw_get_color();
draw_set_color(brush.colors[1]); draw_set_color(brush.colors[1]);
canvas_draw_triangle(p0px, p0py - 1, p1x, p1y + d, p1x, p1y, false); canvas_draw_triangle(p0px, p0py - 1, p1x, p1y + d, p1x, p1y, false);

View file

@ -10,6 +10,7 @@
"Eraser": new hotkeySimple("E"), "Eraser": new hotkeySimple("E"),
"Rectangle": new hotkeySimple("N"), "Rectangle": new hotkeySimple("N"),
"Ellipse": new hotkeySimple("M"), "Ellipse": new hotkeySimple("M"),
"Iso Cube": new hotkeySimple(""),
"Curve": new hotkeySimple(""), "Curve": new hotkeySimple(""),
"Freeform": new hotkeySimple("Q"), "Freeform": new hotkeySimple("Q"),
"Fill": new hotkeySimple("G"), "Fill": new hotkeySimple("G"),

View file

@ -1,5 +1,5 @@
{ {
"$GMScript":"v1", "$GMScript":"",
"%Name":"hotkey_data", "%Name":"hotkey_data",
"isCompatibility":false, "isCompatibility":false,
"isDnD":false, "isDnD":false,

View file

@ -540,7 +540,7 @@ function Node_Collection(_x, _y, _group = noone) : Node(_x, _y, _group) construc
static drawNodeOverlay = function(xx, yy, _mx, _my, _s) { static drawNodeOverlay = function(xx, yy, _mx, _my, _s) {
if(_s < 0.75) return; if(_s < 0.75) return;
var _bx = (xx + w / 2 * _s); var _bx = (xx + w * _s) - 10;
var _by = (yy + h * _s) - 10; var _by = (yy + h * _s) - 10;
var _hv = PANEL_GRAPH.pHOVER && PANEL_GRAPH.node_hovering == self; var _hv = PANEL_GRAPH.pHOVER && PANEL_GRAPH.node_hovering == self;

View file

@ -4,9 +4,9 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
attributes.mesh_bound = []; attributes.mesh_bound = [];
points = []; points = [];
data = { points : [], tris : [], links : [], controls: [] }; mesh_data = { points : [], tris : [], links : [], controls: [] };
function _Point(node, index, _x, _y) constructor { #region function _Point(node, index, _x, _y) constructor {
self.index = index; self.index = index;
self.node = node; self.node = node;
x = _x; x = _x;
@ -23,11 +23,12 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
sy = y; sy = y;
pin = false; pin = false;
u = 0;
v = 0;
controlWeights = []; controlWeights = [];
static reset = function(data) { static reset = function(_mesh_data) {
INLINE
x = sx; x = sx;
y = sy; y = sy;
xp = x; xp = x;
@ -35,8 +36,9 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var dist = 0; var dist = 0;
for( var i = 0, n = array_length(data.controls); i < n; i++ ) { for( var i = 0, n = array_length(_mesh_data.controls); i < n; i++ ) {
var d = point_distance(x, y, data.controls[i][PUPPET_CONTROL.cx], data.controls[i][PUPPET_CONTROL.cy]); var c = _mesh_data.controls[i];
var d = point_distance(x, y, c[PUPPET_CONTROL.cx], c[PUPPET_CONTROL.cy]);
controlWeights[i] = 1 / d; controlWeights[i] = 1 / d;
dist += 1 / d; dist += 1 / d;
@ -47,8 +49,6 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
} }
static draw = function(_x, _y, _s) { static draw = function(_x, _y, _s) {
INLINE
if(pin) { if(pin) {
draw_set_color(COLORS._main_accent); draw_set_color(COLORS._main_accent);
draw_circle_prec(_x + x * _s, _y + y * _s, 3, false); draw_circle_prec(_x + x * _s, _y + y * _s, 3, false);
@ -58,64 +58,16 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
} }
} }
u = 0; static mapTexture = function(ww, hh) { u = x / ww; v = y / hh; }
v = 0; static move = function(dx, dy) { if(pin) return; x += dx; y += dy; }
static mapTexture = function(ww, hh) { static planMove = function(dx, dy) { if(pin) return; ndx += dx; ndy += dy; }
INLINE static stepMove = function(rat) { if(pin) return; move(ndx * rat, ndy * rat); }
static clearMove = function(rat) { if(pin) return; ndx = 0; ndy = 0; }
u = x / ww; static setPin = function(pin) { self.pin = pin; }
v = y / hh; static equal = function(point) { return x == point.x && y == point.y; }
} }
static move = function(dx, dy) { function _Link(_p0, _p1, _k = 1) constructor {
INLINE
if(pin) return;
x += dx;
y += dy;
}
static planMove = function(dx, dy) {
INLINE
if(pin) return;
ndx += dx;
ndy += dy;
}
static stepMove = function(rat) {
INLINE
if(pin) return;
move(ndx * rat, ndy * rat);
}
static clearMove = function(rat) {
INLINE
if(pin) return;
ndx = 0;
ndy = 0;
}
static setPin = function(pin) {
INLINE
self.pin = pin;
}
static equal = function(point) {
INLINE
return x == point.x && y == point.y;
}
} #endregion
function _Link(_p0, _p1, _k = 1) constructor { #region
p0 = _p0; p0 = _p0;
p1 = _p1; p1 = _p1;
k = _k; k = _k;
@ -143,19 +95,19 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
draw_set_color(c_red); draw_set_color(c_red);
draw_line(_x + p0.x * _s, _y + p0.y * _s, _x + p1.x * _s, _y + p1.y * _s); draw_line(_x + p0.x * _s, _y + p0.y * _s, _x + p1.x * _s, _y + p1.y * _s);
} }
} #endregion }
function _Triangle(_p0, _p1, _p2) constructor { #region function _Triangle(_p0, _p1, _p2) constructor {
p0 = _p0; p0 = _p0;
p1 = _p1; p1 = _p1;
p2 = _p2; p2 = _p2;
static reset = function(data) { static reset = function(_mesh_data) {
INLINE INLINE
p0.reset(data); p0.reset(_mesh_data);
p1.reset(data); p1.reset(_mesh_data);
p2.reset(data); p2.reset(_mesh_data);
} }
static initSurface = function(surf) { static initSurface = function(surf) {
@ -192,7 +144,7 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
return p == p0 || p == p1 || p == p2; return p == p0 || p == p1 || p == p2;
} }
} #endregion }
is_convex = true; is_convex = true;
hover = -1; hover = -1;
@ -234,7 +186,7 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone); outputs[| 0] = nodeValue("Surface out", self, JUNCTION_CONNECT.output, VALUE_TYPE.surface, noone);
outputs[| 1] = nodeValue("Mesh data", self, JUNCTION_CONNECT.output, VALUE_TYPE.object, data); outputs[| 1] = nodeValue("Mesh data", self, JUNCTION_CONNECT.output, VALUE_TYPE.object, mesh_data);
input_display_list = [ 5, input_display_list = [ 5,
["Mesh", false], 0, 8, 9, 1, 7, 3, ["Mesh", false], 0, 8, 9, 1, 7, 3,
@ -287,17 +239,17 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
insp1UpdateIcon = [ THEME.refresh_icon, 1, COLORS._main_value_positive ]; insp1UpdateIcon = [ THEME.refresh_icon, 1, COLORS._main_value_positive ];
will_triangluate = false; will_triangluate = false;
static onInspector1Update = function() { #region static onInspector1Update = function() {
Mesh_setTriangle(); Mesh_setTriangle();
} #endregion }
static onValueFromUpdate = function(index) { #region static onValueFromUpdate = function(index) {
if(LOADING || APPENDING) return; if(LOADING || APPENDING) return;
if(index == 0 && array_empty(data.tris)) if(index == 0 && array_empty(mesh_data.tris))
Mesh_setTriangle(); Mesh_setTriangle();
} #endregion }
static drawOverlay = function(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) { #region static drawOverlay = function(hover, active, _x, _y, _s, _mx, _my, _snx, _sny) {
var mx = (_mx - _x) / _s; var mx = (_mx - _x) / _s;
var my = (_my - _y) / _s; var my = (_my - _y) / _s;
@ -393,10 +345,10 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
} }
} }
for(var i = 0; i < array_length(data.links); i++) for(var i = 0; i < array_length(mesh_data.links); i++)
data.links[i].draw(_x, _y, _s); mesh_data.links[i].draw(_x, _y, _s);
for(var i = 0; i < array_length(data.tris); i++) for(var i = 0; i < array_length(mesh_data.tris); i++)
data.tris[i].drawPoints(_x, _y, _s); mesh_data.tris[i].drawPoints(_x, _y, _s);
var _hover = -1; var _hover = -1;
for(var i = control_index; i < ds_list_size(inputs); i++) { for(var i = control_index; i < ds_list_size(inputs); i++) {
@ -437,8 +389,8 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _yy = (_my - _y) / _s; var _yy = (_my - _y) / _s;
if(mouse_click(mb_left, active)) { if(mouse_click(mb_left, active)) {
for(var j = 0; j < array_length(data.tris); j++) { for(var j = 0; j < array_length(mesh_data.tris); j++) {
var t = data.tris[j]; var t = mesh_data.tris[j];
if(point_in_circle(t.p0.x, t.p0.y, _xx, _yy, rad / _s)) if(point_in_circle(t.p0.x, t.p0.y, _xx, _yy, rad / _s))
t.p0.setPin(!key_mod_press(SHIFT)); t.p0.setPin(!key_mod_press(SHIFT));
@ -449,11 +401,11 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
} }
} }
} }
} #endregion }
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
static step = function() { #region static step = function() {
var _type = getInputData(8); var _type = getInputData(8);
inputs[| 2].setVisible(_type == 0); inputs[| 2].setVisible(_type == 0);
@ -462,12 +414,12 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
if(_type == 0) tools = tools_edit; if(_type == 0) tools = tools_edit;
else if (_type == 1) tools = tools_mesh; else if (_type == 1) tools = tools_mesh;
} #endregion }
static reset = function() { #region static reset = function() {
for(var i = 0; i < array_length(data.tris); i++) for(var i = 0; i < array_length(mesh_data.tris); i++)
data.tris[i].reset(data); mesh_data.tris[i].reset(mesh_data);
} #endregion }
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
@ -506,7 +458,7 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _sam = sample + 1; var _sam = sample + 1;
data.points = array_create(_sam * _sam); mesh_data.points = array_create(_sam * _sam);
var ind = 0; var ind = 0;
for(var i = 0; i < _sam; i++) for(var i = 0; i < _sam; i++)
@ -537,32 +489,32 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var px = min(j * gw, ww); var px = min(j * gw, ww);
var py = min(i * gh, hh); var py = min(i * gh, hh);
data.points[i * _sam + j] = new _Point(self, ind++, px, py); mesh_data.points[i * _sam + j] = new _Point(self, ind++, px, py);
if(i == 0) continue; if(i == 0) continue;
if(j && data.points[(i - 1) * _sam + j] != 0 && data.points[i * _sam + j - 1] != 0) if(j && mesh_data.points[(i - 1) * _sam + j] != 0 && mesh_data.points[i * _sam + j - 1] != 0)
array_push(data.tris, new _Triangle(data.points[(i - 1) * _sam + j], data.points[i * _sam + j - 1], data.points[i * _sam + j])); array_push(mesh_data.tris, new _Triangle(mesh_data.points[(i - 1) * _sam + j], mesh_data.points[i * _sam + j - 1], mesh_data.points[i * _sam + j]));
if(j < sample && data.points[(i - 1) * _sam + j] != 0 && data.points[(i - 1) * _sam + j + 1] != 0) if(j < sample && mesh_data.points[(i - 1) * _sam + j] != 0 && mesh_data.points[(i - 1) * _sam + j + 1] != 0)
array_push(data.tris, new _Triangle(data.points[(i - 1) * _sam + j], data.points[(i - 1) * _sam + j + 1], data.points[i * _sam + j])); array_push(mesh_data.tris, new _Triangle(mesh_data.points[(i - 1) * _sam + j], mesh_data.points[(i - 1) * _sam + j + 1], mesh_data.points[i * _sam + j]));
} #endregion } #endregion
for(var i = 0; i < _sam; i++) for(var i = 0; i < _sam; i++)
for(var j = 0; j < _sam; j++) { #region diagonal for(var j = 0; j < _sam; j++) { #region diagonal
var p0 = i && j? data.points[ (i - 1) * _sam + j - 1 ] : 0; var p0 = i && j? mesh_data.points[ (i - 1) * _sam + j - 1 ] : 0;
var p1 = i? data.points[ (i - 1) * _sam + j ] : 0; var p1 = i? mesh_data.points[ (i - 1) * _sam + j ] : 0;
var p2 = j? data.points[ (i ) * _sam + j - 1 ] : 0; var p2 = j? mesh_data.points[ (i ) * _sam + j - 1 ] : 0;
var p3 = data.points[ (i ) * _sam + j ]; var p3 = mesh_data.points[ (i ) * _sam + j ];
if(p3 && p1) array_push(data.links, new _Link(p3, p1)); if(p3 && p1) array_push(mesh_data.links, new _Link(p3, p1));
if(p3 && p2) array_push(data.links, new _Link(p3, p2)); if(p3 && p2) array_push(mesh_data.links, new _Link(p3, p2));
var d0 = p0 && p3; var d0 = p0 && p3;
var d1 = p1 && p2; var d1 = p1 && p2;
if(diagon || d0 ^ d1) { if(diagon || d0 ^ d1) {
if(d0) array_push(data.links, new _Link(p0, p3, spring)); if(d0) array_push(mesh_data.links, new _Link(p0, p3, spring));
if(d1) array_push(data.links, new _Link(p1, p2, spring)); if(d1) array_push(mesh_data.links, new _Link(p1, p2, spring));
} }
} #endregion } #endregion
@ -620,22 +572,22 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
array_push(_p, [ px, py ]); array_push(_p, [ px, py ]);
} }
data.points = array_create(_mb + array_length(_p)); mesh_data.points = array_create(_mb + array_length(_p));
for( var i = 0, n = _mb; i < n; i++ ) for( var i = 0, n = _mb; i < n; i++ )
data.points[i] = new _Point(self, ind++, _m[i][0], _m[i][1]); mesh_data.points[i] = new _Point(self, ind++, _m[i][0], _m[i][1]);
for( var i = 0, n = array_length(_p); i < n; i++ ) for( var i = 0, n = array_length(_p); i < n; i++ )
data.points[_mb + i] = new _Point(self, ind++, _p[i][0], _p[i][1]); mesh_data.points[_mb + i] = new _Point(self, ind++, _p[i][0], _p[i][1]);
var _t = delaunay_triangulation(data.points); var _t = delaunay_triangulation(mesh_data.points);
for( var i = 0, n = array_length(_t); i < n; i++ ) { for( var i = 0, n = array_length(_t); i < n; i++ ) {
var t = _t[i]; var t = _t[i];
array_push(data.tris, new _Triangle(t[0], t[1], t[2])); array_push(mesh_data.tris, new _Triangle(t[0], t[1], t[2]));
array_push(data.links, new _Link(t[0], t[1])); array_push(mesh_data.links, new _Link(t[0], t[1]));
array_push(data.links, new _Link(t[1], t[2])); array_push(mesh_data.links, new _Link(t[1], t[2]));
array_push(data.links, new _Link(t[2], t[0])); array_push(mesh_data.links, new _Link(t[2], t[0]));
} }
} #endregion } #endregion
@ -644,15 +596,15 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _type = getInputData(8); var _type = getInputData(8);
points = []; points = [];
data = { points : [], tris : [], links : [], controls: [] }; mesh_data = { points : [], tris : [], links : [], controls: [] };
switch(_type) { switch(_type) {
case 0 : Mesh_regularTri(_inSurf); break; case 0 : Mesh_regularTri(_inSurf); break;
case 1 : Mesh_triangulate(_inSurf); break; case 1 : Mesh_triangulate(_inSurf); break;
} }
for(var i = 0; i < array_length(data.tris); i++) for(var i = 0; i < array_length(mesh_data.tris); i++)
data.tris[i].initSurface(is_array(_inSurf)? _inSurf[0] : _inSurf); mesh_data.tris[i].initSurface(is_array(_inSurf)? _inSurf[0] : _inSurf);
triggerRender(); triggerRender();
@ -698,25 +650,25 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
} }
} #endregion } #endregion
static control = function() { #region static control = function() {
var lStr = getInputData(6); var lStr = getInputData(6);
for(var i = control_index, n = ds_list_size(inputs); i < n; i++) { for(var i = control_index, n = ds_list_size(inputs); i < n; i++) {
var c = getInputData(i); var c = getInputData(i);
for( var j = 0, m = array_length(data.points); j < m; j++ ) { for( var j = 0, m = array_length(mesh_data.points); j < m; j++ ) {
if(data.points[j] == 0) continue; if(mesh_data.points[j] == 0) continue;
Control_affectPoint(c, data.points[j]); Control_affectPoint(c, mesh_data.points[j]);
} }
} }
for( var i = 0, n = array_length(data.points); i < n; i++ ) { for( var i = 0, n = array_length(mesh_data.points); i < n; i++ ) {
var _p = data.points[i]; if(_p == 0) continue; var _p = mesh_data.points[i]; if(_p == 0) continue;
var _dx = 0; var _dx = 0;
var _dy = 0; var _dy = 0;
for( var j = 0, m = array_length(data.controls); j < m; j++ ) { for( var j = 0, m = array_length(mesh_data.controls); j < m; j++ ) {
var _c = data.controls[j]; var _c = mesh_data.controls[j];
_dx += _c[PUPPET_CONTROL.fx] * _p.controlWeights[j]; _dx += _c[PUPPET_CONTROL.fx] * _p.controlWeights[j];
_dy += _c[PUPPET_CONTROL.fy] * _p.controlWeights[j]; _dy += _c[PUPPET_CONTROL.fy] * _p.controlWeights[j];
@ -729,39 +681,40 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _rat = 1 / it; var _rat = 1 / it;
repeat(it) { repeat(it) {
for( var j = 0; j < array_length(data.points); j++ ) { for( var j = 0; j < array_length(mesh_data.points); j++ ) {
if(data.points[j] == 0) continue; if(mesh_data.points[j] == 0) continue;
data.points[j].stepMove(_rat); mesh_data.points[j].stepMove(_rat);
} }
if(lStr > 0) if(lStr > 0)
repeat(it) { repeat(it) {
for(var i = 0; i < array_length(data.links); i++) for(var i = 0; i < array_length(mesh_data.links); i++)
data.links[i].resolve(lStr); mesh_data.links[i].resolve(lStr);
} }
} }
for( var j = 0; j < array_length(data.points); j++ ) { for( var j = 0; j < array_length(mesh_data.points); j++ ) {
if(data.points[j] == 0) continue; if(mesh_data.points[j] == 0) continue;
data.points[j].clearMove(); mesh_data.points[j].clearMove();
}
} }
} #endregion
static processData = function(_outSurf, _data, _output_index, _array_index) { #region static processData = function(_outData, _data, _output_index, _array_index) { #region
if(will_triangluate) { if(will_triangluate) {
Mesh_setTriangle(); Mesh_setTriangle();
will_triangluate = false; will_triangluate = false;
} }
var _outSurf = _outData[0];
var _inSurf = _data[0]; var _inSurf = _data[0];
if(!is_surface(_inSurf)) return _outSurf; if(!is_surface(_inSurf)) return [ _outSurf, mesh_data ];
data.controls = []; mesh_data.controls = [];
for(var i = control_index; i < ds_list_size(inputs); i++) { for(var i = control_index; i < ds_list_size(inputs); i++) {
var c = getInputData(i); var c = getInputData(i);
if(c[0] == PUPPET_FORCE_MODE.puppet) if(c[0] == PUPPET_FORCE_MODE.puppet)
array_push(data.controls, c); array_push(mesh_data.controls, c);
} }
reset(); reset();
@ -774,36 +727,36 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
surface_set_shader(_outSurf); surface_set_shader(_outSurf);
shader_set_interpolation(_outSurf); shader_set_interpolation(_outSurf);
if(array_length(data.tris) == 0) { if(array_length(mesh_data.tris) == 0) {
draw_surface_safe(_inSurf); draw_surface_safe(_inSurf);
} else { } else {
for(var i = 0; i < array_length(data.tris); i++) for(var i = 0; i < array_length(mesh_data.tris); i++)
data.tris[i].drawSurface(_inSurf); mesh_data.tris[i].drawSurface(_inSurf);
} }
surface_reset_shader(); surface_reset_shader();
return _outSurf; return [ _outSurf, mesh_data ];
} #endregion } #endregion
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
static postDeserialize = function() { #region static postDeserialize = function() {
var _inputs = load_map.inputs; var _inputs = load_map.inputs;
for(var i = control_index; i < array_length(_inputs); i++) { for(var i = control_index; i < array_length(_inputs); i++) {
var inp = createControl(); var inp = createControl();
inp.applyDeserialize(_inputs[i]); inp.applyDeserialize(_inputs[i]);
} }
} #endregion }
static attributeSerialize = function() { #region static attributeSerialize = function() {
var att = {}; var att = {};
struct_append(att, attributes); struct_append(att, attributes);
var pinList = []; var pinList = [];
for( var j = 0; j < array_length(data.points); j++ ) { for( var j = 0; j < array_length(mesh_data.points); j++ ) {
var p = data.points[j]; var p = mesh_data.points[j];
if(p == 0) continue; if(p == 0) continue;
if(p.pin) array_push(pinList, p.index); if(p.pin) array_push(pinList, p.index);
} }
@ -812,17 +765,17 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
att.mesh_bound = attributes.mesh_bound; att.mesh_bound = attributes.mesh_bound;
return att; return att;
} #endregion }
loadPin = noone; loadPin = noone;
static attributeDeserialize = function(attr) { #region static attributeDeserialize = function(attr) {
struct_append(attributes, attr); struct_append(attributes, attr);
if(struct_has(attr, "pin")) loadPin = attr.pin; if(struct_has(attr, "pin")) loadPin = attr.pin;
if(struct_has(attr, "mesh_bound")) attributes.mesh_bound = attr.mesh_bound;; if(struct_has(attr, "mesh_bound")) attributes.mesh_bound = attr.mesh_bound;;
} #endregion }
static postLoad = function() { #region static postLoad = function() {
will_triangluate = true; will_triangluate = true;
} #endregion }
} }

View file

@ -1678,6 +1678,7 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
for (var i = 0, n = array_length(_i); i < n; i++) { for (var i = 0, n = array_length(_i); i < n; i++) {
var _j = _l[| _i[i]]; var _j = _l[| _i[i]];
if(_j.type == value_dragging.type)
array_push_unique(value_draggings, _j); array_push_unique(value_draggings, _j);
} }

View file

@ -7,6 +7,8 @@ function tooltipHotkey(text, context = "", name = "") constructor {
static setKey = function(key) { keyStr = key; return self; } static setKey = function(key) { keyStr = key; return self; }
static drawTooltip = function() { static drawTooltip = function() {
if(keyStr == "") { draw_tooltip_text(text); return; }
draw_set_font(f_p0); draw_set_font(f_p0);
var _w1 = string_width(text); var _w1 = string_width(text);