1 /****************************************************************************
3 ** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
4 ** All rights reserved.
5 ** Contact: Nokia Corporation (qt-info@nokia.com)
7 ** This file is part of the QtSvg module of the Qt Toolkit.
9 ** $QT_BEGIN_LICENSE:LGPL$
10 ** No Commercial Usage
11 ** This file contains pre-release code and may not be distributed.
12 ** You may use this file in accordance with the terms and conditions
13 ** contained in the Technology Preview License Agreement accompanying
16 ** GNU Lesser General Public License Usage
17 ** Alternatively, this file may be used under the terms of the GNU Lesser
18 ** General Public License version 2.1 as published by the Free Software
19 ** Foundation and appearing in the file LICENSE.LGPL included in the
20 ** packaging of this file. Please review the following information to
21 ** ensure the GNU Lesser General Public License version 2.1 requirements
22 ** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
24 ** In addition, as a special exception, Nokia gives you certain additional
25 ** rights. These rights are described in the Nokia Qt LGPL Exception
26 ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
28 ** If you have questions regarding the use of this file, please contact
29 ** Nokia at qt-info@nokia.com.
40 ****************************************************************************/
42 #ifndef QSVGHANDLER_P_H
43 #define QSVGHANDLER_P_H
49 // This file is not part of the Qt API. It exists purely as an
50 // implementation detail. This header file may change from version to
51 // version without notice, or even be removed.
56 #include "QtXml/qxmlstream.h"
60 #include "QtCore/qhash.h"
61 #include "QtCore/qstack.h"
62 #include "qsvgstyle_p.h"
63 #include "private/qcssparser_p.h"
64 #include "private/qsvggraphics_p.h"
69 class QSvgTinyDocument
;
72 class QSvgStyleSelector
;
73 class QXmlStreamReader
;
75 struct QSvgCssAttribute
77 QXmlStreamStringRef name
;
78 QXmlStreamStringRef value
;
96 QSvgHandler(QIODevice
*device
);
97 QSvgHandler(const QByteArray
&data
);
98 QSvgHandler(QXmlStreamReader
*const data
);
101 QSvgTinyDocument
*document() const;
103 inline bool ok() const {
104 return document() != 0 && !xml
->hasError();
107 inline QString
errorString() const { return xml
->errorString(); }
108 inline int lineNumber() const { return xml
->lineNumber(); }
110 void setDefaultCoordinateSystem(LengthType type
);
111 LengthType
defaultCoordinateSystem() const;
113 void pushColor(const QColor
&color
);
114 void pushColorCopy();
116 QColor
currentColor() const;
118 void setInStyle(bool b
);
119 bool inStyle() const;
121 QSvgStyleSelector
*selector() const;
123 void setAnimPeriod(int start
, int end
);
124 int animationDuration() const;
126 void parseCSStoXMLAttrs(QString css
, QVector
<QSvgCssAttribute
> *attributes
);
128 inline QPen
defaultPen() const
129 { return m_defaultPen
; }
132 bool startElement(const QString
&localName
, const QXmlStreamAttributes
&attributes
);
133 bool endElement(const QStringRef
&localName
);
134 bool characters(const QStringRef
&str
);
135 bool processingInstruction(const QString
&target
, const QString
&data
);
140 QSvgTinyDocument
*m_doc
;
141 QStack
<QSvgNode
*> m_nodes
;
143 QList
<QSvgNode
*> m_resolveNodes
;
151 QStack
<CurrentNode
> m_skipNodes
;
154 Follows the depths of elements. The top is current xml:space
155 value that applies for a given element.
157 QStack
<QSvgText::WhitespaceMode
> m_whitespaceMode
;
159 QSvgRefCounter
<QSvgStyleProperty
> m_style
;
161 LengthType m_defaultCoords
;
163 QStack
<QColor
> m_colorStack
;
164 QStack
<int> m_colorTagCount
;
168 QSvgStyleSelector
*m_selector
;
172 QXmlStreamReader
*const xml
;
173 QCss::Parser m_cssParser
;
175 void resolveGradients(QSvgNode
*node
);
179 * Whether we own the variable xml, and hence whether
180 * we need to delete it.
182 const bool m_ownsReader
;
188 #endif // QSVGHANDLER_P_H