Pixel-Composer/objects/o_dialog_gradient/Create_0.gml

242 lines
6.3 KiB
Text
Raw Normal View History

2022-01-13 05:24:03 +01:00
/// @description init
event_inherited();
#region data
2023-01-17 08:11:55 +01:00
dialog_w = ui(1068);
2022-12-10 05:06:01 +01:00
dialog_h = ui(476);
2023-02-28 09:43:01 +01:00
title_height = 52;
2022-01-13 05:24:03 +01:00
2023-06-04 18:28:29 +02:00
name = __txtx("gradient_editor_title", "Gradient editor");
2024-05-25 10:07:11 +02:00
gradient = noone;
interactable = true;
drop_target = noone;
2022-01-13 05:24:03 +01:00
key_selecting = noone;
key_dragging = noone;
key_drag_sx = 0;
key_drag_mx = 0;
2023-01-25 06:49:00 +01:00
key_drag_dead = true;
2022-01-13 05:24:03 +01:00
destroy_on_click_out = true;
2024-03-27 11:51:14 +01:00
sl_position = slider(0, 100, 0.1, function(val) {
2023-02-28 09:43:01 +01:00
if(!interactable) return;
2022-11-14 03:16:15 +01:00
if(key_selecting == noone) return;
setKeyPosition(key_selecting, val / 100);
}, function() { removeKeyOverlap(key_selecting); })
2022-11-18 03:20:31 +01:00
setColor = function(color) {
2022-01-13 05:24:03 +01:00
if(key_selecting == noone) return;
key_selecting.value = int64(color);
2023-02-21 07:38:25 +01:00
onApply(gradient);
2022-01-13 05:24:03 +01:00
}
2023-02-14 13:44:46 +01:00
2023-03-02 07:59:14 +01:00
function setGradient(grad) {
gradient = grad;
2024-01-08 08:10:50 +01:00
if(array_empty(grad.keys)) return;
key_selecting = grad.keys[0];
selector.setColor(key_selecting.value, false);
2022-01-13 05:24:03 +01:00
}
2022-11-18 03:20:31 +01:00
selector = new colorSelector(setColor);
2022-12-22 03:09:55 +01:00
selector.dropper_close = false;
2022-11-18 03:20:31 +01:00
2023-03-02 07:59:14 +01:00
previous_gradient = noone;
2023-02-14 13:44:46 +01:00
2023-03-02 07:59:14 +01:00
function setDefault(grad) {
setGradient(grad);
previous_gradient = grad.clone();
2023-02-14 13:44:46 +01:00
}
b_cancel = button(function() {
onApply(previous_gradient);
instance_destroy();
2023-06-10 13:59:45 +02:00
}).setIcon(THEME.undo, 0, COLORS._main_icon)
2023-06-05 18:27:53 +02:00
.setTooltip(__txtx("dialog_revert_and_exit", "Revert and exit"));
2023-02-14 13:44:46 +01:00
2023-01-25 06:49:00 +01:00
b_apply = button(function() {
2023-02-14 13:44:46 +01:00
onApply(gradient);
2023-01-25 06:49:00 +01:00
instance_destroy();
}).setIcon(THEME.accept, 0, COLORS._main_icon_dark);
2022-11-14 03:16:15 +01:00
function setKeyPosition(key, position) {
key.time = position;
2023-03-02 07:59:14 +01:00
array_remove(gradient.keys, key);
gradient.add(key, false);
2023-02-21 07:38:25 +01:00
onApply(gradient);
2022-11-14 03:16:15 +01:00
}
function removeKeyOverlap(key) {
2023-03-02 07:59:14 +01:00
var keys = gradient.keys;
for(var i = 0; i < array_length(keys); i++) {
var _key = keys[i];
2022-11-14 03:16:15 +01:00
if(_key == key || _key.time != key.time)
continue;
2023-02-14 13:44:46 +01:00
2022-11-14 03:16:15 +01:00
_key.value = key.value;
2023-03-02 07:59:14 +01:00
array_remove(keys, key);
2022-11-14 03:16:15 +01:00
}
2023-02-21 07:38:25 +01:00
onApply(gradient);
2022-11-14 03:16:15 +01:00
}
2022-01-13 05:24:03 +01:00
#endregion
#region preset
2023-03-02 07:59:14 +01:00
hovering_name = "";
2022-11-03 11:44:49 +01:00
sp_preset_w = ui(240 - 32 - 16);
sp_presets = new scrollPane(sp_preset_w, dialog_h - ui(62), function(_y, _m) {
var ww = sp_preset_w - ui(40);
var hh = ui(32);
var yy = _y + ui(8);
var hg = ui(52);
2022-12-19 13:35:30 +01:00
var _hover = sHOVER && sp_presets.hover;
2022-11-18 03:20:31 +01:00
draw_clear_alpha(COLORS.panel_bg_clear, 0);
2022-01-13 05:24:03 +01:00
for(var i = 0; i < array_length(GRADIENTS); i++) {
var _gradient = GRADIENTS[i];
var isHover = point_in_rectangle(_m[0], _m[1], ui(4), yy, ui(4) + sp_preset_w - ui(16), yy + hg);
2022-01-13 05:24:03 +01:00
2023-11-13 15:42:14 +01:00
draw_sprite_stretched(THEME.ui_panel_bg, 3, ui(4), yy, sp_preset_w - ui(16), hg);
2022-12-19 13:35:30 +01:00
if(_hover && isHover)
2022-12-10 05:06:01 +01:00
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_preset_w - ui(16), hg, COLORS._main_accent, 1);
2022-11-18 03:20:31 +01:00
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
draw_text(ui(16), yy + ui(8), _gradient.name);
_gradient.gradient.draw(ui(16), yy + ui(28), ww, ui(16));
2022-01-13 05:24:03 +01:00
2023-03-02 07:59:14 +01:00
if(_hover && isHover) {
2023-11-22 10:21:50 +01:00
if(mouse_press(mb_left, interactable && sFOCUS)) {
gradient.keys = [];
2024-01-08 08:10:50 +01:00
for( var i = 0, n = array_length(_gradient.gradient.keys); i < n; i++ ) {
var k = _gradient.gradient.keys[i].clone();
gradient.keys[i] = k;
if(is_real(k.value)) k.value = cola(k.value);
}
onApply(gradient);
2023-11-22 10:21:50 +01:00
}
2023-03-02 07:59:14 +01:00
if(mouse_press(mb_right, interactable && sFOCUS)) {
hovering_name = _gradient.path;
2023-05-03 21:42:17 +02:00
menuCall("gradient_window_preset_menu",,, [
2023-06-05 18:27:53 +02:00
menuItem(__txtx("gradient_editor_delete", "Delete gradient"), function() {
file_delete(hovering_name);
__initGradient();
2023-03-02 07:59:14 +01:00
})
]);
2023-03-02 07:59:14 +01:00
}
2022-01-13 05:24:03 +01:00
}
2022-11-03 11:44:49 +01:00
yy += hg + ui(4);
hh += hg + ui(4);
2022-01-13 05:24:03 +01:00
}
return hh;
2023-12-29 14:30:54 +01:00
});
sp_presets.always_scroll = true;
2022-11-18 03:20:31 +01:00
#endregion
2023-01-17 08:11:55 +01:00
#region palette
palette_selecting = -1;
2023-01-17 08:11:55 +01:00
sp_palette_w = ui(240 - 32 - 16);
sp_palette_size = ui(24);
2023-07-21 12:40:20 +02:00
click_block = true;
2023-01-17 08:11:55 +01:00
sp_palettes = new scrollPane(sp_palette_w, dialog_h - ui(62), function(_y, _m) {
var ww = sp_palette_w - ui(40);
var hh = ui(32);
var _gs = sp_palette_size;
var yy = _y + ui(8);
var _height, pre_amo;
var _hover = sHOVER && sp_palettes.hover;
draw_clear_alpha(COLORS.panel_bg_clear, 0);
for(var i = -1; i < array_length(PALETTES); i++) {
var pal = i == -1? {
name: "project",
palette: PROJECT.attributes.palette,
path: ""
} : PALETTES[i];
pre_amo = array_length(pal.palette);
2023-01-17 08:11:55 +01:00
var col = floor(ww / _gs);
var row = ceil(pre_amo / col);
if(palette_selecting == i)
_height = ui(28) + row * _gs + ui(12);
else
_height = ui(56);
var isHover = _hover && point_in_rectangle(_m[0], _m[1], ui(4), yy, ui(4) + sp_palette_w - ui(16), yy + _height);
2023-11-13 15:42:14 +01:00
draw_sprite_stretched(THEME.ui_panel_bg, 3, ui(4), yy, sp_palette_w - ui(16), _height);
2023-01-17 08:11:55 +01:00
if(isHover)
draw_sprite_stretched_ext(THEME.node_active, 1, ui(4), yy, sp_palette_w - ui(16), _height, COLORS._main_accent, 1);
var x0 = ui(16) + (i == -1) * ui(8 + 6);
2023-07-25 20:12:40 +02:00
var cc = i == palette_selecting? COLORS._main_accent : COLORS._main_text_sub;
draw_set_text(f_p2, fa_left, fa_top, cc);
draw_text(x0, yy + ui(8), pal.name);
if(i == -1) {
2023-07-25 20:12:40 +02:00
draw_set_color(cc);
draw_circle_prec(ui(16) + ui(4), yy + ui(16), ui(4), false);
}
2023-01-17 08:11:55 +01:00
if(palette_selecting == i)
2024-05-29 04:41:08 +02:00
var _palRes = drawPaletteGrid(pal.palette, ui(16), yy + ui(28), ww, _gs);
2023-01-17 08:11:55 +01:00
else
drawPalette(pal.palette, ui(16), yy + ui(28), ww, ui(20));
2023-01-17 08:11:55 +01:00
2023-02-28 09:43:01 +01:00
if(!click_block && mouse_click(mb_left, interactable && sFOCUS)) {
2024-05-29 04:41:08 +02:00
if(palette_selecting == i && _hover && _palRes.hoverIndex > noone) {
var c = _palRes.hoverColor;
if(is_real(c)) c = cola(c);
selector.setColor(c);
selector.setHSV();
2023-01-17 08:11:55 +01:00
} else if(isHover) {
palette_selecting = i;
click_block = true;
}
}
if(isHover) {
if(i >= 0 && mouse_press(mb_right, interactable && sFOCUS)) {
hovering = pal;
menuCall("palette_window_preset_menu",,, [
menuItem(__txtx("palette_editor_set_default", "Set as default"), function() {
2024-05-16 15:28:45 +02:00
PROJECT.setPalette(array_clone(hovering.palette));
}),
menuItem(__txtx("palette_editor_delete", "Delete palette"), function() {
file_delete(hovering.path);
__initPalette();
}),
]);
}
}
2023-01-17 08:11:55 +01:00
yy += _height + ui(4);
hh += _height + ui(4);
}
if(mouse_release(mb_left))
click_block = false;
return hh;
2023-12-29 14:30:54 +01:00
});
sp_palettes.always_scroll = true;
2023-01-17 08:11:55 +01:00
#endregion
2022-11-18 03:20:31 +01:00
#region action
function checkMouse() {}
2022-01-13 05:24:03 +01:00
#endregion