Constructs a new layout using the given layouts. The graph instance is required for creating the transaction that contains all layouts.
Reference to the enclosing Graph.
Array of GraphLayouts.
Optional
master: GraphLayoutOptional layout that handles moves. If no layout is given, then the first layout of the above array is used to handle moves.
Reference to the enclosing Graph.
Holds the array of GraphLayouts that this layout contains.
Optional
masterReference to the GraphLayouts that handles moves. If this is null
then the first layout in
The parent cell of the layout, if any
Boolean indicating if the bounding box of the label should be used if it iss available.
Shortcut to Graph#updateGroupBounds with moveGroup set to true.
Implements GraphLayout#execute by executing all layouts in a single transaction.
Returns the constraint for the given key and cell. The optional edge and source arguments are used to return inbound and outgoing routing- constraints for the given edge and vertex. This implementation always returns the value for the given key in the style of the given cell.
Key of the constraint to be returned.
Cell whose constraint should be returned.
Optional
edge: CellOptional Cell that represents the connection whose constraint should be returned. Default is null.
Optional
source: booleanOptional boolean that specifies if the connection is incoming or outgoing. Default is null.
Sets the new position of the given cell taking into account the size of the bounding box if useBoundingBox is true. The change is only carried out if the new location is not equal to the existing location, otherwise the geometry is not replaced with an updated instance. The new or old bounds are returned (including overlapping labels).
Traverses the (directed) graph invoking the given function for each visited vertex and edge. The function is invoked with the current vertex and the incoming edge as a parameter. This implementation makes sure each vertex is only visited once. The function may return false if the traversal should stop at the given vertex.
Example:
GlobalConfig.logger.show();
const cell = graph.getSelectionCell();
graph.traverse(cell, false, function(vertex, edge)
{
GlobalConfig.logger.debug(graph.getLabel(vertex));
});
Allows to compose multiple layouts into a single layout.
The master layout is the layout that handles move operations if another layout than the first element in GraphLayouts should be used. The master layout is not executed as the code assumes that it is part of layouts.
Example: