Pixel-Composer/scripts/panel_array_sequence/panel_array_sequence.gml

200 lines
6.1 KiB
Text
Raw Normal View History

2023-06-10 13:59:45 +02:00
function Panel_Array_Sequence(node) : PanelContent() constructor {
self.node = node;
2023-06-13 14:42:06 +02:00
title = __txt("Frame Sequence Editor");
2023-06-10 13:59:45 +02:00
w = ui(640);
h = ui(168);
padding = ui(16);
content_h = ui(64);
content_surface = noone;
content_x = 0;
content_x_to = 0;
content_x_max = 0;
content_drag = noone;
sequence_surface = noone;
sequence_x = 0;
sequence_x_to = 0;
sequence_x_max = 0;
sequence_drag = noone;
len_stretching = false;
function drawContent(panel) {
draw_clear_alpha(COLORS.panel_bg_clear, 0);
var _seq = node.getInputData(0);
var _ord = node.getInputData(2);
2023-06-10 13:59:45 +02:00
var draw_drag = true;
var content_w = w - (padding + padding);
var _ns = content_h;
var msx = mx - padding;
var msy = my - padding;
content_surface = surface_verify(content_surface, content_w, content_h);
surface_set_target(content_surface);
DRAW_CLEAR
2023-07-25 20:12:40 +02:00
for( var i = 0, n = array_length(_seq); i < n; i++ ) {
2023-06-10 13:59:45 +02:00
var _s = _seq[i];
if(!is_surface(_s)) continue;
var _sx = content_x + i * (_ns + ui(8));
var _sy = 0;
2023-09-08 21:37:36 +02:00
var _sw = surface_get_width_safe(_s);
var _sh = surface_get_height_safe(_s);
2023-06-10 13:59:45 +02:00
var _ss = (_ns - ui(8)) / max(_sw, _sh);
var _ssx = _sx + (_ns - _sw * _ss) / 2;
var _ssy = _sy + (_ns - _sh * _ss) / 2;
if(pHOVER && point_in_rectangle(msx, msy, _sx, _sy, _sx + _ns, _sy + _ns)) {
2025-01-06 02:49:09 +01:00
draw_sprite_stretched(THEME.box_r5_clr, 1, _sx, _sy, _ns, _ns);
2023-06-10 13:59:45 +02:00
if(mouse_press(mb_left, pFOCUS))
content_drag = i;
} else
2025-01-06 02:49:09 +01:00
draw_sprite_stretched(THEME.box_r5_clr, 0, _sx, _sy, _ns, _ns);
2023-06-10 13:59:45 +02:00
draw_surface_ext_safe(_s, _ssx, _ssy, _ss, _ss);
}
surface_reset_target();
content_x = lerp_float(content_x, content_x_to, 5);
content_x_max = max(0, array_length(_seq) * (_ns + ui(8)) - content_w + ui(96));
if(pHOVER && point_in_rectangle(mx, my, padding, padding, w - padding, h + content_h)) {
if(mouse_wheel_down()) content_x_to = clamp(content_x_to - (_ns + ui(8)), -content_x_max, 0);
if(mouse_wheel_up()) content_x_to = clamp(content_x_to + (_ns + ui(8)), -content_x_max, 0);
}
2023-09-08 21:09:09 +02:00
draw_surface_safe(content_surface, padding, padding);
2023-06-10 13:59:45 +02:00
var px = padding;
var py = padding + content_h + ui(16);
var pw = w - (padding + padding);
var ph = h - (padding + padding) - content_h - ui(16);
var _ns = ui(32);
var len = array_length(_ord);
var msx = mx - px;
var msy = my - py;
draw_sprite_stretched(THEME.ui_panel_bg, 1, px - ui(8), py - ui(8), pw + ui(16), ph + ui(16));
2023-06-10 13:59:45 +02:00
sequence_surface = surface_verify(sequence_surface, pw, ph);
surface_set_target(sequence_surface);
DRAW_CLEAR
draw_sprite_stretched_ext(THEME.ui_panel_bg, 1, sequence_x, 0, len * _ns, ph, COLORS._main_icon_light);
2023-06-10 13:59:45 +02:00
var ax = sequence_x + len * _ns + ui(12);
var ay = ui(24) + _ns / 2;
if(pHOVER && point_in_circle(msx, msy, ax, ay, ui(8))) {
draw_sprite_ui(THEME.animation_stretch, 0, ax, ay,,,,, 1);
if(mouse_press(mb_left, pFOCUS))
len_stretching = true;
} else
draw_sprite_ui(THEME.animation_stretch, 0, ax, ay,,,,, 0.75);
2023-10-09 16:07:33 +02:00
for( var i = 0; i < TOTAL_FRAMES; i++ ) {
2023-06-10 13:59:45 +02:00
var _sx = sequence_x + i * _ns;
draw_set_color(COLORS._main_text_sub);
draw_set_alpha(0.5);
draw_line(_sx, ui(24), _sx, ph - ui(2));
2023-06-10 13:59:45 +02:00
draw_set_alpha(1);
draw_set_text(f_p2, fa_center, fa_top, COLORS._main_text_sub);
2023-06-13 14:42:06 +02:00
draw_text_add(_sx + _ns / 2, ui(0), i + 1);
2023-06-10 13:59:45 +02:00
}
2023-06-13 14:42:06 +02:00
var __ord = _ord;
var _def = array_length(_ord) == 0;
if(_def) {
__ord = array_create(array_length(_seq));
2023-07-25 20:12:40 +02:00
for( var i = 0, n = array_length(_seq); i < n; i++ )
2023-06-13 14:42:06 +02:00
__ord[i] = i;
}
2023-07-25 20:12:40 +02:00
for( var i = 0, n = array_length(__ord); i < n; i++ ) {
2023-06-13 14:42:06 +02:00
var _i = __ord[i];
2023-06-10 13:59:45 +02:00
if(_i == noone) continue;
var _s = _seq[_i];
if(!is_surface(_s)) continue;
var _sx = sequence_x + i * _ns;
var _sy = ui(24);
2023-09-08 21:37:36 +02:00
var _sw = surface_get_width_safe(_s);
var _sh = surface_get_height_safe(_s);
2023-06-10 13:59:45 +02:00
var _ss = min(_ns / _sw, _ns / _sh);
var _ssx = _sx + (_ns - _sw * _ss) / 2;
var _ssy = _sy + (_ns - _sh * _ss) / 2;
2023-06-13 14:42:06 +02:00
draw_surface_ext_safe(_s, _ssx, _ssy, _ss, _ss,,, _def? 0.5 : 1);
2023-06-10 13:59:45 +02:00
2023-06-13 14:42:06 +02:00
if(pHOVER && !_def && point_in_rectangle(msx, msy, _sx, _sy, _sx + _ns, _sy + _ns)) {
2023-06-10 13:59:45 +02:00
if(mouse_press(mb_left, pFOCUS)) {
_ord[i] = noone;
2024-08-08 06:57:51 +02:00
node.inputs[2].setValue(_ord);
2023-06-10 13:59:45 +02:00
content_drag = _i;
}
}
}
if(content_drag != noone && pHOVER && point_in_rectangle(mx, my, px, py, px + pw, py + ph)) {
var _s = _seq[content_drag];
var frm = round((msx - sequence_x - _ns / 2) / _ns);
var _sx = sequence_x + frm * _ns;
var _sy = ui(24);
2023-09-08 21:37:36 +02:00
var _sw = surface_get_width_safe(_s);
var _sh = surface_get_height_safe(_s);
2023-06-10 13:59:45 +02:00
var _ss = min(_ns / _sw, _ns / _sh);
var _ssx = _sx + (_ns - _sw * _ss) / 2;
var _ssy = _sy + (_ns - _sh * _ss) / 2;
draw_surface_ext_safe(_s, _ssx, _ssy, _ss, _ss,,, 0.75);
draw_drag = false;
if(mouse_release(mb_left, pFOCUS)) {
_ord = array_safe_set(_ord, frm, content_drag, noone);
2024-08-08 06:57:51 +02:00
node.inputs[2].setValue(_ord);
2023-06-10 13:59:45 +02:00
content_drag = noone;
}
}
surface_reset_target();
sequence_x = lerp_float(sequence_x, sequence_x_to, 5);
sequence_x_max = max(0, array_length(_ord) * _ns - pw + ui(320));
if(pHOVER && point_in_rectangle(mx, my, px, py, px + pw, py + ph)) {
if(mouse_wheel_down()) sequence_x_to = clamp(sequence_x_to - (_ns + ui(8)), -sequence_x_max, 0);
if(mouse_wheel_up()) sequence_x_to = clamp(sequence_x_to + (_ns + ui(8)), -sequence_x_max, 0);
}
2023-09-08 21:09:09 +02:00
draw_surface_safe(sequence_surface, px, py);
2023-06-10 13:59:45 +02:00
if(len_stretching) {
var frm = round((msx - sequence_x - _ns / 2) / _ns);
_ord = array_resize_fill(_ord, frm, noone);
2024-08-08 06:57:51 +02:00
node.inputs[2].setValue(_ord);
2023-06-10 13:59:45 +02:00
if(mouse_release(mb_left))
len_stretching = false;
}
if(content_drag != noone) {
if(draw_drag) {
var _s = _seq[content_drag];
var _ns = content_h;
2023-09-08 21:37:36 +02:00
var _sw = surface_get_width_safe(_s);
var _sh = surface_get_height_safe(_s);
2023-06-10 13:59:45 +02:00
var _ss = (_ns - ui(8)) / max(_sw, _sh);
draw_surface_ext_safe(_s, mx, my, _ss, _ss,,, 0.5);
}
if(mouse_release(mb_left))
content_drag = noone;
}
}
}