Qt
Internal/Contributor docs for the Qt SDK. Note: These are NOT official API docs; those are found at https://doc.qt.io/
Loading...
Searching...
No Matches
qdockarealayout_p.h
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3// Qt-Security score:significant reason:default
4
5#ifndef QDOCKAREALAYOUT_P_H
6#define QDOCKAREALAYOUT_P_H
7
8//
9// W A R N I N G
10// -------------
11//
12// This file is not part of the Qt API. It exists purely as an
13// implementation detail. This header file may change from version to
14// version without notice, or even be removed.
15//
16// We mean it.
17//
18
19#include <QtWidgets/private/qtwidgetsglobal_p.h>
20#include <QtWidgets/private/qwidgetanimator_p.h>
21#include "QtWidgets/qlayout.h"
22#include "QtCore/qlist.h"
23#include "QtCore/qloggingcategory.h"
24#include "QtCore/qrect.h"
25
26#include <array>
27
29
31
33
34class QLayoutItem;
35class QWidget;
36class QLayoutItem;
37class QDockAreaLayoutInfo;
38class QPlaceHolderItem;
39class QDockWidget;
40class QMainWindow;
41class QWidgetAnimator;
42class QMainWindowLayout;
43struct QLayoutStruct;
44class QTabBar;
45
46// The classes in this file represent the tree structure that represents all the docks
47// Also see the wiki internal documentation
48// At the root of the tree is: QDockAreaLayout, which handles all 4 sides, so there is only one.
49// For each side it has one QDockAreaLayoutInfo child. (See QDockAreaLayout::docks.)
50// The QDockAreaLayoutInfo have QDockAreaLayoutItems as children (See QDockAreaLayoutInfo::item_list),
51// which then has one QDockAreaLayoutInfo as a child. (QDockAreaLayoutItem::subInfo) or
52// a widgetItem if this is a node of the tree (QDockAreaLayoutItem::widgetItem)
53//
54// A path identifies uniquely one object in this tree, the first number being the side and all the following
55// indexes into the QDockAreaLayoutInfo::item_list.
56
57struct Q_AUTOTEST_EXPORT QDockAreaLayoutItem
58{
59 enum ItemFlags { NoFlags = 0, GapItem = 1, KeepSize = 2 };
60
61 explicit QDockAreaLayoutItem(QLayoutItem *_widgetItem = nullptr);
62 explicit QDockAreaLayoutItem(QDockAreaLayoutInfo *_subinfo);
63 explicit QDockAreaLayoutItem(QPlaceHolderItem *_placeHolderItem);
64 QDockAreaLayoutItem(const QDockAreaLayoutItem &other);
65 ~QDockAreaLayoutItem();
66
67 QDockAreaLayoutItem &operator = (const QDockAreaLayoutItem &other);
68
69 bool skip() const;
70 QSize minimumSize() const;
71 QSize maximumSize() const;
72 QSize sizeHint() const;
73 bool expansive(Qt::Orientation o) const;
74 bool hasFixedSize(Qt::Orientation o) const;
75
76 QLayoutItem *widgetItem;
77 QDockAreaLayoutInfo *subinfo;
78 QPlaceHolderItem *placeHolderItem;
79 int pos;
80 int size;
81 uint flags;
82#ifndef QT_NO_DEBUG_STREAM
83 friend Q_AUTOTEST_EXPORT QDebug operator<<(QDebug dbg, const QDockAreaLayoutItem &item);
84 friend Q_AUTOTEST_EXPORT QDebug operator<<(QDebug dbg, const QDockAreaLayoutItem *item);
85#endif
86};
87
88class Q_AUTOTEST_EXPORT QPlaceHolderItem
89{
90public:
91 QPlaceHolderItem() : hidden(false), window(false) {}
92 explicit QPlaceHolderItem(QWidget *w);
93
94 QString objectName;
95 bool hidden, window;
96 QRect topLevelRect;
97};
98
99class Q_AUTOTEST_EXPORT QDockAreaLayoutInfo
100{
101public:
102 QDockAreaLayoutInfo();
103 QDockAreaLayoutInfo(const int *_sep, QInternal::DockPosition _dockPos, Qt::Orientation _o,
104 int tbhape, QMainWindow *window);
105
106 QSize minimumSize() const;
107 QSize maximumSize() const;
108 QSize sizeHint() const;
109 QSize size() const;
110
111 bool insertGap(const QList<int> &path, QLayoutItem *dockWidgetItem);
112 QLayoutItem *plug(const QList<int> &path);
113 QLayoutItem *unplug(const QList<int> &path);
114 enum TabMode { NoTabs, AllowTabs, ForceTabs };
115 QList<int> gapIndex(const QPoint &pos, bool nestingEnabled,
116 TabMode tabMode) const;
117 void remove(const QList<int> &path);
118 void remove(QWidget *widget);
119 void unnest(int index);
120 void split(int index, Qt::Orientation orientation, QLayoutItem *dockWidgetItem);
121#if QT_CONFIG(tabbar)
122 void tab(int index, QLayoutItem *dockWidgetItem);
123#endif
124 QDockAreaLayoutItem &item(const QList<int> &path);
125 QDockAreaLayoutInfo *info(const QList<int> &path);
126 QDockAreaLayoutInfo *info(QWidget *widget);
127
128 void saveState(QDataStream &stream) const;
129 bool restoreState(QDataStream &stream, QList<QDockWidget*> &widgets, QInternal::CallMode);
130
131 void fitItems();
132 bool expansive(Qt::Orientation o) const;
133 int changeSize(int index, int size, bool below);
134 QRect itemRect(int index, bool isGap = false) const;
135 QRect itemRect(const QList<int> &path) const;
136 QRect separatorRect(int index) const;
137 QRect separatorRect(const QList<int> &path) const;
138
139 void clear();
140 bool isEmpty() const;
141 bool hasGapItem(const QList<int> &path) const;
142 bool onlyHasPlaceholders() const;
143 bool hasFixedSize() const;
144 QList<int> findSeparator(const QPoint &pos) const;
145 int next(int idx) const;
146 int prev(int idx) const;
147
148 QList<int> indexOf(const QWidget *widget) const;
149 QList<int> indexOfPlaceHolder(const QString &objectName) const;
150 std::unique_ptr<QLayoutItem> takeWidgetItem(QWidget *widget);
151
152 QDockWidget *apply(QWidgetAnimator::AnimationRule rule);
153
154 void paintSeparators(QPainter *p, QWidget *widget, const QRegion &clip,
155 const QPoint &mouse) const;
156 QRegion separatorRegion() const;
157 int separatorMove(int index, int delta);
158 int separatorMove(const QList<int> &separator, const QPoint &origin, const QPoint &dest);
159
160 QLayoutItem *itemAt(int *x, int index) const;
161 QLayoutItem *takeAt(int *x, int index);
162 void add(QWidget *widget);
163 void deleteAllLayoutItems();
164
165 QMainWindowLayout *mainWindowLayout() const;
166
167 const int *sep;
168 mutable QList<QWidget *> separatorWidgets;
169 QInternal::DockPosition dockPos;
170 Qt::Orientation o;
171 QRect rect;
172 QMainWindow *mainWindow;
173 QList<QDockAreaLayoutItem> item_list;
174#if QT_CONFIG(tabbar)
175 void updateSeparatorWidgets() const;
176 QSet<QWidget*> usedSeparatorWidgets() const;
177
178 quintptr currentTabId() const;
179 void setCurrentTab(QWidget *widget);
180 void setCurrentTabId(quintptr id);
181 QRect tabContentRect() const;
182 bool tabbed;
183 QTabBar *tabBar;
184 int tabBarShape;
185
186 void reparentWidgets(QWidget *p);
187 bool updateTabBar() const;
188 void setTabBarShape(int shape);
189 QSize tabBarMinimumSize() const;
190 QSize tabBarSizeHint() const;
191
192 QSet<QTabBar*> usedTabBars() const;
193
194 int tabIndexToListIndex(int) const;
195 void moveTab(int from, int to);
196#endif // QT_CONFIG(tabbar)
197};
198
199using QDockAreaLayoutCorners = std::array<Qt::DockWidgetArea, 4>;
200
201class Q_AUTOTEST_EXPORT QDockAreaLayout
202{
203public:
204 enum { EmptyDropAreaSize = 80 }; // when a dock area is empty, how "wide" is it?
205
206 QDockAreaLayoutCorners corners; // use a Qt::Corner for indexing
207 QRect rect;
208 QLayoutItem *centralWidgetItem;
209 QMainWindow *mainWindow;
210 QRect centralWidgetRect;
211 QDockAreaLayout(QMainWindow *win);
212 std::array<QDockAreaLayoutInfo, 4> docks;
213 int sep; // margin between a dock widget and its frame
214 bool fallbackToSizeHints; //determines if we should use the sizehint for the dock areas (true until the layout is restored or the separator is moved by user)
215 mutable QList<QWidget *> separatorWidgets;
216
217 bool isValid() const;
218
219 static QRect constrainedRect(QRect rect, QWidget *widget);
220 void saveState(QDataStream &stream) const;
221 bool restoreState(QDataStream &stream, const QList<QDockWidget*> &_dockWidgets, QInternal::CallMode callMode);
222
223 QList<int> indexOfPlaceHolder(const QString &objectName) const;
224 QList<int> indexOf(const QWidget *dockWidget) const;
225 QList<int> gapIndex(const QPoint &pos, bool disallowTabs) const;
226 QList<int> findSeparator(const QPoint &pos) const;
227
228 QDockAreaLayoutItem &item(const QList<int> &path);
229 QDockAreaLayoutInfo *info(const QList<int> &path);
230 const QDockAreaLayoutInfo *info(const QList<int> &path) const;
231 QDockAreaLayoutInfo *info(QWidget *widget);
232 QRect itemRect(const QList<int> &path) const;
233 QRect separatorRect(int index) const;
234 QRect separatorRect(const QList<int> &path) const;
235
236 bool insertGap(const QList<int> &path, QLayoutItem *dockWidgetItem);
237 QLayoutItem *plug(const QList<int> &path);
238 QLayoutItem *unplug(const QList<int> &path);
239 void remove(const QList<int> &path);
240 void removePlaceHolder(const QString &name);
241
242 void fitLayout();
243
244 void clear();
245
246 QSize sizeHint() const;
247 QSize minimumSize() const;
248 QSize minimumStableSize() const;
249 template<typename SizePMF, typename CenterPMF>
250 QSize size_helper(SizePMF sizeFn, CenterPMF centerFn) const;
251
252 void addDockWidget(QInternal::DockPosition pos, QDockWidget *dockWidget, Qt::Orientation orientation);
253 bool restoreDockWidget(QDockWidget *dockWidget);
254 void splitDockWidget(QDockWidget *after, QDockWidget *dockWidget,
255 Qt::Orientation orientation);
256#if QT_CONFIG(tabbar)
257 void tabifyDockWidget(QDockWidget *first, QDockWidget *second);
258#endif
259 void resizeDocks(const QList<QDockWidget *> &docks, const QList<int> &sizes, Qt::Orientation o);
260
261 void apply(QWidgetAnimator::AnimationRule rule);
262
263 void paintSeparators(QPainter *p, QWidget *widget, const QRegion &clip,
264 const QPoint &mouse) const;
265 QRegion separatorRegion() const;
266 int separatorMove(const QList<int> &separator, const QPoint &origin, const QPoint &dest);
267#if QT_CONFIG(tabbar)
268 void updateSeparatorWidgets() const;
269#endif // QT_CONFIG(tabbar)
270
271 QLayoutItem *itemAt(int *x, int index) const;
272 QLayoutItem *takeAt(int *x, int index);
273 void deleteAllLayoutItems();
274
275 void getGrid(QList<QLayoutStruct> *ver_struct_list, QList<QLayoutStruct> *hor_struct_list);
276 void setGrid(QList<QLayoutStruct> *ver_struct_list, QList<QLayoutStruct> *hor_struct_list);
277
278 QRect gapRect(const QList<int> &path) const;
279 QRect gapRect(QInternal::DockPosition dockPos) const;
280
281 void keepSize(QDockWidget *w);
282#if QT_CONFIG(tabbar)
283 QSet<QTabBar*> usedTabBars() const;
284 QSet<QWidget*> usedSeparatorWidgets() const;
285#endif // QT_CONFIG(tabbar)
286 void styleChangedEvent();
287};
288
289QT_END_NAMESPACE
290
291#endif // QDOCKAREALAYOUT_P_H
friend class QWidget
Definition qpainter.h:432
Combined button and popup list for selecting options.
static int grow(QLayoutStruct &ls, int delta)
static QRect dockedGeometry(QWidget *widget)
static Qt::DockWidgetArea toDockWidgetArea(QInternal::DockPosition pos)
static int realMinSize(const QDockAreaLayoutInfo &info)
static int qMax(int i1, int i2, int i3)
static int shrink(QLayoutStruct &ls, int delta)
Q_DECLARE_FLAGS(StateFlags, StateFlag)
static const int zero
static int separatorMoveHelper(QList< QLayoutStruct > &list, int index, int delta, int sep)
static QInternal::DockPosition dockPosHelper(const QRect &rect, const QPoint &_pos, Qt::Orientation o, bool nestingEnabled, QDockAreaLayoutInfo::TabMode tabMode)
static void paintSep(QPainter *p, QWidget *w, const QRect &r, Qt::Orientation o, bool mouse_over)
static int realMaxSize(const QDockAreaLayoutInfo &info)
QMainWindowLayout * qt_mainwindow_layout(const QMainWindow *window)
QT_REQUIRE_CONFIG(dockwidget)
QT_BEGIN_NAMESPACE Q_DECLARE_LOGGING_CATEGORY(lcQIORing)