Using Plain Java Layout

While layout algorithms can be called directly, it is usually a better idea not to do so except in the simplest of cases. There are several reasons for that:

  1. When calling a layout algorithm directly, your code is hardwired to that implementation and looses a bit of flexibility.

  2. Most importantly, as graphs get more complex there are more and more details to be aware of when executing layout. This is especially true for compound graphs: graphs with nodes that contain further graphs themselves.

The best way to invoke automatic layout is through a fully-fledged implementation of IGraphLayoutEngine. ELK provides a convenient implementation: the RecursiveGraphLayoutEngine.

Using the Recursive Graph Layout Engines

When using the recursive graph layout engine, there is exactly one important method to be aware of:

void layout(KNode layoutGraph, IElkProgressMonitor progressMonitor);

This method provides the entry point to automatic layout and applies the layout algorithms as configured in the layout graph (more details below). To get everything working, follow these steps after you have populated the layout meta data service:

  1. Create an ElkGraph to be laid out (see our graph documentation for how to do so). The ElkGraph will be based on the diagram you want your application to display.

  2. Configure which layout algorithm should be used to layout your graph and how the layout algorithm should layout your graph by setting layout options on the graph’s elements. Check the documentation of the layout algorithm you want to use for which layout properties it supports and what they do, exactly.

  3. Obtain an instance of RecursiveGraphLayoutEngine and call its layout(...) method. Pass it the graph to be laid out as well as a progress monitor to track progress. The progress monitor will allow users to see how long layout will take and to cancel the operation. If you do not care to provide your own progress monitor, simply use BasicProgressMonitor, which is our default implementation. Once the layout(...) method returns, the result will be stored in the layout-related fields of the graph.

  4. Either keep the graph layout engine around to be used again or throw it away.