- [Canvas] When using eraser, if the alpha channel is set to true, then the eraser will only erase alpha channel.

- [Canvas] Add brush distance, rotation, rotate by direction properties.
This commit is contained in:
Tanasart 2023-11-01 20:13:23 +07:00
parent 8aa87fa04f
commit 5234bccba0
2 changed files with 192 additions and 122 deletions

View file

@ -17,7 +17,7 @@ function curveBox(_onModify) : widget() constructor {
display_pos_x = 0; display_pos_x = 0;
display_pos_y = 0; display_pos_y = 0;
display_sel = false; display_sel = 0;
grid_snap = false; grid_snap = false;
grid_step = 0.05; grid_step = 0.05;
@ -329,7 +329,7 @@ function curveBox(_onModify) : widget() constructor {
} }
} }
if(mouse_press(mb_right, active)) { if(node_hovering == -1 && mouse_press(mb_right, active)) {
menuCall("widget_curve", rx + _m[0], ry + _m[1], [ menuCall("widget_curve", rx + _m[0], ry + _m[1], [
menuItem(grid_show? __txt("Hide grid") : __txt("Show grid"), function() { grid_show = !grid_show; }), menuItem(grid_show? __txt("Hide grid") : __txt("Show grid"), function() { grid_show = !grid_show; }),
menuItem(__txt("Snap to grid"), function() { grid_snap = !grid_snap; },,, function() { return grid_snap } ), menuItem(__txt("Snap to grid"), function() { grid_snap = !grid_snap; },,, function() { return grid_snap } ),

View file

@ -17,7 +17,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
inputs[| 5] = nodeValue("Draw preview overlay", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true); inputs[| 5] = nodeValue("Draw preview overlay", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true);
inputs[| 6] = nodeValue("Brush", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, -1) inputs[| 6] = nodeValue("Brush", self, JUNCTION_CONNECT.input, VALUE_TYPE.surface, noone)
.setVisible(true, false); .setVisible(true, false);
inputs[| 7] = nodeValue("Surface amount", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1); inputs[| 7] = nodeValue("Surface amount", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, 1);
@ -38,6 +38,14 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
inputs[| 14] = nodeValue("Use background dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true ); inputs[| 14] = nodeValue("Use background dimension", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, true );
inputs[| 15] = nodeValue("Brush distance", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ 1, 1 ] )
.setDisplay(VALUE_DISPLAY.range, { linked : true });
inputs[| 16] = nodeValue("Rotate brush by direction", self, JUNCTION_CONNECT.input, VALUE_TYPE.boolean, false );
inputs[| 17] = nodeValue("Random direction", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, [ 0, 0, 0, 0, 0 ] )
.setDisplay(VALUE_DISPLAY.rotation_random);
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);
frame_renderer_x = 0; frame_renderer_x = 0;
@ -148,11 +156,12 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
input_display_list = [ input_display_list = [
["Output", false], 0, frame_renderer, 12, 13, ["Output", false], 0, frame_renderer, 12, 13,
["Brush", false], 6, 2, 1, 11, ["Brush", false], 6, 2, 1, 11, 15, 17, 16,
["Fill", false], 3, 4, ["Fill", false], 3, 4,
["Display", false], 8, 10, 14, 9, ["Display", false], 8, 10, 14, 9,
]; ];
#region ++++ data ++++
attributes.frames = 1; attributes.frames = 1;
attribute_surface_depth(); attribute_surface_depth();
@ -188,6 +197,8 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
mouse_pre_y = 0; mouse_pre_y = 0;
mouse_pre_draw_x = -1; mouse_pre_draw_x = -1;
mouse_pre_draw_y = -1; mouse_pre_draw_y = -1;
mouse_pre_dir_x = -1;
mouse_pre_dir_y = -1;
mouse_holding = false; mouse_holding = false;
@ -198,6 +209,17 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
brush_sizing_dx = 0; brush_sizing_dx = 0;
brush_sizing_dy = 0; brush_sizing_dy = 0;
brush_surface = noone;
brush_size = 1;
brush_dist_min = 1;
brush_dist_max = 1;
brush_direction = 0;
brush_rand_dir = [ 0, 0, 0, 0, 0 ];
brush_seed = irandom_range(100000, 999999);
brush_drag_dist = 0;
brush_next_dist = 0;
tool_channel_edit = new checkBoxGroup(THEME.tools_canvas_channel, function(ind, val) { tool_attribute.channel[ind] = val; }); tool_channel_edit = new checkBoxGroup(THEME.tools_canvas_channel, function(ind, val) { tool_attribute.channel[ind] = val; });
tool_attribute.channel = [ true, true, true, true ]; tool_attribute.channel = [ true, true, true, true ];
tool_settings = [ tool_settings = [
@ -214,6 +236,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
]; ];
draw_stack = ds_list_create(); draw_stack = ds_list_create();
#endregion
function removeFrame(index = 0) { #region function removeFrame(index = 0) { #region
if(attributes.frames <= 1) return; if(attributes.frames <= 1) return;
@ -324,9 +347,15 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
storeAction(); storeAction();
surface_set_target(getCanvasSurface()); surface_set_target(getCanvasSurface());
if(isUsingTool("Eraser")) gpu_set_blendmode(bm_subtract); BLEND_ALPHA
else BLEND_ALPHA if(isUsingTool("Eraser")) {
gpu_set_blendmode(bm_subtract);
if(tool_attribute.channel[3])
gpu_set_colorwriteenable(false, false, false, true);
}
draw_surface_ext_safe(drawing_surface, 0, 0, 1, 1, 0, c_white, _alp); draw_surface_ext_safe(drawing_surface, 0, 0, 1, 1, 0, c_white, _alp);
gpu_set_colorwriteenable(tool_attribute.channel[0], tool_attribute.channel[1], tool_attribute.channel[2], tool_attribute.channel[3]);
surface_reset_target(); surface_reset_target();
surface_clear(drawing_surface); surface_clear(drawing_surface);
@ -335,38 +364,42 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
surface_store_buffer(); surface_store_buffer();
} #endregion } #endregion
function draw_point_size(_x, _y, _siz, _brush) { #region function draw_point_size(_x, _y, _draw = false) { #region
if(!is_surface(_brush)) { if(brush_surface == noone) {
if(_siz <= 1) if(brush_size <= 1)
draw_point(_x, _y); draw_point(_x, _y);
else if(_siz == 2) { else if(brush_size == 2) {
draw_point(_x, _y); draw_point(_x, _y);
draw_point(_x + 1, _y); draw_point(_x + 1, _y);
draw_point(_x, _y + 1); draw_point(_x, _y + 1);
draw_point(_x + 1, _y + 1); draw_point(_x + 1, _y + 1);
} else if(_siz == 3) { } else if(brush_size == 3) {
draw_point(_x, _y); draw_point(_x, _y);
draw_point(_x - 1, _y); draw_point(_x - 1, _y);
draw_point(_x, _y - 1); draw_point(_x, _y - 1);
draw_point(_x + 1, _y); draw_point(_x + 1, _y);
draw_point(_x, _y + 1); draw_point(_x, _y + 1);
} else } else
draw_circle_prec(_x, _y, _siz / 2, 0); draw_circle_prec(_x, _y, brush_size / 2, 0);
} else { } else {
var _sw = surface_get_width_safe(_brush); var _sw = surface_get_width_safe(brush_surface);
var _sh = surface_get_height_safe(_brush); var _sh = surface_get_height_safe(brush_surface);
var _r = brush_direction + angle_random_eval(brush_rand_dir, brush_seed);
var _p = point_rotate(-_sw / 2, -_sh / 2, 0, 0, _r);
draw_surface_ext_safe(_brush, _x - floor(_sw / 2), _y - floor(_sh / 2), 1, 1, 0, draw_get_color(), draw_get_alpha()); draw_surface_ext_safe(brush_surface, _x + _p[0], _y + _p[1], 1, 1, _r, draw_get_color(), draw_get_alpha());
if(_draw) brush_seed = irandom_range(100000, 999999);
} }
} #endregion } #endregion
function draw_line_size(_x0, _y0, _x1, _y1, _siz, _brush) { #region function draw_line_size(_x0, _y0, _x1, _y1, _draw = false) { #region
if(_x1 > _x0) _x0--; if(_x1 > _x0) _x0--;
if(_y1 > _y0) _y0--; if(_y1 > _y0) _y0--;
if(_y1 < _y0) _y1--; if(_y1 < _y0) _y1--;
if(_x1 < _x0) _x1--; if(_x1 < _x0) _x1--;
if(_siz == 1 && _brush == -1) if(brush_size == 1 && brush_surface == noone)
draw_line(_x0, _y0, _x1, _y1); draw_line(_x0, _y0, _x1, _y1);
else { else {
var diss = point_distance(_x0, _y0, _x1, _y1); var diss = point_distance(_x0, _y0, _x1, _y1);
@ -374,30 +407,43 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
var st_x = lengthdir_x(1, dirr); var st_x = lengthdir_x(1, dirr);
var st_y = lengthdir_y(1, dirr); var st_y = lengthdir_y(1, dirr);
for( var i = 0; i <= diss; i += 1 ) { var _i = _draw? brush_next_dist : 0;
var _px = _x0 + st_x * i; var _dst = diss;
var _py = _y0 + st_y * i;
draw_point_size(_px, _py, _siz, _brush); if(_i < diss) {
while(_i < diss) {
var _px = _x0 + st_x * _i;
var _py = _y0 + st_y * _i;
draw_point_size(_px, _py, _draw);
brush_next_dist = random_range(brush_dist_min, brush_dist_max);
_i += brush_next_dist;
_dst -= brush_next_dist;
} }
draw_point_size(_x1, _y1, _siz, _brush); brush_next_dist -= _dst;
} else
brush_next_dist -= diss;
if(brush_dist_min == brush_dist_max && brush_dist_min == 1)
draw_point_size(_x1, _y1, _draw);
} }
} #endregion } #endregion
function draw_rect_size(_x0, _y0, _x1, _y1, _siz, _fill, _brush) { #region function draw_rect_size(_x0, _y0, _x1, _y1, _fill) { #region
if(_x0 == _x1 && _y0 == _y1) { if(_x0 == _x1 && _y0 == _y1) {
draw_point_size(_x0, _y0, _siz, _brush); draw_point_size(_x0, _y0);
return; return;
} else if(_x0 == _x1) { } else if(_x0 == _x1) {
draw_point_size(_x0, _y0, _siz, _brush); draw_point_size(_x0, _y0);
draw_point_size(_x1, _y1, _siz, _brush); draw_point_size(_x1, _y1);
draw_line_size(_x0, _y0, _x0, _y1, _siz, _brush); draw_line_size(_x0, _y0, _x0, _y1);
return; return;
} else if(_y0 == _y1) { } else if(_y0 == _y1) {
draw_point_size(_x0, _y0, _siz, _brush); draw_point_size(_x0, _y0);
draw_point_size(_x1, _y1, _siz, _brush); draw_point_size(_x1, _y1);
draw_line_size(_x0, _y0, _x1, _y0, _siz, _brush); draw_line_size(_x0, _y0, _x1, _y0);
return; return;
} }
@ -408,29 +454,29 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(_fill) { if(_fill) {
draw_rectangle(_min_x, _min_y, _max_x, _may_y, 0); draw_rectangle(_min_x, _min_y, _max_x, _may_y, 0);
} else if(_siz == 1 && _brush == -1) } else if(brush_size == 1 && brush_surface == noone)
draw_rectangle(_min_x + 1, _min_y + 1, _max_x - 1, _may_y - 1, 1); draw_rectangle(_min_x + 1, _min_y + 1, _max_x - 1, _may_y - 1, 1);
else { else {
draw_line_size(_min_x, _min_y, _max_x, _min_y, _siz, _brush); draw_line_size(_min_x, _min_y, _max_x, _min_y);
draw_line_size(_min_x, _min_y, _min_x, _may_y, _siz, _brush); draw_line_size(_min_x, _min_y, _min_x, _may_y);
draw_line_size(_max_x, _may_y, _max_x, _min_y, _siz, _brush); draw_line_size(_max_x, _may_y, _max_x, _min_y);
draw_line_size(_max_x, _may_y, _min_x, _may_y, _siz, _brush); draw_line_size(_max_x, _may_y, _min_x, _may_y);
} }
} #endregion } #endregion
function draw_ellp_size(_x0, _y0, _x1, _y1, _siz, _fill, _brush) { #region function draw_ellp_size(_x0, _y0, _x1, _y1, _fill) { #region
if(_x0 == _x1 && _y0 == _y1) { if(_x0 == _x1 && _y0 == _y1) {
draw_point_size(_x0, _y0, _siz, _brush); draw_point_size(_x0, _y0);
return; return;
} else if(_x0 == _x1) { } else if(_x0 == _x1) {
draw_point_size(_x0, _y0, _siz, _brush); draw_point_size(_x0, _y0);
draw_point_size(_x1, _y1, _siz, _brush); draw_point_size(_x1, _y1);
draw_line_size(_x0, _y0, _x0, _y1, _siz, _brush); draw_line_size(_x0, _y0, _x0, _y1);
return; return;
} else if(_y0 == _y1) { } else if(_y0 == _y1) {
draw_point_size(_x0, _y0, _siz, _brush); draw_point_size(_x0, _y0);
draw_point_size(_x1, _y1, _siz, _brush); draw_point_size(_x1, _y1);
draw_line_size(_x0, _y0, _x1, _y0, _siz, _brush); draw_line_size(_x0, _y0, _x1, _y0);
return; return;
} }
@ -453,7 +499,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
nx = cx + lengthdir_x(rx, 360 / samp * i); nx = cx + lengthdir_x(rx, 360 / samp * i);
ny = cy + lengthdir_y(ry, 360 / samp * i); ny = cy + lengthdir_y(ry, 360 / samp * i);
if(i) draw_line_size(ox, oy, nx, ny, _siz, _brush); if(i) draw_line_size(ox, oy, nx, ny);
ox = nx; ox = nx;
oy = ny; oy = ny;
@ -606,8 +652,23 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
var _thr = getInputData(3); var _thr = getInputData(3);
var _fill_type = getInputData(4); var _fill_type = getInputData(4);
var _prev = getInputData(5); var _prev = getInputData(5);
var _brush = getInputData(6); var _brushSurf = getInputData(6);
var _brushDist = getInputData(15);
var _brushRotD = getInputData(16);
var _brushRotR = getInputData(17);
brush_size = _siz;
brush_dist_min = max(1, _brushDist[0]);
brush_dist_max = max(1, _brushDist[1]);
brush_surface = is_surface(_brushSurf)? _brushSurf : noone;
if(!_brushRotD)
brush_direction = 0;
else if(point_distance(mouse_pre_dir_x, mouse_pre_dir_y, _mx, _my) > _s) {
brush_direction = point_direction(mouse_pre_dir_x, mouse_pre_dir_y, _mx, _my);
mouse_pre_dir_x = _mx;
mouse_pre_dir_y = _my;
}
brush_rand_dir = _brushRotR;
if(key_mod_press(ALT)) return; if(key_mod_press(ALT)) return;
var _canvas_surface = getCanvasSurface(); var _canvas_surface = getCanvasSurface();
@ -763,16 +824,18 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
} }
if(mouse_press(mb_left, active)) { if(mouse_press(mb_left, active)) {
brush_next_dist = 0;
drawing_surface = surface_verify(drawing_surface, _dim[0], _dim[1], attrDepth()); drawing_surface = surface_verify(drawing_surface, _dim[0], _dim[1], attrDepth());
surface_set_shader(drawing_surface, noone); surface_set_shader(drawing_surface, noone);
draw_point_size(mouse_cur_x, mouse_cur_y, _siz, _brush); draw_point_size(mouse_cur_x, mouse_cur_y, true);
surface_reset_shader(); surface_reset_shader();
mouse_holding = true; mouse_holding = true;
if(mouse_pre_draw_x > -1 && mouse_pre_draw_y > -1 && key_mod_press(SHIFT)) { if(mouse_pre_draw_x > -1 && mouse_pre_draw_y > -1 && key_mod_press(SHIFT)) { ///////////////// LINE
surface_set_shader(drawing_surface, noone, true, BLEND.alpha); surface_set_shader(drawing_surface, noone, true, BLEND.alpha);
draw_line_size(mouse_pre_draw_x, mouse_pre_draw_y, mouse_cur_x, mouse_cur_y, _siz, _brush); brush_next_dist = 0;
draw_line_size(mouse_pre_draw_x, mouse_pre_draw_y, mouse_cur_x, mouse_cur_y, true);
surface_reset_shader(); surface_reset_shader();
mouse_holding = false; mouse_holding = false;
@ -784,10 +847,13 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
} }
if(mouse_holding && mouse_click(mb_left, active)) { if(mouse_holding && mouse_click(mb_left, active)) {
if(mouse_pre_draw_x != mouse_cur_x || mouse_pre_draw_y != mouse_cur_y) { var _move = mouse_pre_draw_x != mouse_cur_x || mouse_pre_draw_y != mouse_cur_y;
var _1stp = brush_dist_min == brush_dist_max && brush_dist_min == 1;
if(_move || !_1stp) {
surface_set_shader(drawing_surface, noone, false, BLEND.alpha); surface_set_shader(drawing_surface, noone, false, BLEND.alpha);
draw_point_size(mouse_cur_x, mouse_cur_y, _siz, _brush); if(_1stp) draw_point_size(mouse_cur_x, mouse_cur_y, true);
draw_line_size(mouse_pre_draw_x, mouse_pre_draw_y, mouse_cur_x, mouse_cur_y, _siz, _brush); draw_line_size(mouse_pre_draw_x, mouse_pre_draw_y, mouse_cur_x, mouse_cur_y, true);
surface_reset_shader(); surface_reset_shader();
} }
@ -797,6 +863,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(mouse_holding && mouse_release(mb_left)) { if(mouse_holding && mouse_release(mb_left)) {
mouse_holding = false; mouse_holding = false;
apply_draw_surface(); apply_draw_surface();
} }
@ -812,7 +879,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(mouse_release(mb_right)) if(mouse_release(mb_right))
brush_sizing = false; brush_sizing = false;
} else if(mouse_press(mb_right, active) && key_mod_press(SHIFT) && !is_surface(_brush)) { } else if(mouse_press(mb_right, active) && key_mod_press(SHIFT) && brush_surface == noone) {
brush_sizing = true; brush_sizing = true;
brush_sizing_s = _siz; brush_sizing_s = _siz;
brush_sizing_mx = _mx; brush_sizing_mx = _mx;
@ -844,9 +911,9 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
surface_set_shader(drawing_surface, noone); surface_set_shader(drawing_surface, noone);
if(isUsingTool("Rectangle")) if(isUsingTool("Rectangle"))
draw_rect_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, _siz, isUsingTool("Rectangle", 1), _brush); draw_rect_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, isUsingTool("Rectangle", 1));
else if(isUsingTool("Ellipse")) else if(isUsingTool("Ellipse"))
draw_ellp_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, _siz, isUsingTool("Ellipse", 1), _brush); draw_ellp_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, isUsingTool("Ellipse", 1));
surface_reset_shader(); surface_reset_shader();
if(mouse_release(mb_left)) { if(mouse_release(mb_left)) {
@ -862,9 +929,9 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(mouse_release(mb_right)) if(mouse_release(mb_right))
brush_sizing = false; brush_sizing = false;
} else if(mouse_press(mb_right, active) && key_mod_press(SHIFT) && !is_surface(_brush)) { } else if(mouse_press(mb_right, active) && key_mod_press(SHIFT) && brush_surface == noone) {
brush_sizing = true; brush_sizing = true;
brush_sizing_s = _siz; brush_sizing_s = brush_size;
brush_sizing_mx = _mx; brush_sizing_mx = _mx;
brush_sizing_my = _my; brush_sizing_my = _my;
@ -927,27 +994,27 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
if(isUsingTool("Eraser")) draw_set_color(c_white); if(isUsingTool("Eraser")) draw_set_color(c_white);
if(brush_sizing) { if(brush_sizing) {
draw_point_size(brush_sizing_dx, brush_sizing_dy, _siz, _brush); draw_point_size(brush_sizing_dx, brush_sizing_dy);
} else { } else {
if(mouse_pre_draw_x > -1 && mouse_pre_draw_y > -1 && key_mod_press(SHIFT)) if(mouse_pre_draw_x > -1 && mouse_pre_draw_y > -1 && key_mod_press(SHIFT))
draw_line_size(mouse_pre_draw_x, mouse_pre_draw_y, mouse_cur_x, mouse_cur_y, _siz, _brush); draw_line_size(mouse_pre_draw_x, mouse_pre_draw_y, mouse_cur_x, mouse_cur_y);
else else
draw_point_size(mouse_cur_x, mouse_cur_y, _siz, _brush); draw_point_size(mouse_cur_x, mouse_cur_y);
} }
} else if(isUsingTool("Rectangle")) { } else if(isUsingTool("Rectangle")) {
if(brush_sizing) if(brush_sizing)
draw_point_size(brush_sizing_dx, brush_sizing_dy, _siz, _brush); draw_point_size(brush_sizing_dx, brush_sizing_dy);
else if(mouse_holding) else if(mouse_holding)
draw_rect_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, _siz, isUsingTool("Rectangle", 1), _brush); draw_rect_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, isUsingTool("Rectangle", 1));
else else
draw_point_size(mouse_cur_x, mouse_cur_y, _siz, _brush); draw_point_size(mouse_cur_x, mouse_cur_y);
} else if(isUsingTool("Ellipse")) { } else if(isUsingTool("Ellipse")) {
if(brush_sizing) if(brush_sizing)
draw_point_size(brush_sizing_dx, brush_sizing_dy, _siz, _brush); draw_point_size(brush_sizing_dx, brush_sizing_dy);
else if(mouse_holding) else if(mouse_holding)
draw_ellp_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, _siz, isUsingTool("Ellipse", 1), _brush); draw_ellp_size(mouse_pre_x, mouse_pre_y, mouse_cur_x, mouse_cur_y, isUsingTool("Ellipse", 1));
else else
draw_point_size(mouse_cur_x, mouse_cur_y, _siz, _brush); draw_point_size(mouse_cur_x, mouse_cur_y);
} }
surface_reset_shader(); surface_reset_shader();
@ -995,11 +1062,14 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
static step = function() { #region static step = function() { #region
var fram = attributes.frames; var fram = attributes.frames;
var brush = getInputData(6);
var anim = getInputData(12); var anim = getInputData(12);
var anims = getInputData(12); var anims = getInputData(13);
inputs[| 12].setVisible(fram > 1); inputs[| 12].setVisible(fram > 1);
inputs[| 13].setVisible(fram > 1 && anim); inputs[| 13].setVisible(fram > 1 && anim);
inputs[| 15].setVisible(is_surface(brush));
inputs[| 16].setVisible(is_surface(brush));
update_on_frame = fram > 1 && anim; update_on_frame = fram > 1 && anim;
@ -1017,10 +1087,10 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor
var _bgDim = getInputData(14); var _bgDim = getInputData(14);
var cDep = attrDepth(); var cDep = attrDepth();
apply_surfaces();
if(_bgDim && is_surface(_bg)) _dim = [ surface_get_width_safe(_bg), surface_get_height_safe(_bg) ]; if(_bgDim && is_surface(_bg)) _dim = [ surface_get_width_safe(_bg), surface_get_height_safe(_bg) ];
attributes.dimension = _dim; attributes.dimension = _dim;
apply_surfaces();
var _frames = attributes.frames; var _frames = attributes.frames;