This commit is contained in:
Tanasart 2024-06-19 16:32:41 +07:00
parent 10e4041a32
commit 168286b449
6 changed files with 105 additions and 52 deletions

Binary file not shown.

View file

@ -28,7 +28,8 @@ if(winMan_isMinimized()) exit;
break;
case VALUE_TYPE.curve :
draw_tooltip_text($"[{__txt("Curve Object")}]");
// draw_tooltip_text($"[{__txt("Curve Object")}]");
draw_tooltip_curve(content);
break;
case VALUE_TYPE.color :

View file

@ -270,3 +270,43 @@ function draw_tooltip_buffer(buff) { #region
draw_text(mx + pd, my + th + pd, $"...({buffer_get_size(buff)} bytes)");
}
} #endregion
function draw_tooltip_curve(curve) { #region
var ww = ui(160);
var hh = ui(160);
var pd = ui(8);
var mx = min(mouse_mx + ui(16), WIN_W - (ww + pd * 2));
var my = min(mouse_my + ui(16), WIN_H - (hh + pd * 2));
draw_sprite_stretched(THEME.textbox, 3, mx, my, ww + pd * 2, hh + pd * 2);
draw_sprite_stretched(THEME.textbox, 0, mx, my, ww + pd * 2, hh + pd * 2);
var x0 = mx + pd;
var x1 = x0 + ww;
var y0 = my + pd;
var y1 = y0 + hh;
var st = 0.1;
draw_set_color(COLORS.widget_curve_line);
draw_set_alpha(0.15);
for( var i = st; i < 1; i += st ) {
var _y0 = y0 + hh * (1 - i);
draw_line(x0, _y0, x1, _y0);
var _x0 = x0 + ww * i;
draw_line(_x0, y0, _x0, y1);
}
draw_set_alpha(1);
draw_set_color(COLORS._main_accent);
draw_curve(x0, y0, ww, hh, curve);
draw_set_color(COLORS.widget_curve_outline);
draw_rectangle(x0, y0, x1, y1, true);
} #endregion

View file

@ -38,7 +38,7 @@
LATEST_VERSION = 11700;
VERSION = 11740;
SAVE_VERSION = 11700;
VERSION_STRING = "1.17.4.006";
VERSION_STRING = "1.17.4";
BUILD_NUMBER = 11740;
globalvar HOTKEYS, HOTKEY_CONTEXT;

View file

@ -248,11 +248,14 @@ function Panel_Animation() : PanelContent() constructor {
#region ++++ context menu ++++
keyframe_menu = [ #region
menuItem(__txtx("panel_animation_lock_y", "Lock/Unlock Y easing"), function() {
for( var i = 0, n = array_length(keyframe_selecting); i < n; i++ ) {
var k = keyframe_selecting[i];
k.ease_y_lock = !k.ease_y_lock;
} }),
for( var i = 0, n = array_length(keyframe_selecting); i < n; i++ ) {
var k = keyframe_selecting[i];
k.ease_y_lock = !k.ease_y_lock;
}
}),
menuItemGroup(__txtx("panel_animation_ease_in", "Ease in"), [
[ [THEME.timeline_ease, 0], function() {
for( var i = 0, n = array_length(keyframe_selecting); i < n; i++ ) {
@ -673,7 +676,7 @@ function Panel_Animation() : PanelContent() constructor {
var t = (_keyframe.time + 1) * timeline_scale + timeline_shift;
_keyframe.dopesheet_x = t;
draw_sprite_ui_uniform(THEME.timeline_keyframe, _keyframe.getDrawIndex(), t, key_y, 1, COLORS.panel_animation_keyframe_hide);
draw_sprite_ui_uniform(THEME.timeline_keyframe, 0, t, key_y, 1, COLORS.panel_animation_keyframe_hide);
}
}
}
@ -1093,15 +1096,46 @@ function Panel_Animation() : PanelContent() constructor {
#endregion
} #endregion
function editKeyframe(keyframe, _x = mouse_mx + ui(8), _y = mouse_my + ui(8)) {
var _wid = keyframe.anim.prop.editWidget;
__keyframe_editing = keyframe;
switch(animator.prop.type) {
case VALUE_TYPE.color :
switch(animator.prop.display_type) {
case VALUE_DISPLAY.palette :
var dialog = dialogCall(o_dialog_palette, WIN_W / 2, WIN_H / 2);
dialog.setDefault(keyframe.value);
dialog.onApply = function(val) { __keyframe_editing.value = val; };
dialog.drop_target = _wid;
break;
default :
var dialog = dialogCall(o_dialog_color_selector, WIN_W / 2, WIN_H / 2);
dialog.setDefault(keyframe.value);
dialog.selector.onApply = function(val) { __keyframe_editing.value = val; };
dialog.onApply = function(val) { __keyframe_editing.value = val; };
dialog.drop_target = _wid;
}
break;
case VALUE_TYPE.gradient :
var dialog = dialogCall(o_dialog_gradient, WIN_W / 2, WIN_H / 2);
dialog.setDefault(keyframe.value.clone());
dialog.onApply = function(val) { __keyframe_editing.value = val; };
dialog.drop_target = _wid;
break;
default :
dialogCall(o_dialog_value_editor, _x, _y).setKey(keyframe);
}
}
function _drawDopesheetAnimatorKeysBG(animator, msx, msy) { #region
var prop_dope_y = animator.y;
var key_hover = noone;
var key_list = animator.values;
//if(animator.prop.name == "Active") { #region active prop
//} #endregion
if((animator.prop.on_end == KEYFRAME_END.loop || animator.prop.on_end == KEYFRAME_END.ping) && ds_list_size(key_list) > 1) {
var keyframe_s = animator.prop.loop_range == -1? key_list[| 0].time : key_list[| ds_list_size(key_list) - 1 - animator.prop.loop_range].time;
var keyframe_e = key_list[| ds_list_size(key_list) - 1].time;
@ -1155,7 +1189,6 @@ function Panel_Animation() : PanelContent() constructor {
return key_hover;
} #endregion
//// DRAW KEYFRAMES
__keyframe_editing = noone;
function _drawDopesheetAnimatorKeys(_cont, animator, msx, msy) { #region
@ -1192,7 +1225,8 @@ function Panel_Animation() : PanelContent() constructor {
if(pHOVER && point_in_circle(msx, msy, t, prop_y, ui(8))) {
cc = COLORS.panel_animation_keyframe_selected;
key_hover = keyframe;
TOOLTIP = [ keyframe.value, animator.prop.type ];
if(!instance_exists(o_dialog_menubox))
TOOLTIP = [ keyframe.value, animator.prop.type ];
if(pFOCUS && !key_mod_press(SHIFT)) {
if(DOUBLE_CLICK) {
@ -1204,39 +1238,7 @@ function Panel_Animation() : PanelContent() constructor {
} else if(mouse_press(mb_left)) {
if(key_mod_press(CTRL)) {
var _wid = animator.prop.editWidget;
__keyframe_editing = keyframe;
switch(animator.prop.type) {
case VALUE_TYPE.color :
switch(animator.prop.display_type) {
case VALUE_DISPLAY.palette :
var dialog = dialogCall(o_dialog_palette, WIN_W / 2, WIN_H / 2);
dialog.setDefault(keyframe.value);
dialog.onApply = function(val) { __keyframe_editing.value = val; };
dialog.drop_target = _wid;
break;
default :
var dialog = dialogCall(o_dialog_color_selector, WIN_W / 2, WIN_H / 2);
dialog.setDefault(keyframe.value);
dialog.selector.onApply = function(val) { __keyframe_editing.value = val; };
dialog.onApply = function(val) { __keyframe_editing.value = val; };
dialog.drop_target = _wid;
}
break;
case VALUE_TYPE.gradient :
var dialog = dialogCall(o_dialog_gradient, WIN_W / 2, WIN_H / 2);
dialog.setDefault(keyframe.value.clone());
dialog.onApply = function(val) { __keyframe_editing.value = val; };
dialog.drop_target = _wid;
break;
default :
dialogCall(o_dialog_value_editor, mouse_mx + ui(8), mouse_my + ui(8)).setKey(keyframe);
}
editKeyFrame(keyframe);
} else {
keyframe_dragging = keyframe;
@ -1252,8 +1254,8 @@ function Panel_Animation() : PanelContent() constructor {
cc = key_hover == keyframe? COLORS.panel_animation_keyframe_selected : COLORS._main_accent;
var ind = keyframe.getDrawIndex();
draw_sprite_ui_uniform(THEME.timeline_keyframe, ind, t, prop_y, 1, cc);
if(array_exists(keyframe_selecting, keyframe))
draw_sprite_ui_uniform(THEME.timeline_keyframe_selecting, ind, t, prop_y, 1, COLORS._main_accent);
@ -1279,12 +1281,15 @@ function Panel_Animation() : PanelContent() constructor {
var tx = tool_width;
var ty = animator.y - 1;
var hov = item_dragging == noone && pHOVER && point_in_rectangle(msx, msy, 0, ty - ui(8), w, ty + ui(8));
var hov = item_dragging == noone && pHOVER && point_in_rectangle(msx, msy, 0, ty - ui(8), w - ui(64), ty + ui(8));
//// DRAW NAME
var cc = prop.sep_axis? COLORS.axis[animator.index] : COLORS._main_text_inner;
var cc = prop.sep_axis? COLORS.axis[animator.index] : COLORS._main_text_sub;
if(hov) cc = COLORS._main_text_accent;
draw_set_color(CDEF.main_mdblack);
draw_rectangle(ui(32), ty - ui(8), tool_width, ty + ui(8), false);
draw_set_color(cc);
var _title_x = ui(32);
@ -2110,13 +2115,18 @@ function Panel_Animation() : PanelContent() constructor {
if(mouse_press(mb_right, pFOCUS)) { #region context menu
if(point_in_rectangle(mx, my, bar_x, ui(8), bar_x + dope_sheet_w, ui(8) + dope_sheet_h)) {
if(array_empty(keyframe_selecting)) menuCall("animation_keyframe_empty_menu",,, keyframe_menu_empty);
else menuCall("animation_keyframe_menu",,, keyframe_menu,, keyframe_selecting);
} else if(point_in_rectangle(mx, my, ui(8), ui(8), ui(8) + tool_width, ui(8) + dope_sheet_h)) {
if(context_selecting_item == noone)
menuCall("animation_name_empty_menu",,, name_menu_empty);
else if(is_instanceof(context_selecting_item.item, timelineItemNode))
menuCall("animation_name_empty_menu",,, name_menu_item);
else if(is_instanceof(context_selecting_item.item, timelineItemGroup))
menuCall("animation_name_empty_menu",,, name_menu_group);
}

View file

@ -1011,7 +1011,9 @@ function Panel_Inspector() : PanelContent() constructor {
if(PROJECT.meta.steam == FILE_STEAM_TYPE.steamOpen) {
var _tw = string_width(txt) / 2;
draw_sprite_ui(THEME.steam, 0, w / 2 - _tw - ui(16), ui(32),,,, COLORS._main_icon);
BLEND_ADD
draw_sprite_ui(THEME.steam, 0, w / 2 - _tw - ui(16), ui(29), 1, 1, 0, COLORS._main_icon);
BLEND_NORMAL
}
var bx = w - ui(44);