Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qquickpositioners_p_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
4#ifndef QQUICKPOSITIONERS_P_P_H
5#define QQUICKPOSITIONERS_P_P_H
6
7//
8// W A R N I N G
9// -------------
10//
11// This file is not part of the Qt API. It exists purely as an
12// implementation detail. This header file may change from version to
13// version without notice, or even be removed.
14//
15// We mean it.
16//
17
18#include <QtQuick/private/qtquickglobal_p.h>
19
20QT_REQUIRE_CONFIG(quick_positioners);
21
22#include "qquickpositioners_p.h"
24
25#include <private/qlazilyallocated_p.h>
26
27#include <QtCore/qobject.h>
28#include <QtCore/qstring.h>
29#include <QtCore/qtimer.h>
30
32
34
36{
37 Q_DECLARE_PUBLIC(QQuickBasePositioner)
38
39public:
53 QLazilyAllocated<ExtraData> extra;
54
57#if QT_CONFIG(quick_viewtransitions)
58 , transitioner(0)
59#endif
62
63 {
64 }
65
70
72
74#if QT_CONFIG(quick_viewtransitions)
75 QQuickItemViewTransitioner *transitioner;
76#endif
77
82 if (!positioningDirty) {
83 positioningDirty = true;
84 q->polish();
85 }
86 }
87
91
93
94 void mirrorChange() override {
96 }
97 bool isLeftToRight() const {
99 return true;
100 else
102 }
103
109
111 {
112 if (change.sizeChange())
114 }
115
117 {
119 }
120
122 {
124 int index = q->positionedItems.find(QQuickBasePositioner::PositionedItem(item));
125 if (index >= 0)
126 q->removePositionedItem(&q->positionedItems, index);
127 }
128
130 {
131 return positioner->d_func()->layoutDirection;
132 }
133
135 {
136 if (positioner->d_func()->effectiveLayoutMirror)
137 return positioner->d_func()->layoutDirection == Qt::RightToLeft ? Qt::LeftToRight : Qt::RightToLeft;
138 else
139 return positioner->d_func()->layoutDirection;
140 }
141
143 {
144 }
145
146 inline qreal padding() const { return extra.isAllocated() ? extra->padding : 0.0; }
147 void setTopPadding(qreal value, bool reset = false);
148 void setLeftPadding(qreal value, bool reset = false);
149 void setRightPadding(qreal value, bool reset = false);
150 void setBottomPadding(qreal value, bool reset = false);
151};
152
154
155#endif // QQUICKPOSITIONERS_P_P_H
void watchChanges(QQuickItem *other)
void setLeftPadding(qreal value, bool reset=false)
void itemVisibilityChanged(QQuickItem *) override
static Qt::LayoutDirection getEffectiveLayoutDirection(const QQuickBasePositioner *positioner)
void setBottomPadding(qreal value, bool reset=false)
void itemSiblingOrderChanged(QQuickItem *other) override
void setRightPadding(qreal value, bool reset=false)
void setTopPadding(qreal value, bool reset=false)
void unwatchChanges(QQuickItem *other)
void init(QQuickBasePositioner::PositionerType at)
QQuickBasePositioner::PositionerType type
void itemDestroyed(QQuickItem *item) override
void itemGeometryChanged(QQuickItem *, QQuickGeometryChange change, const QRectF &) override
QLazilyAllocated< ExtraData > extra
static Qt::LayoutDirection getLayoutDirection(const QQuickBasePositioner *positioner)
For specifying a base for QQuickGraphics layouts.
quint32 effectiveLayoutMirror
The QQuickItem class provides the most basic of all visual items in \l {Qt Quick}.
Definition qquickitem.h:63
\inmodule QtCore\reentrant
Definition qrect.h:484
Combined button and popup list for selecting options.
Definition qcompare.h:63
LayoutDirection
@ LeftToRight
@ RightToLeft
EGLOutputLayerEXT EGLint EGLAttrib value
[5]
@ None
Definition qhash.cpp:531
GLuint index
[2]
GLenum type
GLboolean reset
GLdouble GLdouble GLdouble GLdouble q
Definition qopenglext.h:259
#define QT_CONFIG(feature)
#define QT_REQUIRE_CONFIG(feature)
#define Q_UNUSED(x)
double qreal
Definition qtypes.h:187
if(qFloatDistance(a, b)<(1<< 7))
[0]
QSharedPointer< T > other(t)
[5]
QGraphicsItem * item
QAction * at