node minimize

This commit is contained in:
Tanasart 2024-07-10 16:48:23 +07:00
parent 82b45b8a50
commit 39421f398c
3 changed files with 110 additions and 50 deletions

Binary file not shown.

View file

@ -92,11 +92,12 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
tooltip = ""; tooltip = "";
x = _x; x = _x;
y = _y; y = _y;
name_height = 16;
w = 128; w = 128;
h = 128; h = 128;
min_w = w; min_w = w;
min_h = h; min_h = name_height;
fix_h = h; fix_h = h;
h_param = h; h_param = h;
will_setHeight = false; will_setHeight = false;
@ -623,36 +624,57 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
outputs_index = array_create_ext(outputs_amount, function(index) { return getOutputJunctionIndex(index); }); outputs_index = array_create_ext(outputs_amount, function(index) { return getOutputJunctionIndex(index); });
} run_in(1, function() /*=>*/ { updateIO() }); } run_in(1, function() /*=>*/ { updateIO() });
static setHeight = function() { #region static setHeight = function() {
w = show_parameter? attributes.node_param_width : min_w; w = show_parameter? attributes.node_param_width : min_w;
if(!auto_height) return; if(!auto_height) return;
junction_draw_hei_y = show_parameter? 32 : 24; junction_draw_hei_y = show_parameter? 32 : 24;
junction_draw_pad_y = show_parameter? min_h : 32; junction_draw_pad_y = show_parameter? min_h : 32;
var _hi = junction_draw_pad_y + show_parameter * 4; var _hi, _ho;
var _ho = junction_draw_pad_y + show_parameter * 4;
if(previewable) {
_hi = junction_draw_pad_y + show_parameter * 4;
_ho = junction_draw_pad_y + show_parameter * 4;
} else {
junction_draw_hei_y = 16;
junction_draw_pad_y = name_height / 2;
_hi = name_height;
_ho = name_height;
}
var _prev_surf = previewable && preview_draw && var _prev_surf = previewable && preview_draw &&
( is_surface(getGraphPreviewSurface()) || ( is_surface(getGraphPreviewSurface()) ||
(preview_channel >= 0 && preview_channel < ds_list_size(outputs) && outputs[| preview_channel].type == VALUE_TYPE.surface) (preview_channel >= 0 && preview_channel < ds_list_size(outputs) && outputs[| preview_channel].type == VALUE_TYPE.surface)
); );
var _p = previewable;
for( var i = 0; i < ds_list_size(inputs); i++ ) { for( var i = 0; i < ds_list_size(inputs); i++ ) {
var _inp = inputs[| i]; var _inp = inputs[| i];
if(is_instanceof(_inp, NodeValue) && _inp.isVisible()) if(is_instanceof(_inp, NodeValue) && _inp.isVisible()) {
_hi += junction_draw_hei_y; if(_p) _hi += junction_draw_hei_y;
_p = true;
}
} }
if(auto_input && dummy_input) _hi += junction_draw_hei_y; if(auto_input && dummy_input) _hi += junction_draw_hei_y;
var _p = previewable;
for( var i = 0; i < ds_list_size(outputs); i++ ) for( var i = 0; i < ds_list_size(outputs); i++ ) {
if(outputs[| i].isVisible()) _ho += junction_draw_hei_y; if(outputs[| i].isVisible()) {
if(_p) _ho += junction_draw_hei_y;
_p = true;
}
}
h = max(min_h, _prev_surf * 128, _hi, _ho);
if(attributes.node_height) h = max(h, attributes.node_height);
h = max(min_h, _prev_surf * 128, _hi, _ho, attributes.node_height);
fix_h = h; fix_h = h;
} #endregion }
static getJunctionList = function() { #region ////getJunctionList static getJunctionList = function() { #region ////getJunctionList
var amo = input_display_list == -1? ds_list_size(inputs) : array_length(input_display_list); var amo = input_display_list == -1? ds_list_size(inputs) : array_length(input_display_list);
@ -1186,10 +1208,10 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
_h *= _s; _h *= _s;
_w -= max(draw_padding, draw_pad_w) * 2; _w -= max(draw_padding, draw_pad_w) * 2;
_h -= max(draw_padding, draw_pad_h) * 2 + 20 * pad_label; _h -= max(draw_padding, draw_pad_h) * 2 + name_height * _s * pad_label;
var _xc = xx + w * _s / 2; var _xc = xx + w * _s / 2;
var _yc = yy + _h / 2 + pad_label * 20 + draw_padding; var _yc = yy + _h / 2 + pad_label * name_height * _s + draw_padding;
_w *= display_parameter.preview_scale / 100; _w *= display_parameter.preview_scale / 100;
_h *= display_parameter.preview_scale / 100; _h *= display_parameter.preview_scale / 100;
@ -1208,11 +1230,11 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
draw_name = true; draw_name = true;
var ts = clamp(power(_s, 0.5), 0.5, 1);
var aa = (.25 + .5 * renderActive) * (.25 + .75 * isHighlightingInGraph()); var aa = (.25 + .5 * renderActive) * (.25 + .75 * isHighlightingInGraph());
var cc = getColor(); var cc = getColor();
var nh = previewable? name_height * _s : h * _s;
draw_sprite_stretched_ext(THEME.node_bg_name, 0, xx, yy, w * _s, ui(20), cc, aa); draw_sprite_stretched_ext(THEME.node_bg_name, 0, xx, yy, w * _s, nh, cc, aa);
var cc = COLORS._main_text; var cc = COLORS._main_text;
if(PREFERENCES.node_show_render_status && !rendered) if(PREFERENCES.node_show_render_status && !rendered)
@ -1220,11 +1242,24 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
aa += 0.25; aa += 0.25;
if(icon) draw_sprite_ui_uniform(icon, 0, xx + ui(12), yy + ui(10),,, aa); var tx = xx + 6 * _s;
var tw = w * _s - 6 * _s;
draw_set_text(f_p1, fa_left, fa_center, cc, aa); if(!previewable) {
var _xpd = ui(8 + (icon != noone) * 16); tx += _s * 4;
draw_text_cut(round(xx + _xpd), round(yy + ui(10)), _name, w * _s - _xpd, ts); tw -= _s * 4;
}
if(icon) {
tx += _s * 6;
draw_sprite_ui_uniform(icon, 0, round(tx), round(yy + nh / 2), _s, c_white, aa);
tx += _s * 12;
tw -= _s * (6 + 12);
}
draw_set_text(f_sdf, fa_left, fa_center, cc, aa);
draw_text_cut(round(tx), round(yy + nh / 2 + 1), _name, tw, _s * 0.275);
draw_set_alpha(1); draw_set_alpha(1);
} }
@ -1302,7 +1337,7 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
h_param = h; h_param = h;
} #endregion } #endregion
static drawJunctions = function(_x, _y, _mx, _my, _s) { #region static drawJunctions = function(_x, _y, _mx, _my, _s) {
if(!active) return; if(!active) return;
var hover = noone; var hover = noone;
@ -1335,14 +1370,12 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
onDrawJunctions(_x, _y, _mx, _my, _s); onDrawJunctions(_x, _y, _mx, _my, _s);
return hover; return hover;
} #endregion }
static drawJunctions_fast = function(_x, _y, _mx, _my, _s) { #region static drawJunctions_fast = function(_x, _y, _mx, _my, _s) {
if(!active) return; if(!active) return;
var hover = noone; var hover = noone;
_s = _s * 6;
draw_set_circle_precision(4); draw_set_circle_precision(4);
for(var i = 0, n = array_length(inputDisplayList); i < n; i++) { for(var i = 0, n = array_length(inputDisplayList); i < n; i++) {
@ -1371,10 +1404,10 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
if(updatedOutTrigger.drawJunction_fast(_s, _mx, _my)) hover = updatedOutTrigger; if(updatedOutTrigger.drawJunction_fast(_s, _mx, _my)) hover = updatedOutTrigger;
} }
onDrawJunctions(_x, _y, _mx, _my, _s / 6); onDrawJunctions(_x, _y, _mx, _my, _s);
return hover; return hover;
} #endregion }
static onDrawJunctions = function(_x, _y, _mx, _my, _s) {} static onDrawJunctions = function(_x, _y, _mx, _my, _s) {}
@ -1390,9 +1423,15 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
var _hov = PANEL_GRAPH.pHOVER && (PANEL_GRAPH.node_hovering == noone || PANEL_GRAPH.node_hovering == self); var _hov = PANEL_GRAPH.pHOVER && (PANEL_GRAPH.node_hovering == noone || PANEL_GRAPH.node_hovering == self);
show_input_name = _hov && point_in_rectangle(_mx, _my, xx - 12 * _s, yy + 20 * _s, xx + 12 * _s, yy + h * _s); show_input_name = _hov;
show_output_name = _hov && point_in_rectangle(_mx, _my, xx + (w - 12) * _s, yy + 20 * _s, xx + (w + 12) * _s, yy + h * _s); show_output_name = _hov;
var _y0 = previewable? yy + name_height * _s : yy;
var _y1 = yy + h * _s;
show_input_name &= point_in_rectangle(_mx, _my, xx - ( 12) * _s, _y0, xx + ( 12) * _s, _y1);
show_output_name &= point_in_rectangle(_mx, _my, xx + (w - 12) * _s, _y0, xx + (w + 12) * _s, _y1);
if(PANEL_GRAPH.value_dragging && PANEL_GRAPH.node_hovering == self) { if(PANEL_GRAPH.value_dragging && PANEL_GRAPH.node_hovering == self) {
if(PANEL_GRAPH.value_dragging.connect_type == JUNCTION_CONNECT.input) if(PANEL_GRAPH.value_dragging.connect_type == JUNCTION_CONNECT.input)
show_output_name = true; show_output_name = true;
@ -1599,8 +1638,9 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
static drawDimension = function(xx, yy, _s) { #region static drawDimension = function(xx, yy, _s) { #region
if(draw_graph_culled) return; if(draw_graph_culled) return;
if(!active) return; if(!active) return;
if(_s * w < 64) return; if(_s * w < 64) return;
if(!previewable) return;
draw_set_text(f_p3, fa_center, fa_top, COLORS.panel_graph_node_dimension); draw_set_text(f_p3, fa_center, fa_top, COLORS.panel_graph_node_dimension);
var tx = xx + w * _s / 2; var tx = xx + w * _s / 2;
@ -1686,7 +1726,7 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
if(show_parameter) drawJunctionWidget(xx, yy, _mx, _my, _s, _hover, _focus); if(show_parameter) drawJunctionWidget(xx, yy, _mx, _my, _s, _hover, _focus);
draw_name = false; draw_name = false;
if(_s >= 0.75) drawNodeName(xx, yy, _s); if((previewable && _s >= 0.75) || (!previewable && h * _s >= name_height * .5)) drawNodeName(xx, yy, _s);
if(attributes.annotation != "") { if(attributes.annotation != "") {
draw_set_text(f_sdf_medium, fa_left, fa_bottom, COLORS._main_text_sub); draw_set_text(f_sdf_medium, fa_left, fa_bottom, COLORS._main_text_sub);
@ -1714,6 +1754,7 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
drawNodeOverlay(xx, yy, _mx, _my, _s); drawNodeOverlay(xx, yy, _mx, _my, _s);
if(!previewable) return drawJunctions_fast(xx, yy, _mx, _my, _s);
return _s > 0.5? drawJunctions(xx, yy, _mx, _my, _s) : drawJunctions_fast(xx, yy, _mx, _my, _s); return _s > 0.5? drawJunctions(xx, yy, _mx, _my, _s) : drawJunctions_fast(xx, yy, _mx, _my, _s);
} #endregion } #endregion
@ -2262,7 +2303,8 @@ function Node(_x, _y, _group = noone) : __Node_Base(_x, _y) constructor {
INLINE INLINE
min_w = _w; min_w = _w;
min_h = _h; min_h = _h;
min_h = name_height; ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
if(_apply) { if(_apply) {
w = _w; w = _w;

View file

@ -1795,26 +1795,38 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
return -1; return -1;
} #endregion } #endregion
static drawJunction_fast = function(_s, _mx, _my) { #region static drawJunction_fast = function(_s, _mx, _my) {
INLINE INLINE
var hov = PANEL_GRAPH.pHOVER && (PANEL_GRAPH.node_hovering == noone || PANEL_GRAPH.node_hovering == node); var hov = PANEL_GRAPH.pHOVER && (PANEL_GRAPH.node_hovering == noone || PANEL_GRAPH.node_hovering == node);
var _hov = hov && abs(_mx - x) + abs(_my - y) < _s; var _d = node.junction_draw_hei_y * _s;
var _hov = hov && point_in_rectangle(_mx, _my, x - 6 * _s, y - _d / 2, x + 6 * _s, y + _d / 2 - 1);
var _aa = 0.75 + (!is_dummy * 0.25); var _aa = 0.75 + (!is_dummy * 0.25);
hover_in_graph = _hov;
draw_set_color(draw_fg); draw_set_color(draw_fg);
draw_set_alpha(_aa); draw_set_alpha(_aa);
draw_circle(x, y, _s, false);
if(node.previewable)
draw_circle(x, y, _s * 6, false);
else if(index == -1)
draw_rectangle( x - _s * 4, y - _s * 1.5,
x + _s * 4, y + _s * 1.5, false);
else
draw_rectangle( x - _s * 1.5, y - _s * 4,
x + _s * 1.5, y + _s * 4, false);
draw_set_alpha(1); draw_set_alpha(1);
return _hov; return _hov;
} #endregion }
static drawJunction = function(_s, _mx, _my) { #region static drawJunction = function(_s, _mx, _my) {
_s /= 2; _s /= 2;
var hov = PANEL_GRAPH.pHOVER && (PANEL_GRAPH.node_hovering == noone || PANEL_GRAPH.node_hovering == node); var hov = PANEL_GRAPH.pHOVER && (PANEL_GRAPH.node_hovering == noone || PANEL_GRAPH.node_hovering == node);
var _d = 24 * _s; var _d = node.junction_draw_hei_y * _s;
var is_hover = hov && point_in_rectangle(_mx, _my, x - _d, y - _d, x + _d - 1, y + _d - 1); var is_hover = hov && point_in_rectangle(_mx, _my, x - _d, y - _d, x + _d - 1, y + _d - 1);
hover_in_graph = is_hover; hover_in_graph = is_hover;
@ -1854,10 +1866,11 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
} }
return is_hover; return is_hover;
} #endregion }
static drawNameBG = function(_s) { #region static drawNameBG = function(_s) {
draw_set_text(f_p1, fa_left, fa_center); var _f = node.previewable? f_p1 : f_p3;
draw_set_text(_f, fa_left, fa_center);
var tw = string_width(name) + 32; var tw = string_width(name) + 32;
var th = string_height(name) + 16; var th = string_height(name) + 16;
@ -1865,41 +1878,46 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
if(type == VALUE_TYPE.action) { if(type == VALUE_TYPE.action) {
var tx = x; var tx = x;
draw_sprite_stretched_ext(THEME.node_junction_name_bg, 0, tx - tw / 2, y - th, tw, th, c_white, 0.5); draw_sprite_stretched_ext(THEME.node_junction_name_bg, 0, tx - tw / 2, y - th, tw, th, c_white, 0.5);
} else if(connect_type == JUNCTION_CONNECT.input) { } else if(connect_type == JUNCTION_CONNECT.input) {
var tx = x - 12 * _s; var tx = x - 12 * _s;
draw_sprite_stretched_ext(THEME.node_junction_name_bg, 0, tx - tw + 16, y - th / 2, tw, th, c_white, 0.5); draw_sprite_stretched_ext(THEME.node_junction_name_bg, 0, tx - tw + 16, y - th / 2, tw, th, c_white, 0.5);
} else { } else {
var tx = x + 12 * _s; var tx = x + 12 * _s;
draw_sprite_stretched_ext(THEME.node_junction_name_bg, 0, tx - 16, y - th / 2, tw, th, c_white, 0.5); draw_sprite_stretched_ext(THEME.node_junction_name_bg, 0, tx - 16, y - th / 2, tw, th, c_white, 0.5);
} }
} #endregion }
static drawName = function(_s, _mx, _my) { #region static drawName = function(_s, _mx, _my) {
var _draw_cc = COLORS._main_text; var _draw_cc = COLORS._main_text;
var _draw_aa = 0.8 + hover_in_graph * 0.2; var _draw_aa = 0.6 + hover_in_graph * 0.4;
draw_set_text(f_p1, fa_left, fa_center, _draw_cc);
var _f = node.previewable? f_p1 : f_p3;
draw_set_text(_f, fa_left, fa_center, _draw_cc);
draw_set_alpha(_draw_aa); draw_set_alpha(_draw_aa);
if(type == VALUE_TYPE.action) { if(type == VALUE_TYPE.action) {
var tx = x; var tx = x;
draw_set_text(f_p1, fa_center, fa_center, _draw_cc); draw_set_text(_f, fa_center, fa_center, _draw_cc);
draw_text_int(tx, y - (line_get_height() + 16) / 2, name); draw_text_add(tx, y - (line_get_height() + 16) / 2, name);
} else if(connect_type == JUNCTION_CONNECT.input) { } else if(connect_type == JUNCTION_CONNECT.input) {
var tx = x - 12 * _s; var tx = x - 12 * _s;
draw_set_halign(fa_right); draw_set_halign(fa_right);
draw_text_int(tx, y, name); draw_text_add(tx, y, name);
} else { } else {
var tx = x + 12 * _s; var tx = x + 12 * _s;
draw_set_halign(fa_left); draw_set_halign(fa_left);
draw_text_int(tx, y, name); draw_text_add(tx, y, name);
} }
draw_set_alpha(1); draw_set_alpha(1);
} #endregion }
static drawConnectionsRaw = function(params = {}) { return drawJuncConnection(value_from, self, params); } static drawConnectionsRaw = function(params = {}) { return drawJuncConnection(value_from, self, params); }
static drawConnections = function(params = {}) { static drawConnections = function(params = {}) {