123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404 |
- /****************************************************************************
- **
- ** Copyright (C) 2016 The Qt Company Ltd.
- ** Contact: https://www.qt.io/licensing/
- **
- ** This file is part of the QtGui module of the Qt Toolkit.
- **
- ** $QT_BEGIN_LICENSE:LGPL$
- ** Commercial License Usage
- ** Licensees holding valid commercial Qt licenses may use this file in
- ** accordance with the commercial license agreement provided with the
- ** Software or, alternatively, in accordance with the terms contained in
- ** a written agreement between you and The Qt Company. For licensing terms
- ** and conditions see https://www.qt.io/terms-conditions. For further
- ** information use the contact form at https://www.qt.io/contact-us.
- **
- ** GNU Lesser General Public License Usage
- ** Alternatively, this file may be used under the terms of the GNU Lesser
- ** General Public License version 3 as published by the Free Software
- ** Foundation and appearing in the file LICENSE.LGPL3 included in the
- ** packaging of this file. Please review the following information to
- ** ensure the GNU Lesser General Public License version 3 requirements
- ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
- **
- ** GNU General Public License Usage
- ** Alternatively, this file may be used under the terms of the GNU
- ** General Public License version 2.0 or (at your option) the GNU General
- ** Public license version 3 or any later version approved by the KDE Free
- ** Qt Foundation. The licenses are as published by the Free Software
- ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
- ** included in the packaging of this file. Please review the following
- ** information to ensure the GNU General Public License requirements will
- ** be met: https://www.gnu.org/licenses/gpl-2.0.html and
- ** https://www.gnu.org/licenses/gpl-3.0.html.
- **
- ** $QT_END_LICENSE$
- **
- ****************************************************************************/
- #ifndef QTRANSFORM_H
- #define QTRANSFORM_H
- #include <QtGui/qmatrix.h>
- #include <QtGui/qpainterpath.h>
- #include <QtGui/qpolygon.h>
- #include <QtGui/qregion.h>
- #include <QtGui/qwindowdefs.h>
- #include <QtCore/qline.h>
- #include <QtCore/qpoint.h>
- #include <QtCore/qrect.h>
- QT_BEGIN_NAMESPACE
- class QVariant;
- class Q_GUI_EXPORT QTransform
- {
- public:
- enum TransformationType {
- TxNone = 0x00,
- TxTranslate = 0x01,
- TxScale = 0x02,
- TxRotate = 0x04,
- TxShear = 0x08,
- TxProject = 0x10
- };
- inline explicit QTransform(Qt::Initialization) : affine(Qt::Uninitialized) {}
- QTransform();
- QTransform(qreal h11, qreal h12, qreal h13,
- qreal h21, qreal h22, qreal h23,
- qreal h31, qreal h32, qreal h33 = 1.0);
- QTransform(qreal h11, qreal h12, qreal h21,
- qreal h22, qreal dx, qreal dy);
- explicit QTransform(const QMatrix &mtx);
- #if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
- // ### Qt 6: remove; the compiler-generated ones are fine!
- QTransform &operator=(QTransform &&other) Q_DECL_NOTHROW // = default
- { memcpy(this, &other, sizeof(QTransform)); return *this; }
- QTransform &operator=(const QTransform &) Q_DECL_NOTHROW; // = default
- QTransform(QTransform &&other) Q_DECL_NOTHROW // = default
- : affine(Qt::Uninitialized)
- { memcpy(this, &other, sizeof(QTransform)); }
- QTransform(const QTransform &other) Q_DECL_NOTHROW // = default
- : affine(Qt::Uninitialized)
- { memcpy(this, &other, sizeof(QTransform)); }
- #endif
- bool isAffine() const;
- bool isIdentity() const;
- bool isInvertible() const;
- bool isScaling() const;
- bool isRotating() const;
- bool isTranslating() const;
- TransformationType type() const;
- inline qreal determinant() const;
- qreal det() const;
- qreal m11() const;
- qreal m12() const;
- qreal m13() const;
- qreal m21() const;
- qreal m22() const;
- qreal m23() const;
- qreal m31() const;
- qreal m32() const;
- qreal m33() const;
- qreal dx() const;
- qreal dy() const;
- void setMatrix(qreal m11, qreal m12, qreal m13,
- qreal m21, qreal m22, qreal m23,
- qreal m31, qreal m32, qreal m33);
- QTransform inverted(bool *invertible = Q_NULLPTR) const Q_REQUIRED_RESULT;
- QTransform adjoint() const Q_REQUIRED_RESULT;
- QTransform transposed() const Q_REQUIRED_RESULT;
- QTransform &translate(qreal dx, qreal dy);
- QTransform &scale(qreal sx, qreal sy);
- QTransform &shear(qreal sh, qreal sv);
- QTransform &rotate(qreal a, Qt::Axis axis = Qt::ZAxis);
- QTransform &rotateRadians(qreal a, Qt::Axis axis = Qt::ZAxis);
- static bool squareToQuad(const QPolygonF &square, QTransform &result);
- static bool quadToSquare(const QPolygonF &quad, QTransform &result);
- static bool quadToQuad(const QPolygonF &one,
- const QPolygonF &two,
- QTransform &result);
- bool operator==(const QTransform &) const;
- bool operator!=(const QTransform &) const;
- QTransform &operator*=(const QTransform &);
- QTransform operator*(const QTransform &o) const;
- operator QVariant() const;
- void reset();
- QPoint map(const QPoint &p) const;
- QPointF map(const QPointF &p) const;
- QLine map(const QLine &l) const;
- QLineF map(const QLineF &l) const;
- QPolygonF map(const QPolygonF &a) const;
- QPolygon map(const QPolygon &a) const;
- QRegion map(const QRegion &r) const;
- QPainterPath map(const QPainterPath &p) const;
- QPolygon mapToPolygon(const QRect &r) const;
- QRect mapRect(const QRect &) const;
- QRectF mapRect(const QRectF &) const;
- void map(int x, int y, int *tx, int *ty) const;
- void map(qreal x, qreal y, qreal *tx, qreal *ty) const;
- const QMatrix &toAffine() const;
- QTransform &operator*=(qreal div);
- QTransform &operator/=(qreal div);
- QTransform &operator+=(qreal div);
- QTransform &operator-=(qreal div);
- static QTransform fromTranslate(qreal dx, qreal dy);
- static QTransform fromScale(qreal dx, qreal dy);
- private:
- inline QTransform(qreal h11, qreal h12, qreal h13,
- qreal h21, qreal h22, qreal h23,
- qreal h31, qreal h32, qreal h33, bool)
- : affine(h11, h12, h21, h22, h31, h32, true)
- , m_13(h13), m_23(h23), m_33(h33)
- , m_type(TxNone)
- , m_dirty(TxProject)
- , d(Q_NULLPTR)
- {
- }
- inline QTransform(bool)
- : affine(true)
- , m_13(0), m_23(0), m_33(1)
- , m_type(TxNone)
- , m_dirty(TxNone)
- , d(Q_NULLPTR)
- {
- }
- inline TransformationType inline_type() const;
- QMatrix affine;
- qreal m_13;
- qreal m_23;
- qreal m_33;
- mutable uint m_type : 5;
- mutable uint m_dirty : 5;
- #if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
- class Private;
- Private *d;
- #endif
- };
- Q_DECLARE_TYPEINFO(QTransform, Q_MOVABLE_TYPE);
- Q_GUI_EXPORT Q_DECL_CONST_FUNCTION uint qHash(const QTransform &key, uint seed = 0) Q_DECL_NOTHROW;
- /******* inlines *****/
- inline QTransform::TransformationType QTransform::inline_type() const
- {
- if (m_dirty == TxNone)
- return static_cast<TransformationType>(m_type);
- return type();
- }
- inline bool QTransform::isAffine() const
- {
- return inline_type() < TxProject;
- }
- inline bool QTransform::isIdentity() const
- {
- return inline_type() == TxNone;
- }
- inline bool QTransform::isInvertible() const
- {
- return !qFuzzyIsNull(determinant());
- }
- inline bool QTransform::isScaling() const
- {
- return type() >= TxScale;
- }
- inline bool QTransform::isRotating() const
- {
- return inline_type() >= TxRotate;
- }
- inline bool QTransform::isTranslating() const
- {
- return inline_type() >= TxTranslate;
- }
- inline qreal QTransform::determinant() const
- {
- return affine._m11*(m_33*affine._m22-affine._dy*m_23) -
- affine._m21*(m_33*affine._m12-affine._dy*m_13)+affine._dx*(m_23*affine._m12-affine._m22*m_13);
- }
- inline qreal QTransform::det() const
- {
- return determinant();
- }
- inline qreal QTransform::m11() const
- {
- return affine._m11;
- }
- inline qreal QTransform::m12() const
- {
- return affine._m12;
- }
- inline qreal QTransform::m13() const
- {
- return m_13;
- }
- inline qreal QTransform::m21() const
- {
- return affine._m21;
- }
- inline qreal QTransform::m22() const
- {
- return affine._m22;
- }
- inline qreal QTransform::m23() const
- {
- return m_23;
- }
- inline qreal QTransform::m31() const
- {
- return affine._dx;
- }
- inline qreal QTransform::m32() const
- {
- return affine._dy;
- }
- inline qreal QTransform::m33() const
- {
- return m_33;
- }
- inline qreal QTransform::dx() const
- {
- return affine._dx;
- }
- inline qreal QTransform::dy() const
- {
- return affine._dy;
- }
- inline QTransform &QTransform::operator*=(qreal num)
- {
- if (num == 1.)
- return *this;
- affine._m11 *= num;
- affine._m12 *= num;
- m_13 *= num;
- affine._m21 *= num;
- affine._m22 *= num;
- m_23 *= num;
- affine._dx *= num;
- affine._dy *= num;
- m_33 *= num;
- if (m_dirty < TxScale)
- m_dirty = TxScale;
- return *this;
- }
- inline QTransform &QTransform::operator/=(qreal div)
- {
- if (div == 0)
- return *this;
- div = 1/div;
- return operator*=(div);
- }
- inline QTransform &QTransform::operator+=(qreal num)
- {
- if (num == 0)
- return *this;
- affine._m11 += num;
- affine._m12 += num;
- m_13 += num;
- affine._m21 += num;
- affine._m22 += num;
- m_23 += num;
- affine._dx += num;
- affine._dy += num;
- m_33 += num;
- m_dirty = TxProject;
- return *this;
- }
- inline QTransform &QTransform::operator-=(qreal num)
- {
- if (num == 0)
- return *this;
- affine._m11 -= num;
- affine._m12 -= num;
- m_13 -= num;
- affine._m21 -= num;
- affine._m22 -= num;
- m_23 -= num;
- affine._dx -= num;
- affine._dy -= num;
- m_33 -= num;
- m_dirty = TxProject;
- return *this;
- }
- inline bool qFuzzyCompare(const QTransform& t1, const QTransform& t2)
- {
- return qFuzzyCompare(t1.m11(), t2.m11())
- && qFuzzyCompare(t1.m12(), t2.m12())
- && qFuzzyCompare(t1.m13(), t2.m13())
- && qFuzzyCompare(t1.m21(), t2.m21())
- && qFuzzyCompare(t1.m22(), t2.m22())
- && qFuzzyCompare(t1.m23(), t2.m23())
- && qFuzzyCompare(t1.m31(), t2.m31())
- && qFuzzyCompare(t1.m32(), t2.m32())
- && qFuzzyCompare(t1.m33(), t2.m33());
- }
- /****** stream functions *******************/
- #ifndef QT_NO_DATASTREAM
- Q_GUI_EXPORT QDataStream &operator<<(QDataStream &, const QTransform &);
- Q_GUI_EXPORT QDataStream &operator>>(QDataStream &, QTransform &);
- #endif
- #ifndef QT_NO_DEBUG_STREAM
- Q_GUI_EXPORT QDebug operator<<(QDebug, const QTransform &);
- #endif
- /****** end stream functions *******************/
- // mathematical semantics
- inline QPoint operator*(const QPoint &p, const QTransform &m)
- { return m.map(p); }
- inline QPointF operator*(const QPointF &p, const QTransform &m)
- { return m.map(p); }
- inline QLineF operator*(const QLineF &l, const QTransform &m)
- { return m.map(l); }
- inline QLine operator*(const QLine &l, const QTransform &m)
- { return m.map(l); }
- inline QPolygon operator *(const QPolygon &a, const QTransform &m)
- { return m.map(a); }
- inline QPolygonF operator *(const QPolygonF &a, const QTransform &m)
- { return m.map(a); }
- inline QRegion operator *(const QRegion &r, const QTransform &m)
- { return m.map(r); }
- inline QPainterPath operator *(const QPainterPath &p, const QTransform &m)
- { return m.map(p); }
- inline QTransform operator *(const QTransform &a, qreal n)
- { QTransform t(a); t *= n; return t; }
- inline QTransform operator /(const QTransform &a, qreal n)
- { QTransform t(a); t /= n; return t; }
- inline QTransform operator +(const QTransform &a, qreal n)
- { QTransform t(a); t += n; return t; }
- inline QTransform operator -(const QTransform &a, qreal n)
- { QTransform t(a); t -= n; return t; }
- QT_END_NAMESPACE
- #endif // QTRANSFORM_H
|