mirror of
https://github.com/Ttanasart-pt/Pixel-Composer.git
synced 2025-01-26 04:48:17 +01:00
multi junctions connect
This commit is contained in:
parent
ef5560ef02
commit
83f2ea53bf
3 changed files with 63 additions and 23 deletions
|
@ -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))
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue