From 088f13293d3b390813f7d13b93764ceb09109353 Mon Sep 17 00:00:00 2001 From: Tanasart Date: Tue, 10 Sep 2024 11:36:30 +0700 Subject: [PATCH] Fix default color has no alpha value (which cause brush to not show up in canvas node) --- objects/o_main/Other_2.gml | 2 + .../canvas_draw_functions.gml | 103 +++++++++--------- .../canvas_tool_brush/canvas_tool_brush.gml | 1 + scripts/globals/globals.gml | 4 +- scripts/node_canvas/node_canvas.gml | 2 +- 5 files changed, 58 insertions(+), 54 deletions(-) diff --git a/objects/o_main/Other_2.gml b/objects/o_main/Other_2.gml index b76436c85..68c174132 100644 --- a/objects/o_main/Other_2.gml +++ b/objects/o_main/Other_2.gml @@ -48,8 +48,10 @@ APP_LOCATION = program_directory; if(OS == os_macosx) APP_LOCATION = string_replace(APP_LOCATION, "/Contents/MacOS/", "/Contents/Resources/"); + if(string_pos("GameMakerStudio2/Cache/runtimes", APP_LOCATION)) APP_LOCATION = working_directory; + print($"===================== WORKING DIRECTORIES =====================\n\t{working_directory}\n\t{DIRECTORY}"); #endregion diff --git a/scripts/canvas_draw_functions/canvas_draw_functions.gml b/scripts/canvas_draw_functions/canvas_draw_functions.gml index f3f7d78b6..520ca8b61 100644 --- a/scripts/canvas_draw_functions/canvas_draw_functions.gml +++ b/scripts/canvas_draw_functions/canvas_draw_functions.gml @@ -1,6 +1,16 @@ -function canvas_draw_point_brush(brush, _x, _y, _draw = false) { #region - if(brush.brush_surface == noone) { +function canvas_draw_point_brush(brush, _x, _y, _draw = false) { + + if(is_surface(brush.brush_surface)) { + var _sw = surface_get_width_safe(brush.brush_surface); + var _sh = surface_get_height_safe(brush.brush_surface); + var _r = brush.brush_direction + angle_random_eval(brush.brush_rand_dir, brush.brush_seed); + var _p = point_rotate(-_sw / 2, -_sh / 2, 0, 0, _r); + draw_surface_ext_safe(brush.brush_surface, round(_x + _p[0]), round(_y + _p[1]), 1, 1, _r, draw_get_color(), draw_get_alpha()); + + if(_draw) brush.brush_seed = irandom_range(100000, 999999); + + } else { if(brush.brush_size <= 1) draw_point(_x, _y); @@ -11,18 +21,8 @@ function canvas_draw_point_brush(brush, _x, _y, _draw = false) { #region } else draw_circle_prec(_x, _y, brush.brush_size / 2, 0); - - } else { - var _sw = surface_get_width_safe(brush.brush_surface); - var _sh = surface_get_height_safe(brush.brush_surface); - var _r = brush.brush_direction + angle_random_eval(brush.brush_rand_dir, brush.brush_seed); - var _p = point_rotate(-_sw / 2, -_sh / 2, 0, 0, _r); - - draw_surface_ext_safe(brush.brush_surface, round(_x + _p[0]), round(_y + _p[1]), 1, 1, _r, draw_get_color(), draw_get_alpha()); - - if(_draw) brush.brush_seed = irandom_range(100000, 999999); } -} #endregion +} function canvas_draw_line(_x0, _y0, _x1, _y1, _th = 1) { if(_th < global.FIX_POINTS_AMOUNT) { @@ -46,36 +46,10 @@ function canvas_draw_line(_x0, _y0, _x1, _y1, _th = 1) { draw_line_width(_x0, _y0, _x1, _y1, _th); } -function canvas_draw_line_brush(brush, _x0, _y0, _x1, _y1, _draw = false, _cap = false) { #region +function canvas_draw_line_brush(brush, _x0, _y0, _x1, _y1, _draw = false, _cap = false) { + + if(is_surface(brush.brush_surface)) { - if(brush.brush_surface == noone) { - - if(brush.brush_size < global.FIX_POINTS_AMOUNT) { - if(_x1 > _x0) _x0--; - if(_x1 < _x0) _x1--; - - if(_y1 > _y0) _y0--; - if(_y1 < _y0) _y1--; - } - - if(brush.brush_size == 1) { - draw_line(_x0, _y0, _x1, _y1); - - } else if(brush.brush_size < global.FIX_POINTS_AMOUNT) { - - var fx = global.FIX_POINTS[brush.brush_size]; - for( var i = 0, n = array_length(fx); i < n; i++ ) - draw_line(_x0 + fx[i][0], _y0 + fx[i][1], _x1 + fx[i][0], _y1 + fx[i][1]); - - } else { - draw_line_width(_x0, _y0, _x1, _y1, brush.brush_size); - if(_cap) { - canvas_draw_point_brush(brush, _x0, _y0, true); - canvas_draw_point_brush(brush, _x1, _y1, true); - } - } - - } else { var diss = point_distance(_x0, _y0, _x1, _y1); var dirr = point_direction(_x0, _y0, _x1, _y1); var st_x = lengthdir_x(1, dirr); @@ -102,10 +76,37 @@ function canvas_draw_line_brush(brush, _x0, _y0, _x1, _y1, _draw = false, _cap = if(brush.brush_dist_min == brush.brush_dist_max && brush.brush_dist_min == 1) canvas_draw_point_brush(brush, _x1, _y1, _draw); + + } else { + + if(brush.brush_size < global.FIX_POINTS_AMOUNT) { + if(_x1 > _x0) _x0--; + if(_x1 < _x0) _x1--; + + if(_y1 > _y0) _y0--; + if(_y1 < _y0) _y1--; + } + + if(brush.brush_size == 1) { + draw_line(_x0, _y0, _x1, _y1); + + } else if(brush.brush_size < global.FIX_POINTS_AMOUNT) { + + var fx = global.FIX_POINTS[brush.brush_size]; + for( var i = 0, n = array_length(fx); i < n; i++ ) + draw_line(_x0 + fx[i][0], _y0 + fx[i][1], _x1 + fx[i][0], _y1 + fx[i][1]); + + } else { + draw_line_width(_x0, _y0, _x1, _y1, brush.brush_size); + if(_cap) { + canvas_draw_point_brush(brush, _x0, _y0, true); + canvas_draw_point_brush(brush, _x1, _y1, true); + } + } } -} #endregion +} -function canvas_draw_rect_brush(brush, _x0, _y0, _x1, _y1, _fill) { #region +function canvas_draw_rect_brush(brush, _x0, _y0, _x1, _y1, _fill) { if(_x0 == _x1 && _y0 == _y1) { canvas_draw_point_brush(brush, _x0, _y0); return; @@ -130,7 +131,7 @@ function canvas_draw_rect_brush(brush, _x0, _y0, _x1, _y1, _fill) { #region if(_fill) draw_rectangle(_min_x, _min_y, _max_x, _may_y, 0); - if(brush.brush_size == 1 && brush.brush_surface == noone) + if(brush.brush_size == 1 && !is_surface(brush.brush_surface)) draw_rectangle(_min_x + 1, _min_y + 1, _max_x - 1, _may_y - 1, 1); else { canvas_draw_line_brush(brush, _min_x, _min_y, _max_x, _min_y); @@ -138,9 +139,9 @@ function canvas_draw_rect_brush(brush, _x0, _y0, _x1, _y1, _fill) { #region canvas_draw_line_brush(brush, _max_x, _may_y, _max_x, _min_y); canvas_draw_line_brush(brush, _max_x, _may_y, _min_x, _may_y); } -} #endregion +} -function canvas_draw_ellp_brush(brush, _x0, _y0, _x1, _y1, _fill) { #region +function canvas_draw_ellp_brush(brush, _x0, _y0, _x1, _y1, _fill) { if(_x0 == _x1 && _y0 == _y1) { canvas_draw_point_brush(brush, _x0, _y0); return; @@ -164,7 +165,7 @@ function canvas_draw_ellp_brush(brush, _x0, _y0, _x1, _y1, _fill) { #region var _min_y = min(_y0, _y1) - 0.5; var _max_y = max(_y0, _y1) - 0.5; - if(brush.brush_surface == noone) { + if(!is_surface(brush.brush_surface)) { if(_fill) draw_ellipse(_min_x, _min_y, _max_x, _max_y, 0); if(brush.brush_size == 1) { @@ -201,9 +202,9 @@ function canvas_draw_ellp_brush(brush, _x0, _y0, _x1, _y1, _fill) { #region ox = nx; oy = ny; } -} #endregion +} -function canvas_draw_curve_brush(brush, x0, y0, cx0, cy0, cx1, cy1, x1, y1, prec = 32) { #region +function canvas_draw_curve_brush(brush, x0, y0, cx0, cy0, cx1, cy1, x1, y1, prec = 32) { var ox, oy, nx, ny; var _st = 1 / prec; @@ -227,6 +228,6 @@ function canvas_draw_curve_brush(brush, x0, y0, cx0, cy0, cx1, cy1, x1, y1, prec ox = nx; oy = ny; } -} #endregion +} function canvas_draw_triangle(x1, y1, x2, y2, x3, y3, outline = false) { INLINE draw_triangle(round(x1), round(y1), round(x2), round(y2), round(x3), round(y3), outline); } \ No newline at end of file diff --git a/scripts/canvas_tool_brush/canvas_tool_brush.gml b/scripts/canvas_tool_brush/canvas_tool_brush.gml index e6312718c..b591d5810 100644 --- a/scripts/canvas_tool_brush/canvas_tool_brush.gml +++ b/scripts/canvas_tool_brush/canvas_tool_brush.gml @@ -99,6 +99,7 @@ function canvas_tool_brush(brush, eraser = false) : canvas_tool() constructor { if(isEraser) draw_set_color(c_white); mouse_line_drawing = false; + //print($"Drawing {mouse_cur_x}, {mouse_cur_y}, [{draw_get_color()}, {draw_get_alpha()}] {surface_get_target()}"); if(mouse_pre_draw_x != undefined && mouse_pre_draw_y != undefined && key_mod_press(SHIFT)) { diff --git a/scripts/globals/globals.gml b/scripts/globals/globals.gml index 62cc25040..e70561a6f 100644 --- a/scripts/globals/globals.gml +++ b/scripts/globals/globals.gml @@ -41,7 +41,7 @@ LATEST_VERSION = 1_17_00; VERSION = 1_17_12_0; SAVE_VERSION = 1_17_10_0; - VERSION_STRING = MAC? "1.18.002m" : "1.18.rc1.002"; + VERSION_STRING = MAC? "1.18.002m" : "1.18.rc1.003"; BUILD_NUMBER = 1_17_12_0; HOTKEYS = ds_map_create(); @@ -52,7 +52,7 @@ global.KEYS = { download_links: "" }; globalvar CURRENT_COLOR; - CURRENT_COLOR = c_white; + CURRENT_COLOR = cola(c_white); #endregion diff --git a/scripts/node_canvas/node_canvas.gml b/scripts/node_canvas/node_canvas.gml index 48d496971..429ab5b85 100644 --- a/scripts/node_canvas/node_canvas.gml +++ b/scripts/node_canvas/node_canvas.gml @@ -891,7 +891,7 @@ function Node_Canvas(_x, _y, _group = noone) : Node(_x, _y, _group) constructor draw_set_alpha(1); surface_reset_shader(); - + draw_surface_ext_safe(preview_draw_surface, _x, _y, _s, _s, 0, isUsingTool("Eraser")? c_red : c_white, isUsingTool("Eraser")? .2 : _alp); surface_set_target(preview_draw_mask);