Page describing how to use the graphical user interface.
When waLBerla is built with the default settings, the GUI is not included due to additional dependency on the Qt Library. Use the cmake switch WALBERLA_ENABLE_GUI
to use the GUI and Qt. If you disable this switch in cmake, all dependencies to Qt are removed, the GUI::run() method then only executes timeloop.run()
The graphical user interface needs a StructuredBlockForest and a Timeloop to work. Create a gui object, pass the required arguments, and call GUI::run() instead of timeloop::run()
Example:
\warning The main purpose of the GUI is to debug and inspect internal waLBerla data structures. It is not suited for production runs. It is also not suitable for debugging parallel simulations, since every process opens another window!
No registration of the blockdata at the GUI is required. All fields that are supported are automatically shown in the GUI. To display custom blockdata look at walberla::gui::GUI::createAdaptors() and the class walberla::gui::DisplayAdaptor .
In the screenshot above, the GUI components are annotated with their class names. The walberla::gui::BlockView3D shows all local blocks in a 3D view. The blocks can be dragged out, and dropped on other elements. The drag&drop message contains an walberla::IBlock pointer. The BlockView3D uses a walberla::gui::BlockDisplayObject to draw the single blocks, but is otherwise independent of the other components. The BlockView3D offers the possibility to display slice indicators (planes that cut through blocks). These can be added/removed/recolored by using a public interface.
The most important widget is the walberla::gui::BlockSliceView. Multiple such views can be opened in a QMdiArea, which is managed by the walberla::gui::MainWindow. The BlockSliceView holds a pointer to the globally unique BlockView3D to display slice indicators.
Additionally it holds a pointer to a QStackedWidget (lower left in the screenshot). It adds a widget to the QStackedWidget where the user can edit the display properties. When the BlockSliceView has the focus it makes sure that its own property widget is displayed on top in the QStackedWidget.
To display different blockdata the walberla::gui::DisplayAdaptor is used. A display adaptor knows how to get blockdata out of the block and how to draw it. Each display adaptor may also holds its own state, for storing display options. Each display adaptor usually adds an item ( walberla::gui::DisplayPropertiesItem ) to a tree view in the properties widget.
For common blockdata DisplayAdaptors exists: