In this example, we use the low-level IGraph to first create the
nodes. The size is determined by
the default size.
const node1 = graph.createNode()
const node2 = graph.createNodeAt(new Point(150, 15))
The third node is created by specifying the node layout. We use a size of
[60,30]
. In this case, the X/Y location describes the upper left
corner of the node bounds.
const node3 = graph.createNode(new Rect(230, 200, 60, 30))
Now, let us add some edges to connect the nodes.
graph.createEdge(node1, node2)
const edgeWithBend = graph.createEdge(node2, node3)
We add a bend to the second edge.
graph.addBend(edgeWithBend, new Point(260, 15))
Next, we add two ports to the nodes and connect the ports using an edge.
Note
|
Edges always start and end at ports. In the above example, where we only
specified the nodes, the ports are created implicitly.
|
const port1AtNode1 = graph.addPort(
node1,
FreeNodePortLocationModel.NODE_CENTER_ANCHORED
)
const port1AtNode3 = graph.addPortAt(
node3,
new Point(node3.layout.x, node3.layout.center.y)
)
const edgeAtPorts = graph.createEdge(port1AtNode1, port1AtNode3)
Finally, add labels to the graph items we just created.
graph.addLabel(node1, 'n1')
graph.addLabel(node2, 'n2')
graph.addLabel(node3, 'n3')
graph.addLabel(edgeAtPorts, 'Edge at Ports')