This commit is contained in:
Tanasart 2024-06-11 16:26:00 +07:00
parent 85919c6912
commit e09089b3b2
15 changed files with 422 additions and 145 deletions

View file

@ -1695,6 +1695,7 @@
{"name":"s_node_cache","order":27,"path":"sprites/s_node_cache/s_node_cache.yy",},
{"name":"s_node_camera_repeat","order":19,"path":"sprites/s_node_camera_repeat/s_node_camera_repeat.yy",},
{"name":"s_node_camera","order":3,"path":"sprites/s_node_camera/s_node_camera.yy",},
{"name":"s_node_canvas_group","order":39,"path":"sprites/s_node_canvas_group/s_node_canvas_group.yy",},
{"name":"s_node_caustic","order":35,"path":"sprites/s_node_caustic/s_node_caustic.yy",},
{"name":"s_node_chromatic_abarration","order":10,"path":"sprites/s_node_chromatic_abarration/s_node_chromatic_abarration.yy",},
{"name":"s_node_color_adjust","order":1,"path":"sprites/s_node_color_adjust/s_node_color_adjust.yy",},

View file

@ -2241,6 +2241,7 @@
{"id":{"name":"s_node_cache","path":"sprites/s_node_cache/s_node_cache.yy",},},
{"id":{"name":"s_node_camera_repeat","path":"sprites/s_node_camera_repeat/s_node_camera_repeat.yy",},},
{"id":{"name":"s_node_camera","path":"sprites/s_node_camera/s_node_camera.yy",},},
{"id":{"name":"s_node_canvas_group","path":"sprites/s_node_canvas_group/s_node_canvas_group.yy",},},
{"id":{"name":"s_node_canvas","path":"sprites/s_node_canvas/s_node_canvas.yy",},},
{"id":{"name":"s_node_caustic","path":"sprites/s_node_caustic/s_node_caustic.yy",},},
{"id":{"name":"s_node_character","path":"sprites/s_node_character/s_node_character.yy",},},

Binary file not shown.

View file

@ -6,6 +6,8 @@ event_inherited();
node_target_x = 0;
node_target_y = 0;
node_target_x_raw = 0;
node_target_y_raw = 0;
node_called = noone;
junction_hovering = noone;
@ -236,12 +238,11 @@ event_inherited();
}
}
} else if(junction_hovering != noone) { //right click on junction
var to = junction_hovering;
var to = junction_hovering;
var from = junction_hovering.value_from;
for( var i = 0; i < ds_list_size(_inputs); i++ ) {
var _in = _inputs[| i];
if(_in.auto_connect && _in.isConnectable(from)) {
_in.setFrom(from);
break;
@ -255,6 +256,22 @@ event_inherited();
break;
}
}
if(_new_node) {
var _fx = from.node.x, _fy = from.node.y;
var _tx = to.node.x, _ty = to.node.y;
var _ny = node_target_y_raw;
if(_tx > _fx) {
var _rt = abs((_ny - _fy) / (_ty - _fy));
if(_rt < 0.3) _new_node.y = _fy;
else if(_rt > 0.7) {
_new_node.y = _ty;
// _new_node.x = min(_new_node.x, _tx - _new_node.w - 32);
}
}
}
}
} #endregion

View file

@ -162,8 +162,7 @@ function buttonInstant(spr, _x, _y, _w, _h, _m, _act, _hvr, _tip = "", _icon = n
} else if(spr)
draw_sprite_stretched(spr, 0, _x, _y, _w, _h);
if(_icon)
draw_sprite_ui_uniform(_icon, _icon_index, _x + _w / 2, _y + _h / 2, _icon_scale, cc, _icon_alpha);
if(_icon) draw_sprite_ui_uniform(_icon, _icon_index, _x + _w / 2, _y + _h / 2, _icon_scale, cc, _icon_alpha);
return res;
}

View file

@ -57,6 +57,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
var _h = 64;
_y += 8;
var _anim = getInputData(12);
var _cnt_hover = false;
draw_sprite_stretched(THEME.button_def, 0, _x, _y, _w, _h);
@ -66,11 +67,12 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
_cnt_hover = _hover;
}
var _ww = _w - 4 - 40;
var _hh = _h - 4 - 4;
var _aw = ui(32);
var _ww = _w - ui(4) - _aw;
var _hh = _h - ui(4) - ui(4);
var _x0 = _x + 4;
var _y0 = _y + 4;
var _x0 = _x + ui(4);
var _y0 = _y + ui(4);
var _x1 = _x0 + _ww;
var _y1 = _y0 + _hh;
@ -119,7 +121,10 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(mouse_press(mb_left, _focus))
_del = i;
} else if(point_in_rectangle(_msx, _msy, _sx, _sy, _sx + _sw * _ss, _sy + _sh * _ss)) {
if(mouse_press(mb_left, _focus)) preview_index = i;
if(mouse_press(mb_left, _focus)) {
if(_anim) PROJECT.animator.setFrame(i);
else preview_index = i;
}
}
}
@ -141,11 +146,11 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(mouse_wheel_up()) frame_renderer_x_to = clamp(frame_renderer_x_to - 80, 0, frame_renderer_x_max);
}
var _bs = 32;
var _bx = _x1 + ui(20) - _bs / 2;
var _bs = _aw - ui(8);
var _bx = _x1 + _aw / 2 - _bs / 2;
var _by = _y + _h / 2 - _bs / 2;
if(buttonInstant(THEME.button_hide, _bx, _by, _bs, _bs, _m, _focus, _hover,, THEME.add,, COLORS._main_value_positive) == 2) {
if(buttonInstant(THEME.button_hide, _bx, _by, _bs, _bs, _m, _focus, _hover, "", THEME.add_16, 0, COLORS._main_value_positive) == 2) {
attributes.frames++;
refreshFrames();
update();

View file

@ -7,6 +7,7 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
inputs[| 0] = nodeValue("Dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, DEF_SURF )
.setDisplay(VALUE_DISPLAY.vector);
layers = {};
canvases = [];
composite = noone;
canvas_sel = noone;
@ -14,24 +15,23 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
layer_height = 0;
layer_renderer = new Inspector_Custom_Renderer(function(_x, _y, _w, _m, _hover, _focus) {
var _h = ui(4);
var _yy = _y;
if(composite == noone) return _h;
composite.canvas_draw = true;
composite.canvas_draw = self;
var _layer_ren = composite.layer_renderer;
_layer_ren.register(layer_renderer.parent);
_layer_ren.rx = layer_renderer.rx;
_layer_ren.ry = layer_renderer.ry;
var _yy = _y + _h;
var bx = _x;
var by = _y;
var by = _yy;
var bs = ui(24);
if(buttonInstant(THEME.button_hide, bx, by, bs, bs, _m, _focus, _hover, "", THEME.add_16, 0, COLORS._main_value_positive) == 2)
layerAdd();
_h += ui(32);
_yy += ui(32);
_h += bs + ui(8);
_yy += bs + ui(8);
var _wdh = _layer_ren.draw(_x, _yy, _w, _m, _hover, _focus);
if(!is_undefined(_wdh)) _h += _wdh;
@ -39,8 +39,31 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
return _h;
});
frame_renderer = new Inspector_Custom_Renderer(function(_x, _y, _w, _m, _hover, _focus) {
var _h = ui(4);
var _yy = _y;
for (var i = 0, n = array_length(canvases); i < n; i++) {
var _canvas = canvases[i];
var _frame_render = _canvas.frame_renderer;
_frame_render.register(frame_renderer.parent);
_frame_render.rx = frame_renderer.rx;
_frame_render.ry = frame_renderer.ry;
var _wdh = _frame_render.draw(_x, _yy, _w, _m, _hover, _focus);
if(!is_undefined(_wdh)) {
_h += _wdh;
_yy += _wdh;
}
}
return _h;
});
input_display_list = [ 0,
["Layers", false], layer_renderer,
["Frames", false], frame_renderer,
];
static refreshNodes = function() {
@ -54,13 +77,61 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
array_push(canvases, _node);
else if(is_instanceof(_node, Node_Composite))
composite = _node;
_node.modifiable = false;
_node.modify_parent = self;
}
refreshLayer();
}
static refreshLayer = function() {
layers = {};
if(composite == noone) return;
var _amo = composite.getInputAmount();
for(var i = 0; i < _amo; i++) {
var index = composite.input_fix_len + i * composite.data_length;
var _can = composite.inputs[| index].value_from;
if(_can == noone) continue;
var _nod = _can.node;
var _lay = _can.node;
var _modStack = [ _nod ];
while(!is_instanceof(_nod, Node_Canvas)) {
if(_nod.inputs[| 0].type != VALUE_TYPE.surface)
break;
if(_nod.inputs[| 0].value_from == noone)
break;
_nod = _nod.inputs[| 0].value_from.node;
array_push(_modStack, _nod);
}
if(!is_instanceof(_nod, Node_Canvas)) continue;
array_pop(_modStack);
layers[$ _lay.node_id] = {
input : _lay,
canvas : _nod,
modifier : _modStack,
};
}
}
static onAddNode = function(node) {
node.modifiable = false;
node.modify_parent = self;
refreshNodes();
if(is_instanceof(node, Node_Canvas))
array_push(canvases, node);
else if(is_instanceof(node, Node_Composite))
composite = node;
refreshLayer();
}
static layerAdd = function() {
@ -81,16 +152,30 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
_b += 32;
var _canvas = nodeBuild("Node_Canvas", _l, _b);
_canvas.inputs[| 12].setValue(true);
composite.dummy_input.setFrom(_canvas.outputs[| 0]);
addNode(_canvas);
return _canvas;
}
if(NODE_NEW_MANUAL) {
var _canvas = nodeBuild("Node_Canvas", x, y);
var _compose = nodeBuild("Node_Composite", x + 160, y);
static deleteLayer = function(index) {
if(composite == noone) return;
var idx = composite.input_fix_len + index * composite.data_length;
var inp = composite.inputs[| idx];
var nod = inp.value_from? inp.value_from.node : noone;
if(!nod) return;
nod.destroy();
}
if(NODE_NEW_MANUAL) {
var _canvas = nodeBuild("Node_Canvas", x, y);
_canvas.inputs[| 12].setValue(true);
var _compose = nodeBuild("Node_Composite", x + 160, y);
_compose.dummy_input.setFrom(_canvas.outputs[| 0]);
addNode(_canvas);
@ -110,6 +195,7 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
canvas_sel = noone;
if(composite == noone) return;
composite.deleteLayer = deleteLayer;
if(composite.getInputAmount()) {
var _ind = composite.surface_selecting;
@ -117,11 +203,8 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
_ind = composite.input_fix_len;
var _can = composite.inputs[| _ind].value_from;
if(_can) {
var _nod = _can.node;
canvas_sel = _nod;
}
if(_can && struct_has(layers, _can.node.node_id))
canvas_sel = layers[$ _can.node.node_id].canvas;
}
if(canvas_sel) {
@ -132,6 +215,10 @@ function Node_Canvas_Group(_x, _y, _group) : Node_Collection_Inline(_x, _y, _gro
}
}
static update = function() {
refreshLayer();
}
static getPreviewValues = function() { return composite == noone? noone : composite.getPreviewValues(); }
static postDeserialize = function() {

View file

@ -34,7 +34,7 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
hold_select = true;
layer_dragging = noone;
layer_remove = -1;
canvas_draw = false;
canvas_draw = noone;
renaming = noone;
rename_text = "";
@ -54,6 +54,7 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
tb_rename.font = f_p1;
tb_rename.hide = true;
layer_height = 0;
layer_renderer = new Inspector_Custom_Renderer(function(_x, _y, _w, _m, _hover, _focus) { #region
PROCESSOR_OVERLAY_CHECK
@ -63,13 +64,8 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
properties_expand = array_verify(properties_expand, amo);
var _h = ui(4);
for(var i = 0; i < amo; i++)
_h += lh + ui(4) + properties_expand[i] * eh;
_h = max(ui(16), _h);
layer_renderer.h = _h;
draw_sprite_stretched_ext(THEME.ui_panel_bg, 1, _x, _y, _w, _h, COLORS.node_composite_bg_blend, 1);
draw_sprite_stretched_ext(THEME.ui_panel_bg, 1, _x, _y, _w, layer_height, COLORS.node_composite_bg_blend, 1);
var _vis = attributes.layer_visible;
var _sel = attributes.layer_selectable;
@ -86,6 +82,7 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _surf = current_data[index + 0];
var _pos = current_data[index + 1];
var _inp = inputs[| index];
var _junc = _inp.value_from? _inp.value_from.node : noone;
var _bx = _x + _w - ui(24);
var aa = (ind != layer_dragging || layer_dragging == noone)? 1 : 0.5;
@ -93,111 +90,174 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var sel = _sel[ind];
var _exp = properties_expand[i];
var _lh = lh + 4 + _exp * eh;
var _lh = lh + ui(4) + _exp * eh;
_h += _lh;
if(_exp) { #region extended
var _px = _x + ui(4);
var _py = _cy + lh + ui(4);
var _pw = _w - ui(8);
var _ph = eh - ui(4);
#region extended
if(_exp) {
var _px = _x + ui(4);
var _py = _cy + lh + ui(4);
var _pw = _w - ui(8);
var _ph = eh - ui(4);
var _pww = (_pw - ui(8)) / 2 - ui(8);
var _pwh = _ph - ui(8);
var _pww = (_pw - ui(8)) / 2 - ui(8);
var _pwh = _ph - ui(8);
draw_sprite_stretched_ext(THEME.ui_panel_bg, 0, _px, _py, _pw, _ph, COLORS.node_composite_bg_blend, 1);
draw_sprite_stretched_ext(THEME.ui_panel_bg, 0, _px, _py, _pw, _ph, COLORS.node_composite_bg_blend, 1);
var jn_bld = inputs[| index + 4];
var jn_alp = inputs[| index + 5];
var jn_bld = inputs[| index + 4];
var jn_alp = inputs[| index + 5];
var wd_bld = jn_bld.editWidget;
var wd_alp = jn_alp.editWidget;
var wd_bld = jn_bld.editWidget;
var wd_alp = jn_alp.editWidget;
var _param = new widgetParam(_px + ui(4), _py + ui(4), _pww, _pwh, jn_bld.showValue(), jn_bld.display_data, _m, layer_renderer.rx, layer_renderer.ry);
_param.font = f_p2;
var _param = new widgetParam(_px + ui(4), _py + ui(4), _pww, _pwh, jn_bld.showValue(), jn_bld.display_data, _m, layer_renderer.rx, layer_renderer.ry);
_param.font = f_p2;
wd_bld.setFocusHover(_focus, _hover);
wd_bld.drawParam(_param);
wd_bld.setFocusHover(_focus, _hover);
wd_bld.drawParam(_param);
var _param = new widgetParam(_px + ui(4) + _pww + ui(8), _py + ui(4), _pww, _pwh, jn_alp.showValue(), jn_alp.display_data, _m, layer_renderer.rx, layer_renderer.ry);
_param.font = f_p2;
var _param = new widgetParam(_px + ui(4) + _pww + ui(8), _py + ui(4), _pww, _pwh, jn_alp.showValue(), jn_alp.display_data, _m, layer_renderer.rx, layer_renderer.ry);
_param.font = f_p2;
wd_alp.setFocusHover(_focus, _hover);
wd_alp.drawParam(_param);
} #endregion
if(point_in_circle(_m[0], _m[1], _bx, _cy + lh / 2, ui(16))) {
draw_sprite_ui_uniform(THEME.icon_delete, 3, _bx, _cy + lh / 2, 1, COLORS._main_value_negative);
if(mouse_press(mb_left, _focus))
layer_remove = ind;
} else
draw_sprite_ui_uniform(THEME.icon_delete, 3, _bx, _cy + lh / 2, 1, COLORS._main_icon);
if(!is_surface(_surf)) continue;
var _bx = _x + ui(16 + 24);
if(point_in_circle(_m[0], _m[1], _bx, _cy + lh / 2, ui(12))) {
draw_sprite_ui_uniform(THEME.junc_visible, vis, _bx, _cy + lh / 2, 1, c_white);
if(mouse_press(mb_left, _focus))
hold_visibility = !_vis[ind];
if(mouse_click(mb_left, _focus) && _vis[ind] != hold_visibility) {
_vis[ind] = hold_visibility;
doUpdate();
wd_alp.setFocusHover(_focus, _hover);
wd_alp.drawParam(_param);
}
} else
draw_sprite_ui_uniform(THEME.junc_visible, vis, _bx, _cy + lh / 2, 1, COLORS._main_icon, 0.5 + 0.5 * vis);
#endregion
_bx += ui(12 + 1 + 12);
if(point_in_circle(_m[0], _m[1], _bx, _cy + lh / 2, ui(12))) {
draw_sprite_ui_uniform(THEME.cursor_select, sel, _bx, _cy + lh / 2, 1, c_white);
#region draw buttons
if(point_in_circle(_m[0], _m[1], _bx, _cy + lh / 2, ui(16))) {
draw_sprite_ui_uniform(THEME.icon_delete, 3, _bx, _cy + lh / 2, 1, COLORS._main_value_negative);
if(mouse_press(mb_left, _focus))
hold_select = !_sel[ind];
if(mouse_press(mb_left, _focus))
layer_remove = ind;
} else
draw_sprite_ui_uniform(THEME.icon_delete, 3, _bx, _cy + lh / 2, 1, COLORS._main_icon);
if(mouse_click(mb_left, _focus) && _sel[ind] != hold_select)
_sel[ind] = hold_select;
} else
draw_sprite_ui_uniform(THEME.cursor_select, sel, _bx, _cy + lh / 2, 1, COLORS._main_icon, 0.5 + 0.5 * sel);
if(!is_surface(_surf)) continue;
var hover = point_in_rectangle(_m[0], _m[1], _bx + ui(12 + 6), _cy, _x + _w - ui(48), _cy + lh - 1);
var _bx = _x + ui(16 + 24);
if(point_in_circle(_m[0], _m[1], _bx, _cy + lh / 2, ui(12))) {
draw_sprite_ui_uniform(THEME.junc_visible, vis, _bx, _cy + lh / 2, 1, c_white);
var _sx0 = _bx + ui(12 + 6);
var _sx1 = _sx0 + ssh;
var _sy0 = _cy + ui(3);
var _sy1 = _sy0 + ssh;
if(mouse_press(mb_left, _focus))
hold_visibility = !_vis[ind];
var _ssw = surface_get_width_safe(_surf);
var _ssh = surface_get_height_safe(_surf);
var _sss = min(ssh / _ssw, ssh / _ssh);
draw_surface_ext_safe(_surf, _sx0, _sy0, _sss, _sss, 0, c_white, 1);
if(mouse_click(mb_left, _focus) && _vis[ind] != hold_visibility) {
_vis[ind] = hold_visibility;
doUpdate();
}
} else
draw_sprite_ui_uniform(THEME.junc_visible, vis, _bx, _cy + lh / 2, 1, COLORS._main_icon, 0.5 + 0.5 * vis);
draw_set_text(f_p1, fa_left, fa_center, hover? COLORS._main_text_accent : COLORS._main_text);
var _txt = _inp.name;
_bx += ui(12 + 1 + 12);
if(point_in_circle(_m[0], _m[1], _bx, _cy + lh / 2, ui(12))) {
draw_sprite_ui_uniform(THEME.cursor_select, sel, _bx, _cy + lh / 2, 1, c_white);
if(canvas_draw) {
if(_inp.value_from && is_instanceof(_inp.value_from.node, Node_Canvas))
_txt = _inp.value_from.node.display_name;
}
if(mouse_press(mb_left, _focus))
hold_select = !_sel[ind];
var _txx = _sx1 + ui(12);
var _txy = _cy + lh / 2 + ui(2);
if(mouse_click(mb_left, _focus) && _sel[ind] != hold_select)
_sel[ind] = hold_select;
} else
draw_sprite_ui_uniform(THEME.cursor_select, sel, _bx, _cy + lh / 2, 1, COLORS._main_icon, 0.5 + 0.5 * sel);
if(renaming_index == index) {
tb_rename.setFocusHover(_focus, _hover);
tb_rename.draw(_txx, _cy, _w - ui(172), lh, rename_text, _m);
var hover = point_in_rectangle(_m[0], _m[1], _bx + ui(12 + 6), _cy, _x + _w - ui(48), _cy + lh - 1);
#endregion
} else {
var _txw = string_width(_txt);
var _txh = string_height(_txt);
draw_set_alpha(aa);
draw_text(_txx, _txy, _txt);
draw_set_alpha(1);
#region draw surface
var _sx0 = _bx + ui(12 + 6);
var _sx1 = _sx0 + ssh;
var _sy0 = _cy + ui(3);
var _sy1 = _sy0 + ssh;
if(surface_selecting == index)
draw_sprite_stretched_add(THEME.menu_button_mask, 1, _txx - ui(8), _txy - _txh / 2 - ui(2), _txw + ui(16), _txh + ui(4), COLORS._main_icon, 0.3);
}
var _ssw = surface_get_width_safe(_surf);
var _ssh = surface_get_height_safe(_surf);
var _sss = min(ssh / _ssw, ssh / _ssh);
draw_surface_ext_safe(_surf, _sx0, _sy0, _sss, _sss, 0, c_white, 1);
if(surface_selecting == index) draw_sprite_stretched_add(THEME.menu_button_mask, 1, _sx0, _sy0, ssh, ssh, COLORS._main_accent, 1);
else draw_sprite_stretched_add(THEME.menu_button_mask, 1, _sx0, _sy0, ssh, ssh, COLORS._main_icon, 0.3);
#endregion
#region layers
var _junc_canvas = noone;
var _jun_layer = noone;
if(canvas_draw != noone && _junc && struct_has(canvas_draw.layers, _junc.node_id)) {
_jun_layer = canvas_draw.layers[$ _junc.node_id];
_junc_canvas = _jun_layer.canvas;
}
#endregion
#region draw title
draw_set_text(f_p1, fa_left, fa_center, hover? COLORS._main_text_accent : COLORS._main_text);
var _txt = _inp.name;
var _txx = _sx1 + ui(12);
var _txy = _cy + lh / 2 + ui(2);
if(canvas_draw != noone && _junc_canvas)
_txt = _junc_canvas.display_name;
if(renaming_index == index) {
tb_rename.setFocusHover(_focus, _hover);
tb_rename.draw(_txx, _cy, _w - ui(172), lh, rename_text, _m);
} else {
var _txw = string_width(_txt);
var _txh = string_height(_txt);
if(_junc_canvas) {
draw_sprite_ui_uniform(THEME.icon_canvas, 0, _txx + ui(12), _txy - ui(1), 1, COLORS._main_icon, aa * .8);
draw_set_alpha(aa);
draw_text(_txx + ui(28), _txy, _txt);
draw_set_alpha(1);
} else {
draw_set_alpha(aa);
draw_text(_txx, _txy, _txt);
draw_set_alpha(1);
}
}
#endregion
#region modifiers
if(_jun_layer) {
var _modis = _jun_layer.modifier;
var _mdx = _txx - ui(23);
var _mdy = _cy + _lh;
var mh = ui(24);
for (var j = array_length(_modis) - 1; j >= 0; j--) {
var _modi = _modis[j];
var _mtx = _mdx;
if(_modi.active_index != -1) {
var _bx = _mtx + ui(12);
var _by = _mdy + mh / 2;
var _acti = _modi.inputs[| _modi.active_index].getValue();
if(_hover && point_in_circle(_m[0], _m[1], _bx, _by, ui(12))) {
draw_sprite_ui_uniform(THEME.visible_12, _acti, _bx, _by - ui(2), 1, c_white);
if(mouse_press(mb_left, _focus))
_modi.inputs[| _modi.active_index].setValue(!_acti);
} else
draw_sprite_ui_uniform(THEME.visible_12, _acti, _bx, _by - ui(2), 1, COLORS._main_icon);
}
_mtx += ui(24);
var _mhov = _hover && point_in_rectangle(_m[0], _m[1], _mtx, _mdy, _x + _w, _mdy + mh - 1);
draw_set_text(f_p2, fa_left, fa_center, _mhov? COLORS._main_text : COLORS._main_text_sub);
draw_text_add(_mtx, _mdy + mh / 2 - ui(2), _modi.display_name);
_h += mh;
_lh += mh;
_mdy += mh;
}
}
#endregion
if(_hover && point_in_rectangle(_m[0], _m[1], _x, _cy, _x + _w, _cy + lh)) {
hoverIndex = ind;
@ -227,8 +287,8 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
renaming = index;
rename_text = _txt;
if(canvas_draw && _inp.value_from && is_instanceof(_inp.value_from.node, Node_Canvas))
renaming = _inp.value_from.node;
if(canvas_draw != noone && _junc_canvas)
renaming = _junc_canvas;
tb_rename._current_text = _txt;
tb_rename.activate();
@ -273,7 +333,10 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
layer_dragging = noone;
}
return _h;
layer_height = max(ui(16), _h);
layer_renderer.h = layer_height;
return layer_height;
}); #endregion
input_display_list = [
@ -646,6 +709,9 @@ function Node_Composite(_x, _y, _group = noone) : Node_Processor(_x, _y, _group)
var _dim_type = getSingleValue(1);
inputs[| 2].setVisible(_dim_type == COMPOSE_OUTPUT_SCALING.constant);
if(canvas_draw != noone && surface_selecting == noone && getInputAmount())
surface_selecting = input_fix_len;
} #endregion
static processData = function(_outSurf, _data, _output_index, _array_index) { #region

View file

@ -40,6 +40,8 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
modifiable = true;
modify_parent = noone;
onDoubleClick = -1;
#endregion
static resetInternalName = function() { #region

View file

@ -490,7 +490,7 @@ function __initNodes() {
addNodeCatagory("IO", input);
ds_list_add(input, "Images");
addNodeObject(input, "Canvas", s_node_canvas, "Node_Canvas", [1, Node_Canvas], ["draw"], "Draw on surface using brush, eraser, etc.");
addNodeObject(input, "Canvas Group", s_node_canvas, "Node_Canvas_Group", [1, Node_Canvas_Group]);
addNodeObject(input, "Canvas Group", s_node_canvas_group, "Node_Canvas_Group", [1, Node_Canvas_Group]).setVersion(11740);
addNodeObject(input, "Active Canvas", s_node_active_canvas, "Node_Active_Canvas", [1, Node_Active_Canvas], ["draw"], "Draw using parameterized brush.").setVersion(11570);
addNodeObject(input, "Image", s_node_image, "Node_Image", [0, Node_create_Image],, "Load a single image from your computer.");
addNodeObject(input, "Image GIF", s_node_image_gif, "Node_Image_gif", [0, Node_create_Image_gif],, "Load animated .gif from your computer.");

View file

@ -1043,14 +1043,15 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
for(var i = 0; i < array_length(nodes_list); i++) {
var _node = nodes_list[i];
_node.branch_drawing = false;
if(_node.pointIn(gr_x, gr_y, mx, my, graph_s))
node_hovering = _node.modify_parent == noone? _node : _node.modify_parent;
node_hovering = _node;
}
if(node_hovering != noone)
_HOVERING_ELEMENT = node_hovering;
if(node_hovering != noone && _focus && DOUBLE_CLICK && struct_has(node_hovering, "onDoubleClick")) {
if(node_hovering != noone && _focus && DOUBLE_CLICK && node_hovering.onDoubleClick != -1) {
if(node_hovering.onDoubleClick(self)) {
DOUBLE_CLICK = false;
@ -1111,6 +1112,7 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
}
} else if(DOUBLE_CLICK) {
PANEL_PREVIEW.setNodePreview(node_hovering);
if(PREFERENCES.inspector_focus_on_double_click) {
if(PANEL_INSPECTOR.panel && struct_has(PANEL_INSPECTOR.panel, "switchContent"))
PANEL_INSPECTOR.panel.switchContent(PANEL_INSPECTOR);
@ -1252,6 +1254,9 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
if(is_instanceof(frame_hovering, Node_Collection_Inline) && DOUBLE_CLICK && array_empty(nodes_selecting)) { #region
nodes_selecting = [ frame_hovering ];
if(frame_hovering.onDoubleClick != -1) frame_hovering.onDoubleClick(self)
if(frame_hovering.previewable) PANEL_PREVIEW.setNodePreview(frame_hovering);
} #endregion
}
#endregion
@ -1561,9 +1566,11 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
ctx = value_dragging.node.inline_context;
with(dialogCall(o_dialog_add_node, mouse_mx + 8, mouse_my + 8, { context: ctx })) {
node_target_x = other.mouse_grid_x;
node_target_y = other.mouse_grid_y;
node_called = other.value_dragging;
node_target_x = other.mouse_grid_x;
node_target_y = other.mouse_grid_y;
node_target_x_raw = other.mouse_grid_x;
node_target_y_raw = other.mouse_grid_y;
node_called = other.value_dragging;
alarm[0] = 1;
}
@ -1761,6 +1768,8 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
with(_dia) {
node_target_x = other.mouse_grid_x;
node_target_y = other.mouse_grid_y;
node_target_x_raw = other.mouse_grid_x;
node_target_y_raw = other.mouse_grid_y;
junction_hovering = other.junction_hovering;
resetPosition();

View file

@ -1898,7 +1898,7 @@ function Panel_Preview() : PanelContent() constructor {
function drawContent(panel) { #region >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>> MAIN DRAW <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<
mouse_on_preview = pHOVER && point_in_rectangle(mx, my, 0, topbar_height, w, h - toolbar_height);
if(do_fullView) fullView();
if(do_fullView) run_in(1, fullView);
do_fullView = false;
var _prev_node = getNodePreview();

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

View file

@ -0,0 +1,90 @@
{
"$GMSprite":"",
"%Name":"s_node_canvas_group",
"bboxMode":0,
"bbox_bottom":63,
"bbox_left":2,
"bbox_right":63,
"bbox_top":2,
"collisionKind":1,
"collisionTolerance":0,
"DynamicTexturePage":false,
"edgeFiltering":false,
"For3D":false,
"frames":[
{"$GMSpriteFrame":"","%Name":"f9dbf063-7abe-47a2-bc35-983ff7f9e83e","name":"f9dbf063-7abe-47a2-bc35-983ff7f9e83e","resourceType":"GMSpriteFrame","resourceVersion":"2.0",},
],
"gridX":0,
"gridY":0,
"height":64,
"HTile":false,
"layers":[
{"$GMImageLayer":"","%Name":"6c3c616c-af55-430e-99da-29a0fd5aab17","blendMode":0,"displayName":"default","isLocked":false,"name":"6c3c616c-af55-430e-99da-29a0fd5aab17","opacity":100.0,"resourceType":"GMImageLayer","resourceVersion":"2.0","visible":true,},
],
"name":"s_node_canvas_group",
"nineSlice":null,
"origin":4,
"parent":{
"name":"IO",
"path":"folders/nodes/icons/IO.yy",
},
"preMultiplyAlpha":false,
"resourceType":"GMSprite",
"resourceVersion":"2.0",
"sequence":{
"$GMSequence":"",
"%Name":"s_node_canvas_group",
"autoRecord":true,
"backdropHeight":768,
"backdropImageOpacity":0.5,
"backdropImagePath":"",
"backdropWidth":1366,
"backdropXOffset":0.0,
"backdropYOffset":0.0,
"events":{
"$KeyframeStore<MessageEventKeyframe>":"",
"Keyframes":[],
"resourceType":"KeyframeStore<MessageEventKeyframe>",
"resourceVersion":"2.0",
},
"eventStubScript":null,
"eventToFunction":{},
"length":1.0,
"lockOrigin":false,
"moments":{
"$KeyframeStore<MomentsEventKeyframe>":"",
"Keyframes":[],
"resourceType":"KeyframeStore<MomentsEventKeyframe>",
"resourceVersion":"2.0",
},
"name":"s_node_canvas_group",
"playback":1,
"playbackSpeed":30.0,
"playbackSpeedType":0,
"resourceType":"GMSequence",
"resourceVersion":"2.0",
"showBackdrop":true,
"showBackdropImage":false,
"timeUnits":1,
"tracks":[
{"$GMSpriteFramesTrack":"","builtinName":0,"events":[],"inheritsTrackColour":true,"interpolation":1,"isCreationTrack":false,"keyframes":{"$KeyframeStore<SpriteFrameKeyframe>":"","Keyframes":[
{"$Keyframe<SpriteFrameKeyframe>":"","Channels":{
"0":{"$SpriteFrameKeyframe":"","Id":{"name":"f9dbf063-7abe-47a2-bc35-983ff7f9e83e","path":"sprites/s_node_canvas_group/s_node_canvas_group.yy",},"resourceType":"SpriteFrameKeyframe","resourceVersion":"2.0",},
},"Disabled":false,"id":"0ff72cb6-ecd8-47ca-a671-b475834f3bdd","IsCreationKey":false,"Key":0.0,"Length":1.0,"resourceType":"Keyframe<SpriteFrameKeyframe>","resourceVersion":"2.0","Stretch":false,},
],"resourceType":"KeyframeStore<SpriteFrameKeyframe>","resourceVersion":"2.0",},"modifiers":[],"name":"frames","resourceType":"GMSpriteFramesTrack","resourceVersion":"2.0","spriteId":null,"trackColour":0,"tracks":[],"traits":0,},
],
"visibleRange":null,
"volume":1.0,
"xorigin":32,
"yorigin":32,
},
"swatchColours":null,
"swfPrecision":0.5,
"textureGroupId":{
"name":"Default",
"path":"texturegroups/Default",
},
"type":0,
"VTile":false,
"width":64,
}