From 1979d57c83d066cbb45eb3d0ff82bae634c72452 Mon Sep 17 00:00:00 2001 From: Tanasart Date: Fri, 5 Jul 2024 12:06:49 +0700 Subject: [PATCH] - [Mesh Warp] Fix general error. --- .../canvas_tool_brush_shape_iso.gml | 42 ++- scripts/hotkey_data/hotkey_data.gml | 1 + scripts/hotkey_data/hotkey_data.yy | 2 +- scripts/node_collection/node_collection.gml | 4 +- scripts/node_mesh_warp/node_mesh_warp.gml | 269 ++++++++---------- scripts/panel_graph/panel_graph.gml | 3 +- scripts/tooltip_hotkey/tooltip_hotkey.gml | 2 + 7 files changed, 137 insertions(+), 186 deletions(-) diff --git a/scripts/canvas_tool_brush_shape_iso/canvas_tool_brush_shape_iso.gml b/scripts/canvas_tool_brush_shape_iso/canvas_tool_brush_shape_iso.gml index 7e01537e7..93b8027a3 100644 --- a/scripts/canvas_tool_brush_shape_iso/canvas_tool_brush_shape_iso.gml +++ b/scripts/canvas_tool_brush_shape_iso/canvas_tool_brush_shape_iso.gml @@ -68,8 +68,10 @@ function canvas_tool_shape_iso(brush, shape) : canvas_tool() constructor { break; } - if(mouse_press(mb_right, active)) + if(key_press(vk_escape)) { mouse_holding = 0; + surface_clear(drawing_surface); + } } 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) { var p0x = _p[0][0], p0y = _p[0][1]; var p1x = _p[1][0], p1y = _p[1][1]; + var ww = p1x - p0x; if(p1x < p0x) { var tx = p0x, ty = p0y; @@ -109,41 +112,31 @@ function canvas_draw_iso_cube(brush, _p, _fill = false) { var p1py = p1y - h1; var _simp = true; + var cc = draw_get_color(); if(w > 0) { if(round(h2) < 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); - p0y = floor(p0py); - p1x = ceil(p1px) + 1; - p1y = ceil(p1py); - } + p0x = floor(p1px); + p0y = floor(p1py); + p1x = ceil(p0px) + 1; + p1y = ceil(p0py); + if(ww < 0) { p0x--; p1x--; } _simp = false; } } else if(round(h2) > 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); - p0y = floor(p0py); - p1x = ceil(p1px) + 1; - p1y = ceil(p1py); - } + p0x = floor(p0px); + p0y = floor(p0py); + p1x = ceil(p1px) + 1; + p1y = ceil(p1py); + if(frac(p0py) >= 0.5) { p0x--; } + if(ww < 0 && frac(p0px) == 0 && frac(p0py) == 0) { p0x--; p1x--; } _simp = false; } else if(round(w1) > 0) { @@ -196,6 +189,8 @@ function canvas_draw_iso_cube(brush, _p, _fill = false) { d = -d; } + draw_set_color(cc); + if(_fill == 2) { if(d == 0) { 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); } else { - var cc = draw_get_color(); draw_set_color(brush.colors[1]); canvas_draw_triangle(p0px, p0py - 1, p1x, p1y + d, p1x, p1y, false); diff --git a/scripts/hotkey_data/hotkey_data.gml b/scripts/hotkey_data/hotkey_data.gml index 190d6b48a..045f42cc7 100644 --- a/scripts/hotkey_data/hotkey_data.gml +++ b/scripts/hotkey_data/hotkey_data.gml @@ -10,6 +10,7 @@ "Eraser": new hotkeySimple("E"), "Rectangle": new hotkeySimple("N"), "Ellipse": new hotkeySimple("M"), + "Iso Cube": new hotkeySimple(""), "Curve": new hotkeySimple(""), "Freeform": new hotkeySimple("Q"), "Fill": new hotkeySimple("G"), diff --git a/scripts/hotkey_data/hotkey_data.yy b/scripts/hotkey_data/hotkey_data.yy index 09b491cdd..dd2294ad7 100644 --- a/scripts/hotkey_data/hotkey_data.yy +++ b/scripts/hotkey_data/hotkey_data.yy @@ -1,5 +1,5 @@ { - "$GMScript":"v1", + "$GMScript":"", "%Name":"hotkey_data", "isCompatibility":false, "isDnD":false, diff --git a/scripts/node_collection/node_collection.gml b/scripts/node_collection/node_collection.gml index 5e7495229..929d322cc 100644 --- a/scripts/node_collection/node_collection.gml +++ b/scripts/node_collection/node_collection.gml @@ -540,8 +540,8 @@ function Node_Collection(_x, _y, _group = noone) : Node(_x, _y, _group) construc static drawNodeOverlay = function(xx, yy, _mx, _my, _s) { if(_s < 0.75) return; - var _bx = (xx + w / 2 * _s); - var _by = (yy + h * _s) - 10; + var _bx = (xx + w * _s) - 10; + var _by = (yy + h * _s) - 10; var _hv = PANEL_GRAPH.pHOVER && PANEL_GRAPH.node_hovering == self; _hv &= point_in_circle(_mx, _my, _bx, _by, 8); diff --git a/scripts/node_mesh_warp/node_mesh_warp.gml b/scripts/node_mesh_warp/node_mesh_warp.gml index 62d0e80f3..ac19f99ec 100644 --- a/scripts/node_mesh_warp/node_mesh_warp.gml +++ b/scripts/node_mesh_warp/node_mesh_warp.gml @@ -3,10 +3,10 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) attributes.mesh_bound = []; - points = []; - data = { points : [], tris : [], links : [], controls: [] }; + points = []; + 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.node = node; x = _x; @@ -23,20 +23,22 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) sy = y; pin = false; + u = 0; + v = 0; + controlWeights = []; - static reset = function(data) { - INLINE - - x = sx; - y = sy; - xp = x; + static reset = function(_mesh_data) { + x = sx; + y = sy; + xp = x; yp = y; var dist = 0; - for( var i = 0, n = array_length(data.controls); i < n; i++ ) { - var d = point_distance(x, y, data.controls[i][PUPPET_CONTROL.cx], data.controls[i][PUPPET_CONTROL.cy]); + for( var i = 0, n = array_length(_mesh_data.controls); i < n; i++ ) { + var c = _mesh_data.controls[i]; + var d = point_distance(x, y, c[PUPPET_CONTROL.cx], c[PUPPET_CONTROL.cy]); controlWeights[i] = 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) { - INLINE - if(pin) { draw_set_color(COLORS._main_accent); 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; - v = 0; - static mapTexture = function(ww, hh) { - INLINE - - u = x / ww; - v = y / hh; - } - - static move = function(dx, dy) { - 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 + static mapTexture = function(ww, hh) { u = x / ww; v = y / hh; } + static move = function(dx, dy) { if(pin) return; x += dx; y += dy; } + static planMove = function(dx, dy) { if(pin) return; ndx += dx; ndy += dy; } + static stepMove = function(rat) { if(pin) return; move(ndx * rat, ndy * rat); } + static clearMove = function(rat) { if(pin) return; ndx = 0; ndy = 0; } + static setPin = function(pin) { self.pin = pin; } + static equal = function(point) { return x == point.x && y == point.y; } + } - function _Link(_p0, _p1, _k = 1) constructor { #region + function _Link(_p0, _p1, _k = 1) constructor { p0 = _p0; p1 = _p1; 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_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; p1 = _p1; p2 = _p2; - static reset = function(data) { + static reset = function(_mesh_data) { INLINE - p0.reset(data); - p1.reset(data); - p2.reset(data); + p0.reset(_mesh_data); + p1.reset(_mesh_data); + p2.reset(_mesh_data); } 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; } - } #endregion + } is_convex = true; 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[| 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, ["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 ]; will_triangluate = false; - static onInspector1Update = function() { #region + static onInspector1Update = function() { Mesh_setTriangle(); - } #endregion + } - static onValueFromUpdate = function(index) { #region + static onValueFromUpdate = function(index) { if(LOADING || APPENDING) return; - if(index == 0 && array_empty(data.tris)) + if(index == 0 && array_empty(mesh_data.tris)) 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 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++) - data.links[i].draw(_x, _y, _s); - for(var i = 0; i < array_length(data.tris); i++) - data.tris[i].drawPoints(_x, _y, _s); + for(var i = 0; i < array_length(mesh_data.links); i++) + mesh_data.links[i].draw(_x, _y, _s); + for(var i = 0; i < array_length(mesh_data.tris); i++) + mesh_data.tris[i].drawPoints(_x, _y, _s); var _hover = -1; 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; if(mouse_click(mb_left, active)) { - for(var j = 0; j < array_length(data.tris); j++) { - var t = data.tris[j]; + for(var j = 0; j < array_length(mesh_data.tris); j++) { + var t = mesh_data.tris[j]; if(point_in_circle(t.p0.x, t.p0.y, _xx, _yy, rad / _s)) 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); 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; else if (_type == 1) tools = tools_mesh; - } #endregion + } - static reset = function() { #region - for(var i = 0; i < array_length(data.tris); i++) - data.tris[i].reset(data); - } #endregion + static reset = function() { + for(var i = 0; i < array_length(mesh_data.tris); i++) + mesh_data.tris[i].reset(mesh_data); + } //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// @@ -506,7 +458,7 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) var _sam = sample + 1; - data.points = array_create(_sam * _sam); + mesh_data.points = array_create(_sam * _sam); var ind = 0; 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 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(j && data.points[(i - 1) * _sam + j] != 0 && 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])); + if(j && mesh_data.points[(i - 1) * _sam + j] != 0 && mesh_data.points[i * _sam + j - 1] != 0) + 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) - array_push(data.tris, new _Triangle(data.points[(i - 1) * _sam + j], data.points[(i - 1) * _sam + j + 1], data.points[i * _sam + j])); + if(j < sample && mesh_data.points[(i - 1) * _sam + j] != 0 && mesh_data.points[(i - 1) * _sam + j + 1] != 0) + 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 for(var i = 0; i < _sam; i++) for(var j = 0; j < _sam; j++) { #region diagonal - var p0 = i && j? data.points[ (i - 1) * _sam + j - 1 ] : 0; - var p1 = i? data.points[ (i - 1) * _sam + j ] : 0; - var p2 = j? data.points[ (i ) * _sam + j - 1 ] : 0; - var p3 = data.points[ (i ) * _sam + j ]; + var p0 = i && j? mesh_data.points[ (i - 1) * _sam + j - 1 ] : 0; + var p1 = i? mesh_data.points[ (i - 1) * _sam + j ] : 0; + var p2 = j? mesh_data.points[ (i ) * _sam + j - 1 ] : 0; + var p3 = mesh_data.points[ (i ) * _sam + j ]; - if(p3 && p1) array_push(data.links, new _Link(p3, p1)); - if(p3 && p2) array_push(data.links, new _Link(p3, p2)); + if(p3 && p1) array_push(mesh_data.links, new _Link(p3, p1)); + if(p3 && p2) array_push(mesh_data.links, new _Link(p3, p2)); var d0 = p0 && p3; var d1 = p1 && p2; if(diagon || d0 ^ d1) { - if(d0) array_push(data.links, new _Link(p0, p3, spring)); - if(d1) array_push(data.links, new _Link(p1, p2, spring)); + if(d0) array_push(mesh_data.links, new _Link(p0, p3, spring)); + if(d1) array_push(mesh_data.links, new _Link(p1, p2, spring)); } } #endregion @@ -620,22 +572,22 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) 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++ ) - 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++ ) - 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++ ) { 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(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[0], t[1])); + array_push(mesh_data.links, new _Link(t[1], t[2])); + array_push(mesh_data.links, new _Link(t[2], t[0])); } } #endregion @@ -644,15 +596,15 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) var _type = getInputData(8); points = []; - data = { points : [], tris : [], links : [], controls: [] }; + mesh_data = { points : [], tris : [], links : [], controls: [] }; switch(_type) { case 0 : Mesh_regularTri(_inSurf); break; case 1 : Mesh_triangulate(_inSurf); break; } - for(var i = 0; i < array_length(data.tris); i++) - data.tris[i].initSurface(is_array(_inSurf)? _inSurf[0] : _inSurf); + for(var i = 0; i < array_length(mesh_data.tris); i++) + mesh_data.tris[i].initSurface(is_array(_inSurf)? _inSurf[0] : _inSurf); triggerRender(); @@ -698,25 +650,25 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) } } #endregion - static control = function() { #region + static control = function() { var lStr = getInputData(6); for(var i = control_index, n = ds_list_size(inputs); i < n; i++) { var c = getInputData(i); - for( var j = 0, m = array_length(data.points); j < m; j++ ) { - if(data.points[j] == 0) continue; - Control_affectPoint(c, data.points[j]); + for( var j = 0, m = array_length(mesh_data.points); j < m; j++ ) { + if(mesh_data.points[j] == 0) continue; + Control_affectPoint(c, mesh_data.points[j]); } } - for( var i = 0, n = array_length(data.points); i < n; i++ ) { - var _p = data.points[i]; if(_p == 0) continue; + for( var i = 0, n = array_length(mesh_data.points); i < n; i++ ) { + var _p = mesh_data.points[i]; if(_p == 0) continue; var _dx = 0; var _dy = 0; - for( var j = 0, m = array_length(data.controls); j < m; j++ ) { - var _c = data.controls[j]; + for( var j = 0, m = array_length(mesh_data.controls); j < m; j++ ) { + var _c = mesh_data.controls[j]; _dx += _c[PUPPET_CONTROL.fx] * _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; repeat(it) { - for( var j = 0; j < array_length(data.points); j++ ) { - if(data.points[j] == 0) continue; - data.points[j].stepMove(_rat); + for( var j = 0; j < array_length(mesh_data.points); j++ ) { + if(mesh_data.points[j] == 0) continue; + mesh_data.points[j].stepMove(_rat); } if(lStr > 0) repeat(it) { - for(var i = 0; i < array_length(data.links); i++) - data.links[i].resolve(lStr); + for(var i = 0; i < array_length(mesh_data.links); i++) + mesh_data.links[i].resolve(lStr); } } - for( var j = 0; j < array_length(data.points); j++ ) { - if(data.points[j] == 0) continue; - data.points[j].clearMove(); + for( var j = 0; j < array_length(mesh_data.points); j++ ) { + if(mesh_data.points[j] == 0) continue; + 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) { Mesh_setTriangle(); will_triangluate = false; } - var _inSurf = _data[0]; - if(!is_surface(_inSurf)) return _outSurf; + var _outSurf = _outData[0]; + var _inSurf = _data[0]; + if(!is_surface(_inSurf)) return [ _outSurf, mesh_data ]; - data.controls = []; + mesh_data.controls = []; for(var i = control_index; i < ds_list_size(inputs); i++) { var c = getInputData(i); if(c[0] == PUPPET_FORCE_MODE.puppet) - array_push(data.controls, c); + array_push(mesh_data.controls, c); } reset(); @@ -774,36 +727,36 @@ function Node_Mesh_Warp(_x, _y, _group = noone) : Node_Processor(_x, _y, _group) surface_set_shader(_outSurf); shader_set_interpolation(_outSurf); - if(array_length(data.tris) == 0) { + if(array_length(mesh_data.tris) == 0) { draw_surface_safe(_inSurf); } else { - for(var i = 0; i < array_length(data.tris); i++) - data.tris[i].drawSurface(_inSurf); + for(var i = 0; i < array_length(mesh_data.tris); i++) + mesh_data.tris[i].drawSurface(_inSurf); } surface_reset_shader(); - return _outSurf; + return [ _outSurf, mesh_data ]; } #endregion //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// - static postDeserialize = function() { #region + static postDeserialize = function() { var _inputs = load_map.inputs; for(var i = control_index; i < array_length(_inputs); i++) { var inp = createControl(); inp.applyDeserialize(_inputs[i]); } - } #endregion + } - static attributeSerialize = function() { #region + static attributeSerialize = function() { var att = {}; struct_append(att, attributes); var pinList = []; - for( var j = 0; j < array_length(data.points); j++ ) { - var p = data.points[j]; + for( var j = 0; j < array_length(mesh_data.points); j++ ) { + var p = mesh_data.points[j]; if(p == 0) continue; 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; return att; - } #endregion + } loadPin = noone; - static attributeDeserialize = function(attr) { #region + static attributeDeserialize = function(attr) { struct_append(attributes, attr); if(struct_has(attr, "pin")) loadPin = attr.pin; if(struct_has(attr, "mesh_bound")) attributes.mesh_bound = attr.mesh_bound;; - } #endregion + } - static postLoad = function() { #region + static postLoad = function() { will_triangluate = true; - } #endregion + } } \ No newline at end of file diff --git a/scripts/panel_graph/panel_graph.gml b/scripts/panel_graph/panel_graph.gml index 5859e07c2..b300a2123 100644 --- a/scripts/panel_graph/panel_graph.gml +++ b/scripts/panel_graph/panel_graph.gml @@ -1678,7 +1678,8 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor { for (var i = 0, n = array_length(_i); i < n; i++) { var _j = _l[| _i[i]]; - array_push_unique(value_draggings, _j); + if(_j.type == value_dragging.type) + array_push_unique(value_draggings, _j); } } else if(key_mod_press(SHIFT)) { diff --git a/scripts/tooltip_hotkey/tooltip_hotkey.gml b/scripts/tooltip_hotkey/tooltip_hotkey.gml index b2745bc00..dbf7705a5 100644 --- a/scripts/tooltip_hotkey/tooltip_hotkey.gml +++ b/scripts/tooltip_hotkey/tooltip_hotkey.gml @@ -7,6 +7,8 @@ function tooltipHotkey(text, context = "", name = "") constructor { static setKey = function(key) { keyStr = key; return self; } static drawTooltip = function() { + if(keyStr == "") { draw_tooltip_text(text); return; } + draw_set_font(f_p0); var _w1 = string_width(text);