mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2024-11-11 04:54:06 +01:00
115 lines
3.1 KiB
Plaintext
115 lines
3.1 KiB
Plaintext
function Node_Frame(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
|
|
name = "Frame";
|
|
w = 240;
|
|
h = 160;
|
|
alpha = 1;
|
|
bg_spr = THEME.node_frame_bg;
|
|
|
|
size_dragging = false;
|
|
size_dragging_w = w;
|
|
size_dragging_h = h;
|
|
size_dragging_mx = w;
|
|
size_dragging_my = h;
|
|
|
|
auto_height = false;
|
|
name_hover = false;
|
|
|
|
inputs[| 0] = nodeValue("Size", self, JUNCTION_CONNECT.input, VALUE_TYPE.integer, [ 240, 160 ] )
|
|
.setDisplay(VALUE_DISPLAY.vector)
|
|
.rejectArray();
|
|
|
|
inputs[| 1] = nodeValue("Color", self, JUNCTION_CONNECT.input, VALUE_TYPE.color, c_white )
|
|
.rejectArray();
|
|
|
|
inputs[| 2] = nodeValue("Alpha", self, JUNCTION_CONNECT.input, VALUE_TYPE.float, 0.75 )
|
|
.setDisplay(VALUE_DISPLAY.slider, [ 0, 1, 0.01 ])
|
|
.rejectArray();
|
|
|
|
static step = function() {
|
|
var si = inputs[| 0].getValue();
|
|
w = si[0];
|
|
h = si[1];
|
|
|
|
color = inputs[| 1].getValue();
|
|
alpha = inputs[| 2].getValue();
|
|
}
|
|
|
|
static drawNodeBase = function(xx, yy, _s) {
|
|
draw_sprite_stretched_ext(bg_spr, 0, xx, yy, w * _s, h * _s, color, alpha);
|
|
var txt = display_name == ""? name : display_name;
|
|
|
|
draw_set_text(f_h5, fa_left, fa_top, COLORS._main_text);
|
|
draw_set_alpha(clamp(alpha + name_hover * 0.5, 0, 1));
|
|
draw_text_cut(xx + 24, yy + 4 * _s, txt, (w - 8) * _s - 24);
|
|
draw_set_alpha(1);
|
|
}
|
|
|
|
draw_scale = 1;
|
|
static drawNode = function(_x, _y, _mx, _my, _s) {
|
|
draw_scale = _s;
|
|
if(group != PANEL_GRAPH.getCurrentContext()) return;
|
|
|
|
if(size_dragging) {
|
|
w = size_dragging_w + (mouse_mx - size_dragging_mx) / _s;
|
|
h = size_dragging_h + (mouse_my - size_dragging_my) / _s;
|
|
if(!key_mod_press(CTRL)) {
|
|
w = round(w / 32) * 32;
|
|
h = round(h / 32) * 32;
|
|
}
|
|
|
|
if(mouse_release(mb_left)) {
|
|
size_dragging = false;
|
|
inputs[| 0].setValue([ w, h ]);
|
|
}
|
|
}
|
|
|
|
var xx = x * _s + _x;
|
|
var yy = y * _s + _y;
|
|
drawNodeBase(xx, yy, _s);
|
|
|
|
if(active_draw_index > -1) {
|
|
draw_sprite_stretched_ext(bg_sel_spr, 0, x * _s + _x, y * _s + _y, w * _s, h * _s, COLORS._main_accent, 1);
|
|
active_draw_index = -1;
|
|
}
|
|
|
|
var x1 = xx + w * _s;
|
|
var y1 = yy + h * _s;
|
|
var x0 = x1 - 16;
|
|
var y0 = y1 - 16;
|
|
var ics = 0.5;
|
|
|
|
draw_sprite_ext(THEME.node_move, 0, xx + 4, yy + 4 * _s, ics, ics, 0, c_white, 0.25 + 0.35 * name_hover);
|
|
|
|
if(point_in_rectangle(_mx, _my, xx, yy, x1, y1) || size_dragging)
|
|
draw_sprite_ext(THEME.node_resize, 0, x1 - 4, y1 - 4, ics, ics, 0, c_white, 0.5);
|
|
|
|
if(!name_hover && point_in_rectangle(_mx, _my, x0, y0, x1, y1)) {
|
|
draw_sprite_ext(THEME.node_resize, 0, x1 - 4, y1 - 4, ics, ics, 0, c_white, 1);
|
|
PANEL_GRAPH.drag_locking = true;
|
|
|
|
if(mouse_press(mb_left)) {
|
|
size_dragging = true;
|
|
size_dragging_w = w;
|
|
size_dragging_h = h;
|
|
size_dragging_mx = mouse_mx;
|
|
size_dragging_my = mouse_my;
|
|
}
|
|
}
|
|
return noone;
|
|
}
|
|
|
|
static pointIn = function(_x, _y, _mx, _my, _s) {
|
|
var xx = x * _s + _x;
|
|
var yy = y * _s + _y;
|
|
|
|
var txt = display_name == ""? name : display_name;
|
|
draw_set_font(f_h5);
|
|
var ww = string_width(txt) + 24 + 8;
|
|
var hh = string_height("l") + 8;
|
|
|
|
var hover = point_in_rectangle(_mx, _my, xx, yy, xx + ww, yy + hh);
|
|
name_hover = hover;
|
|
|
|
return hover;
|
|
}
|
|
} |