KDDockWidgets
is a Qt dock widget library written by KDAB, suitable for replacing
QDockWidget
and implementing advanced functionalities missing in Qt.
Although KDDockWidgets
is ready to be used out of the box, it can also be seen
as a framework to allow building very tailored custom docking systems. It tries
to expose every internal widget and every knob for the app developer to tune.
Throughout the years KDAB contributed and funded bug fixes and features to QDockWidget
.
Sadly, this was very painful. Each bug fix or feature took many days of implementation,
and an equal number of days just to fix dozens of regressions.
QDockWidget
mixes GUI code with logic with state, making it very hard
to move forward with new features. Furthermore, our customers were getting more
creative with their requests, so it was clear we needed a better docking framework.
You will find more information in these places:
- Provide advanced docking that QDockWidgets doesn't support
- Native window resize on Windows (allowing for Aero-snap even with custom title bar decorations)
- Arrow drop indicators for great drop precision
- Allow for totally different, user provided, drop indicator types
- Nesting dock widgets in a floating window and docking that group back to main window
- Docking to any main window, not only to the parent main window
- Docking to center of main window, or simply removing the concept of "central widget"
- Main window supporting detachable tabs in center widget
- Detaching arbitrary tabs from a tab bar into a dock area
- Supporting more than 1 main window
- Support for affinities, making some dock widgets only dockable on certain main windows
- Allow to hide TitleBar and just show tabs. Allows dragging via the tab bar.
- Exposing inner helper widgets so the user can customize them or provide his own
- Customize tab widgets
- Customize title bars
- Customize window frames
- Custom widget separators
- Layouting engine honouring min/max size constraints and some size policies
- PySide2 bindings
- Clean codebase
- Not mixing GUI with state with logic with animations
- Great test coverage, even the gui and DnD operations are tested. 200 tests currently.
- Fuzzer for doing random testing and finding bugs
- Lazy separator resize
- Reordering tabs with mouse
- Partial layout save/restore, affecting only a chosen sub-set
- Double click on title bar to maximize
- Double click on separator to distribute equally
- Show close button on tabs
- Allow to make a dock widget non-closable and/or non-dockable
- Optional maximize button on the title bar
- QtQuick support for v1.1
- "Minimization bar" for v1.2
A full demo lives in examples/dockwidgets/
, it showcasts most of the features.
A simpler example lives in examples/minimal/
, which might be more indicated
to learn the API, as it's less overwelming than the full demo.
Open a terminal capable of building Qt5 applications. Make sure you have cmake, ninja, compiler, Qt, etc in PATH.
Adapt the instructions to suit your cmake generator and operating system. Build and install the KDDockWidgets framework:
$ cmake -G Ninja -DCMAKE_INSTALL_PREFIX=/path/where/to/install ../path/to/kddockwidgets
$ make
$ make install
Now build and run the example:
$ cd path/to/kddockwidgets/examples/dockwidgets/
$ cmake -DCMAKE_PREFIX_PATH=/path/where/to/install
$ make
$ ./kddockwidgets_example
The installation directory defaults to c:\KDAB\KDDockWidgets-<version>
on Windows
and /usr/local/KDAB/KDDockWidgets-<version>
on non-Windows. You can change this
location by passing the option -DCMAKE_INSTALL_PREFIX=/install/path
to cmake.
To generate PySide2 bindings, pass -DOPTION_BUILD_PYTHON_BINDINGS=ON
to CMake.
The bindings will be installed to the passed -DCMAKE_INSTALL_PREFIX
. Which
might require setting the PYTHONPATH
env variable to point to that path when
running applications. Alternatively, pass -DPYTHON_BINDINGS_INSTALL_PREFIX=/usr/lib/python3.8/site-packages
to CMake (adjust to the python path on your system).
To run the KDDW python example
$ export PYTHONPATH=/kddw/install/path # Only if needed
$ cd python/examples/
$ rcc -g python -o rc_assets.py ../../examples/dockwidgets/resources_example.qrc
$ python3 main.py
KDDockWidgets requires Qt >= 5.9 (or >=5.12 if Python bindings are enabled). The QtQuick support will require Qt >= 5.15.
KDDockWidgets is (C) 2018-2020, Klarälvdalens Datakonsult AB, and is licensed according to the terms of the GPL 2.0 or GPL 3.0.
Contact KDAB at [email protected] to inquire about commercial licensing.
KDAB will happily accept external contributions; however, all contributions require a signed Copyright Assignment Agreement.
Contact [email protected] for more information.
Please submit your contributions or issue reports from our GitHub space at https://github.com/KDAB/KDDockWidgets
KDDockWidgets is supported and maintained by Klarälvdalens Datakonsult AB (KDAB).
The KDAB Group is the global No.1 software consultancy for Qt, C++ and OpenGL applications across desktop, embedded and mobile platforms.
The KDAB Group provides consulting and mentoring for developing Qt applications from scratch and in porting from all popular and legacy frameworks to Qt. We continue to help develop parts of Qt and are one of the major contributors to the Qt Project. We can give advanced or standard trainings anywhere around the globe on Qt as well as C++, OpenGL, 3D and more.
Please visit https://www.kdab.com to meet the people who write code like this.