2023-03-28 06:58:28 +02:00
|
|
|
function Panel_Gradient() : PanelContent() constructor {
|
2023-06-04 18:28:29 +02:00
|
|
|
title = __txt("Gradients");
|
2023-03-28 06:58:28 +02:00
|
|
|
showHeader = false;
|
|
|
|
title_height = 64;
|
2024-07-27 05:46:16 +02:00
|
|
|
padding = 20;
|
2023-03-28 06:58:28 +02:00
|
|
|
|
|
|
|
w = ui(320);
|
|
|
|
h = ui(480);
|
|
|
|
|
|
|
|
function onResize() {
|
|
|
|
PANEL_PADDING
|
|
|
|
|
|
|
|
sp_gradient.resize(w - ui(padding + padding), h - ui(title_height + padding));
|
|
|
|
}
|
|
|
|
|
|
|
|
sp_gradient = new scrollPane(w - ui(padding + padding), h - ui(title_height + padding), function(_y, _m) {
|
|
|
|
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
|
|
|
var ww = sp_gradient.surface_w;
|
|
|
|
var hh = 0;
|
|
|
|
|
2023-10-16 12:54:20 +02:00
|
|
|
var amo = array_length(GRADIENTS);
|
2023-03-28 06:58:28 +02:00
|
|
|
var col = floor(ww / ui(160));
|
|
|
|
var row = ceil(amo / col);
|
|
|
|
|
|
|
|
var gw = (ww + ui(8)) / col;
|
|
|
|
var gh = ui(16);
|
|
|
|
|
|
|
|
var hg = ui(24 + 8) + gh;
|
|
|
|
var yy = _y;
|
|
|
|
|
|
|
|
for(var i = 0; i < row; i++) {
|
|
|
|
for(var j = 0; j < col; j++) {
|
|
|
|
var ind = i * col + j;
|
|
|
|
if(ind >= amo) break;
|
|
|
|
|
|
|
|
var xx = j * gw;
|
2023-10-16 12:54:20 +02:00
|
|
|
var preset = GRADIENTS[ind];
|
2023-03-28 06:58:28 +02:00
|
|
|
var isHover = pHOVER && point_in_rectangle(_m[0], _m[1], xx, max(0, yy), xx + gw - ui(8), min(sp_gradient.h, yy + hg));
|
|
|
|
|
2023-11-13 05:38:37 +01:00
|
|
|
draw_sprite_stretched(THEME.ui_panel_bg, 3, xx, yy, gw - ui(8), hg);
|
2024-07-28 13:55:57 +02:00
|
|
|
if(isHover) {
|
|
|
|
sp_gradient.hover_content = true;
|
2023-03-28 06:58:28 +02:00
|
|
|
draw_sprite_stretched_ext(THEME.node_active, 1, xx, yy, gw - ui(8), hg, COLORS._main_accent, 1);
|
2024-07-28 13:55:57 +02:00
|
|
|
}
|
2023-03-28 06:58:28 +02:00
|
|
|
|
|
|
|
draw_set_text(f_p2, fa_left, fa_top, COLORS._main_text_sub);
|
|
|
|
draw_text(xx + ui(10), yy + ui(2), preset.name);
|
|
|
|
preset.gradient.draw(xx + ui(10), yy + ui(24), gw - ui(28), gh);
|
|
|
|
|
|
|
|
if(isHover && mouse_press(mb_left, pFOCUS)) {
|
|
|
|
DRAGGING = {
|
|
|
|
type: "Gradient",
|
|
|
|
data: preset.gradient
|
|
|
|
}
|
2023-10-04 09:49:31 +02:00
|
|
|
MESSAGE = DRAGGING;
|
2023-03-28 06:58:28 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
yy += hg + ui(8);
|
|
|
|
hh += hg + ui(8);
|
|
|
|
}
|
|
|
|
|
|
|
|
return hh;
|
|
|
|
});
|
|
|
|
|
|
|
|
function drawContent(panel) {
|
2023-06-10 13:59:45 +02:00
|
|
|
draw_clear_alpha(COLORS.panel_bg_clear, 0);
|
2023-03-28 06:58:28 +02:00
|
|
|
PANEL_PADDING
|
|
|
|
PANEL_TITLE
|
|
|
|
|
|
|
|
var px = ui(padding);
|
|
|
|
var py = ui(title_height);
|
|
|
|
var pw = w - ui(padding + padding);
|
|
|
|
var ph = h - ui(title_height + padding);
|
|
|
|
|
2023-11-13 05:38:37 +01:00
|
|
|
draw_sprite_stretched(THEME.ui_panel_bg, 1, px - ui(8), py - ui(8), pw + ui(16), ph + ui(16));
|
2023-03-28 06:58:28 +02:00
|
|
|
|
2023-06-21 20:36:53 +02:00
|
|
|
sp_gradient.setFocusHover(pFOCUS, pHOVER);
|
2023-03-28 06:58:28 +02:00
|
|
|
sp_gradient.draw(px, py, mx - px, my - py);
|
|
|
|
|
|
|
|
var bx = w - ui(32 + 16);
|
|
|
|
var by = title_height / 2 - ui(16 + !in_dialog * 2);
|
|
|
|
|
2024-03-31 05:36:11 +02:00
|
|
|
if(buttonInstant(THEME.button_hide, bx, by, ui(32), ui(32), [mx, my], pFOCUS, pHOVER, __txt("Refresh"), THEME.refresh_icon, 1, COLORS._main_icon) == 2)
|
2023-10-16 12:54:20 +02:00
|
|
|
__initGradient();
|
2023-03-28 06:58:28 +02:00
|
|
|
}
|
|
|
|
}
|