Pixel-Composer/scripts/node_collection_inline/node_collection_inline.gml

337 lines
9.1 KiB
Text
Raw Normal View History

2023-12-18 08:27:31 +01:00
function Node_Collection_Inline(_x, _y, _group = noone) : Node(_x, _y, _group) constructor {
attributes.members = [];
nodes = [];
2023-12-18 08:27:31 +01:00
group_vertex = [];
group_dragging = false;
group_adding = false;
vertex_hash = "";
2024-06-11 05:06:42 +02:00
modifiable = true;
2023-12-18 08:27:31 +01:00
2023-12-19 14:30:34 +01:00
managedRenderOrder = false;
2023-12-18 08:27:31 +01:00
group_hovering = false;
2023-12-18 13:54:33 +01:00
group_hover_al = 0;
2023-12-19 14:30:34 +01:00
selectable = false;
2023-12-18 08:27:31 +01:00
2023-12-20 14:02:49 +01:00
input_node_type = noone;
output_node_type = noone;
add_point = false;
point_x = 0;
point_y = 0;
2024-11-30 06:50:20 +01:00
junction_x = 0;
junction_y = 0;
2023-12-22 04:15:04 +01:00
is_root = true;
2024-11-30 06:50:20 +01:00
bbox = [ 0, 0, 0, 0 ];
2024-08-08 06:57:51 +02:00
static topoSortable = function() { return false; }
2023-12-22 04:15:04 +01:00
2024-08-08 06:57:51 +02:00
static removeNode = function(node) {
2023-12-18 08:27:31 +01:00
array_remove(attributes.members, node.node_id);
2023-12-22 04:15:04 +01:00
array_remove(nodes, node);
2023-12-18 08:27:31 +01:00
if(node.inline_context == self)
node.inline_context = noone;
2023-12-22 04:15:04 +01:00
onRemoveNode(node);
2024-11-12 04:15:04 +01:00
// print($"Pose remove node : {array_length(nodes)}");
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2023-12-22 04:15:04 +01:00
static onRemoveNode = function(node) {}
2024-08-08 06:57:51 +02:00
static addNode = function(node) {
if(node.inline_context != noone && node.inline_context != self)
node.inline_context.removeNode(node);
node.inline_context = self;
2023-12-22 04:15:04 +01:00
array_push_unique(attributes.members, node.node_id);
array_push_unique(nodes, node);
2024-11-12 04:15:04 +01:00
refreshGroupBG();
2023-12-18 08:27:31 +01:00
2023-12-22 04:15:04 +01:00
onAddNode(node);
2024-11-12 04:15:04 +01:00
2024-11-30 06:50:20 +01:00
// print($"Post add node : {array_length(nodes)}");
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2024-05-24 10:33:27 +02:00
static addPoint = function(_x, _y) {
add_point = true;
point_x = _x;
point_y = _y;
}
2023-12-22 04:15:04 +01:00
static onAddNode = function(node) {}
2024-11-30 06:50:20 +01:00
static resetRender = function(_clearCache = false) {
LOG_LINE_IF(global.FLAG.render == 1, $"Reset Render for {INAME}");
setRenderStatus(false);
if(_clearCache) clearInputCache();
for( var i = 0; i < array_length(nodes); i++ )
nodes[i].resetRender(_clearCache);
}
///////////////////////////////////////////////////////////////////////////////////////
2023-12-18 08:27:31 +01:00
static ccw = function(a, b, c) { return (b[0] - a[0]) * (c[1] - a[1]) - (c[0] - a[0]) * (b[1] - a[1]); }
2024-08-08 06:57:51 +02:00
static getNodeBorder = function(_ind, _vertex, _node) {
2023-12-19 14:30:34 +01:00
var _rad = 6;
2024-04-05 05:50:03 +02:00
var _stp = 30;
2023-12-18 08:27:31 +01:00
2023-12-20 14:02:49 +01:00
var _nx0 = is_instanceof(_node, input_node_type)? _node.x + _node.w / 2 : _node.x - 32 + _rad;
2023-12-18 08:27:31 +01:00
var _ny0 = _node.y - 32 + _rad;
2023-12-20 14:02:49 +01:00
var _nx1 = is_instanceof(_node, output_node_type)? _node.x + _node.w / 2 : _node.x + _node.w + 32 - _rad;
2023-12-18 08:27:31 +01:00
var _ny1 = _node.y + _node.h + 32 - _rad;
2024-04-05 05:50:03 +02:00
for( var i = 0; i <= 90; i += _stp ) _vertex[_ind++] = [ _nx1 + lengthdir_x(_rad, i), _ny0 + lengthdir_y(_rad, i) ];
for( var i = 90; i <= 180; i += _stp ) _vertex[_ind++] = [ _nx0 + lengthdir_x(_rad, i), _ny0 + lengthdir_y(_rad, i) ];
for( var i = 180; i <= 270; i += _stp ) _vertex[_ind++] = [ _nx0 + lengthdir_x(_rad, i), _ny1 + lengthdir_y(_rad, i) ];
for( var i = 270; i <= 360; i += _stp ) _vertex[_ind++] = [ _nx1 + lengthdir_x(_rad, i), _ny1 + lengthdir_y(_rad, i) ];
2023-12-19 14:30:34 +01:00
return _ind;
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2024-08-08 06:57:51 +02:00
static refreshMember = function() {
nodes = [];
2024-10-01 05:46:28 +02:00
array_foreach(attributes.members, function(m) /*=>*/ { if(ds_map_exists(PROJECT.nodeMap, m)) addNode(PROJECT.nodeMap[? m]); })
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2024-08-08 06:57:51 +02:00
static refreshGroupBG = function() {
2023-12-18 08:27:31 +01:00
var _hash = "";
var _ind = 0;
for( var i = 0, n = array_length(nodes); i < n; i++ ) {
var _node = nodes[i];
2023-12-18 08:27:31 +01:00
if(!_node.active) continue;
_hash += $"{_node.x},{_node.y},{_node.w},{_node.h}|";
_ind++;
}
if(add_point) _hash += $"{point_x},{point_y}|";
2023-12-18 08:27:31 +01:00
if(_hash == "") {
group_vertex = [];
2024-04-08 07:13:46 +02:00
destroy();
2023-12-18 08:27:31 +01:00
return;
}
_hash = md5_string_utf8(_hash);
if(vertex_hash == _hash) return;
2024-11-30 06:50:20 +01:00
vertex_hash = _hash;
2023-12-18 08:27:31 +01:00
group_vertex = [];
if(_ind == 0) return;
2024-04-05 05:50:03 +02:00
var _vtrx = array_create(_ind * 4 * (90 / 30 + 1));
2023-12-18 08:27:31 +01:00
var _ind = 0;
for( var i = 0, n = array_length(nodes); i < n; i++ ) {
var _node = nodes[i];
2023-12-18 08:27:31 +01:00
if(!_node.active) continue;
2023-12-19 14:30:34 +01:00
_ind = getNodeBorder(_ind, _vtrx, _node);
2023-12-18 08:27:31 +01:00
}
if(add_point) array_push(_vtrx, [ point_x, point_y ]);
2024-08-08 06:57:51 +02:00
__temp_minP = _vtrx[0];
__temp_minI = 0;
for( var i = 0, n = array_length(_vtrx); i < n; i++ ) {
var _v = _vtrx[i];
var _vx = _v[0];
var _vy = _v[1];
2023-12-18 08:27:31 +01:00
2024-08-08 06:57:51 +02:00
if(_vy > __temp_minP[1] || (_vy == __temp_minP[1] && _vx < __temp_minP[0])) {
__temp_minP = _v;
__temp_minI = i;
2023-12-19 14:30:34 +01:00
}
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2024-08-08 06:57:51 +02:00
_vtrx = array_map( _vtrx, function(a, i) { return [ a[0], a[1], i == __temp_minI? -999 : point_direction(__temp_minP[0], __temp_minP[1], a[0], a[1]) + 360 ] });
array_sort(_vtrx, function(a0, a1) { return a0[2] == a1[2]? sign(a0[0] - a1[0]) : sign(a0[2] - a1[2]); });
var _linS = 0;
for( var i = 1, n = array_length(_vtrx); i < n; i++ ) {
if(_vtrx[i][1] != _vtrx[0][1]) break;
_linS = i;
}
array_delete(_vtrx, 1, _linS - 1);
group_vertex = [ _vtrx[0], _vtrx[1] ];
2024-11-30 06:50:20 +01:00
junction_x = _vtrx[0][0];
junction_y = _vtrx[0][1];
var minx = _vtrx[0][0];
var miny = _vtrx[0][1];
var maxx = _vtrx[0][0];
var maxy = _vtrx[0][1];
2023-12-18 08:27:31 +01:00
2024-08-08 06:57:51 +02:00
for( var i = 2, n = array_length(_vtrx); i < n; i++ ) {
var _v = _vtrx[i];
while( array_length(group_vertex) >= 2 && ccw( group_vertex[array_length(group_vertex) - 2], group_vertex[array_length(group_vertex) - 1], _v ) >= 0 )
array_pop(group_vertex);
array_push(group_vertex, _v);
}
for( var i = array_length(group_vertex) - 1; i >= 0; i-- ) {
var n = array_length(group_vertex);
if(n < 4) break;
2024-04-05 05:50:03 +02:00
2024-08-08 06:57:51 +02:00
var v0 = group_vertex[(i - 1 + n) % n];
var v1 = group_vertex[i];
var v2 = group_vertex[(i + 1) % n];
2023-12-18 08:27:31 +01:00
2024-08-08 06:57:51 +02:00
var a0 = point_direction(v1[0], v1[1], v0[0], v0[1]);
var a1 = point_direction(v1[0], v1[1], v2[0], v2[1]);
var d = angle_difference(a0, a1);
2024-04-05 05:50:03 +02:00
2024-08-08 06:57:51 +02:00
if(min(abs(d), abs(d - 180)) <= 2)
array_delete(group_vertex, i, 1);
2024-11-30 06:50:20 +01:00
if(v1[0] <= junction_x && v1[1] <= junction_y) {
junction_x = v1[0];
junction_y = v1[1] + 8;
}
minx = min(minx, v1[0]);
miny = min(miny, v1[1]);
maxx = max(maxx, v1[0]);
maxy = max(maxy, v1[1]);
2024-08-08 06:57:51 +02:00
}
2024-11-30 06:50:20 +01:00
bbox = [ minx, miny, maxx, maxy ];
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2024-08-08 06:57:51 +02:00
static groupCheck = function(_x, _y, _s, _mx, _my) {
2023-12-18 08:27:31 +01:00
if(array_length(group_vertex) < 3) return;
2024-06-11 05:06:42 +02:00
if(!modifiable) return;
2024-11-23 12:08:44 +01:00
var _m = [ _mx / _s - _x, _my / _s - _y ];
2023-12-18 08:27:31 +01:00
group_adding = false;
if(PANEL_GRAPH.node_dragging && PANEL_GRAPH.frame_hovering == self) {
2023-12-18 13:54:33 +01:00
var _list = PANEL_GRAPH.nodes_selecting;
2024-10-01 05:46:28 +02:00
PANEL_GRAPH.addKeyOverlay("Inline group", [[ "Shift", "Add/remove" ]]);
if(!array_empty(_list) && key_mod_down(SHIFT)) {
var _remove = _list[0].inline_context == self;
if(_remove) {
for( var i = 0, n = array_length(_list); i < n; i++ )
if(_list[i].manual_ungroupable) removeNode(_list[i]);
} else {
group_adding = true;
2024-11-12 04:15:04 +01:00
for( var i = 0, n = array_length(_list); i < n; i++ )
if(_list[i].manual_ungroupable) addNode(_list[i]);
}
2023-12-18 08:27:31 +01:00
}
}
if(group_dragging && mouse_release(mb_left)) {
refreshMember();
refreshGroupBG();
group_dragging = false;
}
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2023-12-19 14:30:34 +01:00
static pointIn = function(_x, _y, _mx, _my, _s) { return false; }
static cullCheck = function(_x, _y, _s, minx, miny, maxx, maxy) { return true; }
2023-12-19 14:30:34 +01:00
2024-08-08 06:57:51 +02:00
static drawNodeBG = function(_x, _y, _mx, _my, _s) {
2023-12-18 08:27:31 +01:00
refreshGroupBG();
if(array_length(group_vertex) < 3) return false;
2023-12-19 14:30:34 +01:00
var _hov = false;
var _color = getColor();
var _sel = inspecting || add_point;
2023-12-19 14:30:34 +01:00
inspecting = false;
2023-12-18 08:27:31 +01:00
draw_set_color(_color);
2023-12-18 13:54:33 +01:00
group_hover_al = lerp_float(group_hover_al, group_hovering, 4);
2023-12-22 04:15:04 +01:00
group_hovering = 0;
draw_set_alpha(_sel? 0.1 : lerp(0.025, 0.05, group_hover_al));
2023-12-19 14:30:34 +01:00
2023-12-18 08:27:31 +01:00
draw_primitive_begin(pr_trianglelist);
var a = group_vertex[0];
var b = group_vertex[1];
var c;
for( var i = 2, n = array_length(group_vertex); i < n; i++ ) {
c = group_vertex[i];
var v0x = _x + a[0] * _s;
var v0y = _y + a[1] * _s;
var v1x = _x + b[0] * _s;
var v1y = _y + b[1] * _s;
var v2x = _x + c[0] * _s;
var v2y = _y + c[1] * _s;
2023-12-22 04:15:04 +01:00
draw_vertex(round(v0x), round(v0y));
draw_vertex(round(v1x), round(v1y));
draw_vertex(round(v2x), round(v2y));
2023-12-18 08:27:31 +01:00
2023-12-22 04:15:04 +01:00
if(!_hov && point_in_triangle(_mx, _my, v0x, v0y, v1x, v1y, v2x, v2y)) {
group_hovering = 1 + (PANEL_GRAPH._frame_hovering == self && key_mod_press(SHIFT)) * 2;
2023-12-18 08:27:31 +01:00
_hov = true;
2023-12-22 04:15:04 +01:00
}
2023-12-18 08:27:31 +01:00
b = group_vertex[i];
}
draw_primitive_end();
draw_set_alpha(_sel? 1 : lerp(0.4, 0.65, group_hover_al));
2023-12-18 08:27:31 +01:00
draw_primitive_begin(pr_linestrip);
for( var i = 0, n = array_length(group_vertex); i < n; i++ ) {
var a = group_vertex[i];
draw_vertex(_x + a[0] * _s, _y + a[1] * _s);
}
a = group_vertex[0];
draw_vertex(_x + a[0] * _s, _y + a[1] * _s);
draw_primitive_end();
draw_set_alpha(1);
add_point = false;
2023-12-18 08:27:31 +01:00
return _hov;
2024-08-08 06:57:51 +02:00
}
2023-12-18 08:27:31 +01:00
2024-11-30 06:50:20 +01:00
static drawNode = function(_draw, _x, _y, _mx, _my, _s, display_parameter = noone) {
var xx = x * _s + _x;
var yy = y * _s + _y;
return drawJunctions(_draw, xx, yy, _mx, _my, _s)
}
2023-12-18 08:27:31 +01:00
2023-12-19 14:30:34 +01:00
static drawBadge = function(_x, _y, _s) {}
2024-11-30 06:50:20 +01:00
static drawJunctions = function(_draw, _x, _y, _mx, _my, _s) {}
2024-08-08 06:57:51 +02:00
static postDeserialize = function() {
2023-12-18 08:27:31 +01:00
refreshMember();
2024-08-08 06:57:51 +02:00
}
2024-09-07 12:48:57 +02:00
static junctionIsInside = function(junc) {
if(!modifiable)
return false;
if(is_instanceof(junc.node, input_node_type) && junc.connect_type == CONNECT_TYPE.input)
return false;
if(is_instanceof(junc.node, output_node_type) && junc.connect_type == CONNECT_TYPE.output)
return false;
return true;
}
2023-12-18 08:27:31 +01:00
}