Fix selection sprite clipping on small scale.

This commit is contained in:
Tanasart 2023-11-10 07:50:16 +07:00
parent 19133ca97f
commit 6d3c70c726
6 changed files with 86 additions and 42 deletions

View file

@ -40,6 +40,17 @@ function draw_sprite_stretched_points(spr, ind, _x0, _y0, _x1, _y1, color = c_wh
__draw_sprite_stretched_ext(spr, ind, _xs, _ys, _w, _h, color, alpha); __draw_sprite_stretched_ext(spr, ind, _xs, _ys, _w, _h, color, alpha);
} }
function draw_sprite_stretched_points_clamp(spr, ind, _x0, _y0, _x1, _y1, color = c_white, alpha = 1, _min = 12) {
INLINE
var _xs = round(min(_x0, _x1));
var _ys = round(min(_y0, _y1));
var _w = max(_min, round(max(_x0, _x1) - _xs));
var _h = max(_min, round(max(_y0, _y1) - _ys));
__draw_sprite_stretched_ext(spr, ind, _xs, _ys, _w, _h, color, alpha);
}
function draw_sprite_bbox(spr, ind, _bbox) { function draw_sprite_bbox(spr, ind, _bbox) {
INLINE INLINE
if(_bbox == noone) return; if(_bbox == noone) return;

View file

@ -42,7 +42,7 @@ function Action(_type, _object, _data) constructor {
clear_action = noone; clear_action = noone;
static undo = function() { static undo = function() { #region
var _n; var _n;
switch(type) { switch(type) {
@ -110,9 +110,9 @@ function Action(_type, _object, _data) constructor {
data = obj(data); data = obj(data);
break; break;
} }
} } #endregion
static redo = function() { static redo = function() { #region
var _n; var _n;
switch(type) { switch(type) {
case ACTION_TYPE.var_modify : case ACTION_TYPE.var_modify :
@ -179,9 +179,9 @@ function Action(_type, _object, _data) constructor {
data = obj(data); data = obj(data);
break; break;
} }
} } #endregion
static toString = function() { static toString = function() { #region
var ss = ""; var ss = "";
switch(type) { switch(type) {
case ACTION_TYPE.var_modify : case ACTION_TYPE.var_modify :
@ -237,15 +237,15 @@ function Action(_type, _object, _data) constructor {
break; break;
} }
return ss; return ss;
} } #endregion
static destroy = function() { static destroy = function() { #region
if(clear_action == noone) return; if(clear_action == noone) return;
clear_action(data); clear_action(data);
} } #endregion
} }
function recordAction(_type, _object, _data = -1) { function recordAction(_type, _object, _data = -1) { #region
if(IS_UNDOING) return; if(IS_UNDOING) return;
if(LOADING) return; if(LOADING) return;
if(UNDO_HOLDING) return; if(UNDO_HOLDING) return;
@ -261,9 +261,9 @@ function recordAction(_type, _object, _data = -1) {
PANEL_MENU.undoUpdate(); PANEL_MENU.undoUpdate();
return act; return act;
} } #endregion
function UNDO() { function UNDO() { #region
if(ds_stack_empty(UNDO_STACK)) return; if(ds_stack_empty(UNDO_STACK)) return;
if(instance_exists(_p_dialog_undo_block)) return; if(instance_exists(_p_dialog_undo_block)) return;
@ -276,9 +276,9 @@ function UNDO() {
ds_stack_push(REDO_STACK, actions); ds_stack_push(REDO_STACK, actions);
PANEL_MENU.undoUpdate(); PANEL_MENU.undoUpdate();
} } #endregion
function REDO() { function REDO() { #region
if(ds_stack_empty(REDO_STACK)) return; if(ds_stack_empty(REDO_STACK)) return;
if(instance_exists(_p_dialog_undo_block)) return; if(instance_exists(_p_dialog_undo_block)) return;
@ -291,4 +291,4 @@ function REDO() {
ds_stack_push(UNDO_STACK, actions); ds_stack_push(UNDO_STACK, actions);
PANEL_MENU.undoUpdate(); PANEL_MENU.undoUpdate();
} } #endregion

View file

@ -430,21 +430,6 @@ function NodeObject(_name, _spr, _node, _create, tags = []) constructor { #regio
ds_list_add(d3d, "Points"); ds_list_add(d3d, "Points");
addNodeObject(d3d, "Point Affector", s_node_3d_point_affector, "Node_3D_Point_Affector", [1, Node_3D_Point_Affector]).setVersion(11570); addNodeObject(d3d, "Point Affector", s_node_3d_point_affector, "Node_3D_Point_Affector", [1, Node_3D_Point_Affector]).setVersion(11570);
//ds_list_add(d3d, "Legacy"); //////////////////////////////////////////////////////////////////////////////////////////////////////////////
//addNodeObject(d3d, "3D Plane", s_node_3d_plane, "__Node_3D_Plane", [1, __Node_3D_Plane],, "Put 2D image on a plane in 3D space.").isDeprecated();
//addNodeObject(d3d, "3D Cube", s_node_3d_cube, "__Node_3D_Cube", [1, __Node_3D_Cube]).isDeprecated();
//addNodeObject(d3d, "3D Cylinder", s_node_3d_cylinder, "__Node_3D_Cylinder", [1, __Node_3D_Cylinder]).isDeprecated();
//addNodeObject(d3d, "3D Sphere", s_node_3d_sphere, "__Node_3D_Sphere", [1, __Node_3D_Sphere]).setVersion(1090).isDeprecated();
//addNodeObject(d3d, "3D Cone", s_node_3d_cone, "__Node_3D_Cone", [1, __Node_3D_Cone]).setVersion(1090).isDeprecated();
//addNodeObject(d3d, "3D Extrude", s_node_3d_extrude, "__Node_3D_Extrude", [1, __Node_3D_Extrude],, "Extrude 2D image into 3D object.").isDeprecated();
//addNodeObject(d3d, "3D Transform", s_node_3d_transform, "__Node_3D_Transform", [1, __Node_3D_Transform]).setVersion(1080).isDeprecated();
//addNodeObject(d3d, "3D Combine", s_node_3d_obj_combine, "__Node_3D_Combine", [1, __Node_3D_Combine],, "Combine multiple 3D object to a single scene,").setVersion(1080).isDeprecated();
//addNodeObject(d3d, "3D Repeat", s_node_3d_array, "__Node_3D_Repeat", [1, __Node_3D_Repeat], ["3d array"], "Repeat 3D object multiple times.").setVersion(1080).isDeprecated();
//addNodeObject(d3d, "3D Displace", s_node_3d_displace, "__Node_3D_Displace", [1, __Node_3D_Displace]).setVersion(1143).isDeprecated();
//addNodeObject(d3d, "3D Export", s_node_3d_export, "__Node_3D_Export", [1, __Node_3D_Export]).setVersion(1143).isDeprecated();
#endregion #endregion
var generator = ds_list_create(); #region var generator = ds_list_create(); #region

View file

@ -1632,7 +1632,7 @@ function Panel_Animation() : PanelContent() constructor {
#endregion #endregion
if(keyframe_boxing) { #region if(keyframe_boxing) { #region
draw_sprite_stretched_points(THEME.ui_selection, 0, keyframe_box_sx, keyframe_box_sy, msx, msy, COLORS._main_accent); draw_sprite_stretched_points_clamp(THEME.ui_selection, 0, keyframe_box_sx, keyframe_box_sy, msx, msy, COLORS._main_accent);
if(mouse_release(mb_left)) if(mouse_release(mb_left))
keyframe_boxing = false; keyframe_boxing = false;

View file

@ -1056,7 +1056,7 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
#region draw selection frame #region draw selection frame
if(nodes_select_drag) { if(nodes_select_drag) {
if(point_distance(nodes_select_mx, nodes_select_my, mx, my) > 16) { if(point_distance(nodes_select_mx, nodes_select_my, mx, my) > 16) {
draw_sprite_stretched_points(THEME.ui_selection, 0, nodes_select_mx, nodes_select_my, mx, my, COLORS._main_accent); draw_sprite_stretched_points_clamp(THEME.ui_selection, 0, nodes_select_mx, nodes_select_my, mx, my, COLORS._main_accent);
for(var i = 0; i < ds_list_size(nodes_list); i++) { for(var i = 0; i < ds_list_size(nodes_list); i++) {
var _node = nodes_list[| i]; var _node = nodes_list[| i];

View file

@ -59,6 +59,11 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
syntax_highlight = true; syntax_highlight = true;
undo_current_text = "";
undo_delay = 0;
undo_stack = ds_stack_create();
redo_stack = ds_stack_create();
_cl = -1; _cl = -1;
static activate = function() { #region static activate = function() { #region
@ -76,6 +81,7 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
keyboard_lastkey = -1; keyboard_lastkey = -1;
cut_line(); cut_line();
undo_delay = 10;
} #endregion } #endregion
static deactivate = function() { #region static deactivate = function() { #region
@ -85,9 +91,7 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
UNDO_HOLDING = false; UNDO_HOLDING = false;
} #endregion } #endregion
static isCodeFormat = function() { static isCodeFormat = function() { INLINE return format == TEXT_AREA_FORMAT.codeLUA || format == TEXT_AREA_FORMAT.codeHLSL; }
return format == TEXT_AREA_FORMAT.codeLUA || format == TEXT_AREA_FORMAT.codeHLSL
}
static onModified = function() { #region static onModified = function() { #region
if(!isCodeFormat()) return; if(!isCodeFormat()) return;
@ -355,11 +359,36 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
static editText = function() { #region static editText = function() { #region
var _input_text_pre = _input_text; var _input_text_pre = _input_text;
var modified = false; var modified = false;
var undoed = true;
#region text editor #region text editor
if(key_mod_press(CTRL) && keyboard_check_pressed(ord("A"))) { if(key_mod_press(CTRL) && keyboard_check_pressed(ord("A"))) {
cursor_select = 0; cursor_select = 0;
cursor = string_length(_input_text); cursor = string_length(_input_text);
} else if(key_mod_press(CTRL) && keyboard_check_pressed(ord("Z"))) {
if(!ds_stack_empty(undo_stack)) {
ds_stack_push(redo_stack, _input_text);
_input_text = ds_stack_pop(undo_stack);
undo_current_text = _input_text;
cut_line();
move_cursor(0);
modified = true;
undoed = false;
undo_delay = 10;
}
} else if(key_mod_press(CTRL) && key_mod_press(SHIFT) && keyboard_check_pressed(ord("Z"))) {
if(!ds_stack_empty(redo_stack)) {
ds_stack_push(undo_stack, _input_text);
_input_text = ds_stack_pop(redo_stack);
undo_current_text = _input_text;
cut_line();
move_cursor(0);
modified = true;
undoed = false;
undo_delay = 10;
}
} else if(key_mod_press(CTRL) && (keyboard_check_pressed(ord("C")) || keyboard_check_pressed(ord("X")))) { } else if(key_mod_press(CTRL) && (keyboard_check_pressed(ord("C")) || keyboard_check_pressed(ord("X")))) {
if(cursor_select != -1) { if(cursor_select != -1) {
var minc = min(cursor, cursor_select); var minc = min(cursor, cursor_select);
@ -392,7 +421,8 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
cut_line(); cut_line();
cursor = minc + string_length(ch); cursor = minc + string_length(ch);
} }
modified = true; modified = true;
undo_delay = 10;
} else if(KEYBOARD_PRESSED == vk_backspace) { } else if(KEYBOARD_PRESSED == vk_backspace) {
if(cursor_select == -1) { if(cursor_select == -1) {
var str_before, str_after; var str_before, str_after;
@ -403,6 +433,7 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
var ch = string_char_at(_input_text, _c); var ch = string_char_at(_input_text, _c);
if(breakCharacter(ch)) break; if(breakCharacter(ch)) break;
_c--; _c--;
undo_delay++;
} }
str_before = string_copy(_input_text, 1, _c); str_before = string_copy(_input_text, 1, _c);
@ -411,9 +442,10 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
} else { } else {
str_before = string_copy(_input_text, 1, cursor - 1); str_before = string_copy(_input_text, 1, cursor - 1);
str_after = string_copy(_input_text, cursor + 1, string_length(_input_text) - cursor); str_after = string_copy(_input_text, cursor + 1, string_length(_input_text) - cursor);
undo_delay++;
} }
_input_text = str_before + str_after; _input_text = str_before + str_after;
cut_line(); cut_line();
} else { } else {
var minc = min(cursor, cursor_select); var minc = min(cursor, cursor_select);
@ -425,9 +457,10 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
cursor = minc + 1; cursor = minc + 1;
_input_text = str_before + str_after; _input_text = str_before + str_after;
cut_line(); cut_line();
undo_delay += maxc - minc;
} }
cursor_select = -1; cursor_select = -1;
move_cursor(-1); move_cursor(-1);
modified = true; modified = true;
} else if(KEYBOARD_PRESSED == vk_delete || (keyboard_check_pressed(ord("X")) && key_mod_press(CTRL) && cursor_select != -1)) { } else if(KEYBOARD_PRESSED == vk_delete || (keyboard_check_pressed(ord("X")) && key_mod_press(CTRL) && cursor_select != -1)) {
@ -437,6 +470,7 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
_input_text = str_before + str_after; _input_text = str_before + str_after;
cut_line(); cut_line();
undo_delay++;
} else { } else {
var minc = min(cursor, cursor_select); var minc = min(cursor, cursor_select);
var maxc = max(cursor, cursor_select); var maxc = max(cursor, cursor_select);
@ -445,10 +479,12 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
var str_after = string_copy(_input_text, maxc + 1, string_length(_input_text) - maxc); var str_after = string_copy(_input_text, maxc + 1, string_length(_input_text) - maxc);
cursor = minc; cursor = minc;
_input_text = str_before + str_after; _input_text = str_before + str_after;
cut_line(); cut_line();
undo_delay += maxc - minc;
} }
cursor_select = -1;
cursor_select = -1;
modified = true; modified = true;
} else if(KEYBOARD_STRING != "" && KEYBOARD_STRING != "\b" && KEYBOARD_STRING != "\r") { } else if(KEYBOARD_STRING != "" && KEYBOARD_STRING != "\b" && KEYBOARD_STRING != "\r") {
var ch = KEYBOARD_STRING; var ch = KEYBOARD_STRING;
@ -458,10 +494,10 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
var str_after = string_copy(_input_text, cursor + 1, string_length(_input_text) - cursor); var str_after = string_copy(_input_text, cursor + 1, string_length(_input_text) - cursor);
_input_text = str_before + ch + str_after; _input_text = str_before + ch + str_after;
//print($"{str_before} + {ch} + {str_after}");
cut_line(); cut_line();
move_cursor(string_length(ch)); move_cursor(string_length(ch));
undo_delay++;
} else { } else {
var minc = min(cursor, cursor_select); var minc = min(cursor, cursor_select);
var maxc = max(cursor, cursor_select); var maxc = max(cursor, cursor_select);
@ -472,9 +508,12 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
_input_text = str_before + ch + str_after; _input_text = str_before + ch + str_after;
cut_line(); cut_line();
cursor = minc + string_length(ch); cursor = minc + string_length(ch);
undo_delay += maxc - minc;
} }
cursor_select = -1; if(ch == " ") undo_delay = 10;
cursor_select = -1;
modified = true; modified = true;
} }
} }
@ -483,7 +522,16 @@ function textArea(_input, _onModify) : textInput(_input, _onModify) constructor
keyboard_lastkey = -1; keyboard_lastkey = -1;
#endregion #endregion
if(modified) onModified(); if(modified) {
if(undoed && undo_delay >= 10) {
ds_stack_push(undo_stack, undo_current_text);
ds_stack_clear(redo_stack);
undo_current_text = _input_text_pre;
undo_delay = 0;
}
onModified();
}
if(auto_update && keyboard_check_pressed(vk_anykey)) if(auto_update && keyboard_check_pressed(vk_anykey))
apply(); apply();