Ответ 1
ниже ссылки на jsfiddle со скриптами. Все синие блоки перетаскиваются, поэтому вы можете экспериментировать с положением блоков и поведением соединений.
И прошу прощения за столь большой ответ;)
A: Подключение двух конечных точек с одним соединением:
jsPlumb.ready(function() {
// default settings for connectors
var connectionParams = {
connector: ["Flowchart", {cornerRadius:1}],
paintStyle:{
lineWidth: 1,
outlineColor:"blue",
outlineWidth: 0
},
detachable:false,
endpointStyle: { radius:1 }
};
// w2 <=> w1
jsPlumb.connect({
source: "window2",
target: "window1",
anchors: ["TopCenter", "Left"]
}, connectionParams);
// w2 <=> w2
jsPlumb.connect({
source: "window2",
target: "window3",
anchors: ["BottomCenter", "Left"]
}, connectionParams);
//
jsPlumb.draggable(
jsPlumb.getSelector(".window"),
{ containment:".demo"}
);
});
B: Подключение двух конечных точек с одним соединением:
jsPlumb rule: одно соединение между двумя окнами. Поэтому, если вам нужно разделить какое-то соединение в конце, вам нужно создать прокси-точку, которая будет источником для одной вдовы и создаст 2 новых подключения для других окон.
jsPlumb.ready(function() {
// default settings for connectors
var connectionParams = {
connector: ["Flowchart", {cornerRadius:1}],
paintStyle:{
lineWidth: 1,
outlineColor:"green",
outlineWidth: 0
},
detachable:false,
endpointStyle: { radius:1 }
};
// w1 <=> w1s
jsPlumb.connect({
source: "window1",
target: "window1s",
anchors: ["Right", "Center"],
anchor:[ "Perimeter", { shape:"Circle" } ]
}, connectionParams);
// w1s <=> w2
jsPlumb.connect({
source: "window1s",
target: "window2",
anchors: ["Center", "Bottom"]
}, connectionParams);
// w1s <=> w3
jsPlumb.connect({
source: "window1s",
target: "window3",
anchors: ["Center", "Top"]
}, connectionParams);
//
jsPlumb.draggable(
jsPlumb.getSelector(".window"),
{ containment:".demo"}
);
});
C: Подключение трех конечных точек с одним соединением:
Он будет таким же, как в 'B', но с дополнительным скрытым прокси-блоком.
jsPlumb.ready(function() {
// default settings for connectors
var connectionParams = {
connector: ["Flowchart", {cornerRadius:1}],
paintStyle:{
lineWidth: 1,
outlineColor:"blue",
outlineWidth: 0
},
detachable:false,
endpointStyle: { radius:1 }
};
// w1 <=> w1s1
jsPlumb.connect({
source: "window1",
target: "window1s1",
anchors: ["Right", "Center"]
}, connectionParams);
// w1s1 <=> w1s2
jsPlumb.connect({
source: "window1s1",
target: "window1s2",
anchors: ["Center", "Center"]
}, connectionParams);
// w1s1 <=> w2
jsPlumb.connect({
source: "window1s1",
target: "window2",
anchors: ["TopCenter", "Left"]
}, connectionParams);
// w1s1 <=> w3
jsPlumb.connect({
source: "window1s1",
target: "window3",
anchors: ["BottomCenter", "Left"]
}, connectionParams);
// w1s2 <=> w4
jsPlumb.connect({
source: "window1s2",
target: "window4",
anchors: ["Right", "Left"]
}, connectionParams);
//
jsPlumb.draggable(
jsPlumb.getSelector(".window"),
{ containment:".demo"}
);
});