1
/****************************************************************************
3
** Copyright (C) 1992-2005 Trolltech AS. All rights reserved.
5
** This file is part of the painting module of the Qt Toolkit.
7
** This file may be distributed under the terms of the Q Public License
8
** as defined by Trolltech AS of Norway and appearing in the file
9
** LICENSE.QPL included in the packaging of this file.
11
** This file may be distributed and/or modified under the terms of the
12
** GNU General Public License version 2 as published by the Free Software
13
** Foundation and appearing in the file LICENSE.GPL included in the
14
** packaging of this file.
16
** See http://www.trolltech.com/pricing.html or email sales@trolltech.com for
17
** information about Qt Commercial License Agreements.
18
** See http://www.trolltech.com/qpl/ for QPL licensing information.
19
** See http://www.trolltech.com/gpl/ for GPL licensing information.
21
** Contact info@trolltech.com if any conditions of this licensing are
24
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
25
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
27
****************************************************************************/
32
#include "QtCore/qvector.h"
33
#include "QtCore/qpoint.h"
34
#include "QtCore/qrect.h"
40
class Q_GUI_EXPORT QPolygon : public QVector<QPoint>
45
inline QPolygon(int size);
46
inline QPolygon(const QPolygon &a) : QVector<QPoint>(a) {}
47
inline QPolygon(const QVector<QPoint> &v) : QVector<QPoint>(v) {}
48
QPolygon(const QRect &r, bool closed=false);
49
QPolygon(int nPoints, const int *points);
50
operator QVariant() const;
52
void translate(int dx, int dy);
53
void translate(const QPoint &offset);
54
QRect boundingRect() const;
56
void point(int i, int *x, int *y) const;
57
QPoint point(int i) const;
58
void setPoint(int index, int x, int y);
59
void setPoint(int index, const QPoint &p);
60
void setPoints(int nPoints, const int *points);
61
void setPoints(int nPoints, int firstx, int firsty, ...);
62
void putPoints(int index, int nPoints, const int *points);
63
void putPoints(int index, int nPoints, int firstx, int firsty, ...);
64
void putPoints(int index, int nPoints, const QPolygon & from, int fromIndex=0);
67
inline QPolygon::QPolygon(int asize) : QVector<QPoint>(asize) {}
69
#ifndef QT_NO_DEBUG_STREAM
70
Q_GUI_EXPORT QDebug operator<<(QDebug, const QPolygon &);
73
/*****************************************************************************
74
Misc. QPolygon functions
75
*****************************************************************************/
77
inline void QPolygon::setPoint(int index, const QPoint &pt)
78
{ (*this)[index] = pt; }
80
inline void QPolygon::setPoint(int index, int x, int y)
81
{ (*this)[index] = QPoint(x, y); }
83
inline QPoint QPolygon::point(int index) const
86
inline void QPolygon::translate(const QPoint &offset)
87
{ translate(offset.x(), offset.y()); }
91
class Q_GUI_EXPORT QPolygonF : public QVector<QPointF>
95
inline ~QPolygonF() {}
96
inline QPolygonF(int size);
97
inline QPolygonF(const QPolygonF &a) : QVector<QPointF>(a) {}
98
inline QPolygonF(const QVector<QPointF> &v) : QVector<QPointF>(v) {}
99
QPolygonF(const QRectF &r);
100
QPolygonF(const QPolygon &a);
102
inline void translate(qreal dx, qreal dy);
103
void translate(const QPointF &offset);
105
QPolygon toPolygon() const;
107
bool isClosed() const { return !isEmpty() && first() == last(); }
109
QRectF boundingRect() const;
112
inline QPolygonF::QPolygonF(int asize) : QVector<QPointF>(asize) {}
114
#ifndef QT_NO_DEBUG_STREAM
115
Q_GUI_EXPORT QDebug operator<<(QDebug, const QPolygonF &);
118
/*****************************************************************************
119
QPolygonF stream functions
120
*****************************************************************************/
121
#ifndef QT_NO_DATASTREAM
122
Q_GUI_EXPORT QDataStream &operator<<(QDataStream &stream, const QPolygonF &array);
123
Q_GUI_EXPORT QDataStream &operator>>(QDataStream &stream, QPolygonF &array);
126
inline void QPolygonF::translate(qreal dx, qreal dy)
127
{ translate(QPointF(dx, dy)); }