1 /****************************************************************************
3 ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
4 ** Contact: http://www.qt-project.org/
6 ** This file is part of the QtGui module of the Qt Toolkit.
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** GNU Lesser General Public License Usage
10 ** This file may be used under the terms of the GNU Lesser General Public
11 ** License version 2.1 as published by the Free Software Foundation and
12 ** appearing in the file LICENSE.LGPL included in the packaging of this
13 ** file. Please review the following information to ensure the GNU Lesser
14 ** General Public License version 2.1 requirements will be met:
15 ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
17 ** In addition, as a special exception, Nokia gives you certain additional
18 ** rights. These rights are described in the Nokia Qt LGPL Exception
19 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
21 ** GNU General Public License Usage
22 ** Alternatively, this file may be used under the terms of the GNU General
23 ** Public License version 3.0 as published by the Free Software Foundation
24 ** and appearing in the file LICENSE.GPL included in the packaging of this
25 ** file. Please review the following information to ensure the GNU General
26 ** Public License version 3.0 requirements will be met:
27 ** http://www.gnu.org/copyleft/gpl.html.
30 ** Alternatively, this file may be used in accordance with the terms and
31 ** conditions contained in a signed written agreement between you and Nokia.
40 ****************************************************************************/
42 #ifndef QCOSMETICSTROKER_P_H
43 #define QCOSMETICSTROKER_P_H
45 #include <private/qdrawhelper_p.h>
46 #include <private/qvectorpath_p.h>
47 #include <private/qpaintengine_raster_p.h>
55 class QCosmeticStroker;
58 typedef void (*StrokeLine)(QCosmeticStroker *stroker, qreal x1, qreal y1, qreal x2, qreal y2, int caps);
60 class QCosmeticStroker
78 // used to avoid drop outs or duplicated points
88 QCosmeticStroker(QRasterPaintEngineState *s, const QRect &dr)
98 lastAxisAligned(false)
100 ~QCosmeticStroker() { free(pattern); free(reversePattern); }
101 void drawLine(const QPointF &p1, const QPointF &p2);
102 void drawPath(const QVectorPath &path);
103 void drawPoints(const QPoint *points, int num);
104 void drawPoints(const QPointF *points, int num);
107 QRasterPaintEngineState *state;
109 // clip bounds in real
122 enum { NSPANS = 255 };
123 QT_FT_Span spans[NSPANS];
135 bool lastAxisAligned;
140 void renderCubic(const QPointF &p1, const QPointF &p2, const QPointF &p3, const QPointF &p4, int caps);
141 void renderCubicSubdivision(PointF *points, int level, int caps);
142 // used for closed subpaths
143 void calculateLastPoint(qreal rx1, qreal ry1, qreal rx2, qreal ry2);
146 bool clipLine(qreal &x1, qreal &y1, qreal &x2, qreal &y2);
153 #endif // QCOSMETICLINE_H