multi junctions connect

This commit is contained in:
Tanasart 2023-08-13 09:51:36 +02:00
parent ef5560ef02
commit 83f2ea53bf
3 changed files with 63 additions and 23 deletions

View file

@ -59,10 +59,12 @@ function Node_Armature_Bind(_x, _y, _group = noone) : Node_Processor(_x, _y, _gr
ds_map_clear(surfMap); ds_map_clear(surfMap);
var index = -1; var index = -1;
for(var i = input_fix_len; i < ds_list_size(inputs) - data_length; i += data_length) { var amo = min(ds_list_size(inputs) - data_length, array_length(current_data));
for(var i = input_fix_len; i < amo; i += data_length) {
index++; index++;
var _surf = current_data[i]; var _surf = current_data[i];
var _id = inputs[| i].extra_data.bone_id; var _id = inputs[| i].extra_data.bone_id;
if(_id == "") continue; if(_id == "") continue;
if(ds_map_exists(surfMap, _id)) if(ds_map_exists(surfMap, _id))

View file

@ -1771,12 +1771,8 @@ function NodeValue(_name, _node, _connect, _type, _value, _tooltip = "") constru
static drawConnectionMouse = function(_mx, _my, ss, target) { static drawConnectionMouse = function(_mx, _my, ss, target) {
var drawCorner = type == VALUE_TYPE.action; var drawCorner = type == VALUE_TYPE.action;
if(target != noone) { if(target != noone)
_mx = target.x;
_my = target.y;
drawCorner |= target.type == VALUE_TYPE.action; drawCorner |= target.type == VALUE_TYPE.action;
}
var corner = PREF_MAP[? "connection_line_corner"] * ss; var corner = PREF_MAP[? "connection_line_corner"] * ss;
var th = PREF_MAP[? "connection_line_width"] * ss; var th = PREF_MAP[? "connection_line_width"] * ss;

View file

@ -1390,11 +1390,12 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
function drawJunctionConnect() { function drawJunctionConnect() {
if(value_dragging) { if(value_dragging) {
var xx = value_dragging.x; var xx = value_dragging.x;
var yy = value_dragging.y; var yy = value_dragging.y;
var _mx = mx; var _mx = mx;
var _my = my; var _my = my;
var target = noone; var target = noone;
var _addInput = false;
if(value_focus && value_focus != value_dragging && value_focus.connect_type != value_dragging.connect_type) if(value_focus && value_focus != value_dragging && value_focus.connect_type != value_dragging.connect_type)
target = value_focus; target = value_focus;
@ -1410,21 +1411,43 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
} }
} }
value_dragging.drawConnectionMouse(_mx, _my, graph_s, target); if(target != noone && struct_has(target.node, "addInput"))
_addInput = true;
var _mmx = target != noone? target.x : _mx;
var _mmy = target != noone? target.y : _my;
if(array_empty(value_draggings))
value_dragging.drawConnectionMouse(_mmx, _mmy, graph_s, target);
else {
var _stIndex = array_find(value_draggings, value_dragging);
for( var i = 0, n = array_length(value_draggings); i < n; i++ ) {
var _dmx = _mmx;
var _dmy = _mmy + (i - _stIndex) * 24 * graph_s;
value_draggings[i].drawConnectionMouse(_dmx, _dmy, graph_s, target);
}
}
value_dragging.drawJunction(graph_s, value_dragging.x, value_dragging.y); value_dragging.drawJunction(graph_s, value_dragging.x, value_dragging.y);
if(target) if(target)
target.drawJunction(graph_s, target.x, target.y); target.drawJunction(graph_s, target.x, target.y);
if(mouse_release(mb_left)) { if(mouse_release(mb_left)) { // CONNECT junction
if(value_focus && value_focus != value_dragging) { if(target != noone) {
if(value_focus.connect_type == JUNCTION_CONNECT.input) if(value_dragging.connect_type == JUNCTION_CONNECT.input)
var res = value_focus.setFrom(value_dragging); value_dragging.setFrom(target);
else else if(!_addInput)
value_dragging.setFrom(value_focus); target.setFrom(value_dragging);
} else if(target != noone && value_dragging.connect_type == JUNCTION_CONNECT.input) { else { //addInput
value_dragging.setFrom(target); if(array_empty(value_draggings))
} else if(target != noone && value_dragging.connect_type == JUNCTION_CONNECT.output) { target.node.addInput(value_dragging);
node_hovering.addInput(value_dragging); else {
for( var i = 0, n = array_length(value_draggings); i < n; i++ )
target.node.addInput(value_draggings[i]);
}
}
} else { } else {
if(value_dragging.connect_type == JUNCTION_CONNECT.input) if(value_dragging.connect_type == JUNCTION_CONNECT.input)
value_dragging.removeFrom(); value_dragging.removeFrom();
@ -1447,7 +1470,26 @@ function Panel_Graph(project = PROJECT) : PanelContent() constructor {
value_dragging = value_focus; value_dragging = value_focus;
value_draggings = []; value_draggings = [];
if(ds_list_empty(nodes_select_list)) {} if(value_dragging.connect_type == JUNCTION_CONNECT.output) {
var _jlist = ds_priority_create();
for( var i = 0, n = ds_list_size(nodes_select_list); i < n; i++ ) {
var _node = nodes_select_list[| i];
for( var j = 0, m = ds_list_size(_node.outputs); j < m; j++ ) {
var _junction = _node.outputs[| j];
if(!_junction.visible) continue;
if(_junction.type != value_dragging.type) continue;
ds_priority_add(_jlist, _junction, _junction.y);
}
}
while(!ds_priority_empty(_jlist))
array_push(value_draggings, ds_priority_delete_min(_jlist));
ds_priority_destroy(_jlist);
}
} }
#region draw junction name #region draw junction name