OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2004, 2005, 2006, 2008 Nikolas Zimmermann <zimmermann@kde.org> | 2 * Copyright (C) 2004, 2005, 2006, 2008 Nikolas Zimmermann <zimmermann@kde.org> |
3 * Copyright (C) 2004, 2005, 2006 Rob Buis <buis@kde.org> | 3 * Copyright (C) 2004, 2005, 2006 Rob Buis <buis@kde.org> |
4 * Copyright (C) 2009 Apple Inc. All rights reserved. | 4 * Copyright (C) 2009 Apple Inc. All rights reserved. |
5 * | 5 * |
6 * This library is free software; you can redistribute it and/or | 6 * This library is free software; you can redistribute it and/or |
7 * modify it under the terms of the GNU Library General Public | 7 * modify it under the terms of the GNU Library General Public |
8 * License as published by the Free Software Foundation; either | 8 * License as published by the Free Software Foundation; either |
9 * version 2 of the License, or (at your option) any later version. | 9 * version 2 of the License, or (at your option) any later version. |
10 * | 10 * |
11 * This library is distributed in the hope that it will be useful, | 11 * This library is distributed in the hope that it will be useful, |
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
14 * Library General Public License for more details. | 14 * Library General Public License for more details. |
15 * | 15 * |
16 * You should have received a copy of the GNU Library General Public License | 16 * You should have received a copy of the GNU Library General Public License |
17 * along with this library; see the file COPYING.LIB. If not, write to | 17 * along with this library; see the file COPYING.LIB. If not, write to |
18 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, | 18 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, |
19 * Boston, MA 02110-1301, USA. | 19 * Boston, MA 02110-1301, USA. |
20 */ | 20 */ |
21 | 21 |
22 #ifndef SVGElement_h | 22 #ifndef SVGElement_h |
23 #define SVGElement_h | 23 #define SVGElement_h |
24 | 24 |
25 #include "core/dom/Element.h" | 25 #include "core/dom/Element.h" |
26 #include "core/svg/SVGAnimatedString.h" | 26 #include "core/svg/SVGAnimatedString.h" |
27 #include "core/svg/SVGLangSpace.h" | 27 #include "core/svg/SVGLangSpace.h" |
28 #include "core/svg/SVGLocatable.h" | |
29 #include "core/svg/SVGParsingError.h" | 28 #include "core/svg/SVGParsingError.h" |
30 #include "core/svg/properties/SVGAnimatedPropertyMacros.h" | 29 #include "core/svg/properties/SVGAnimatedPropertyMacros.h" |
31 #include "core/svg/properties/SVGPropertyInfo.h" | 30 #include "core/svg/properties/SVGPropertyInfo.h" |
32 #include "platform/Timer.h" | 31 #include "platform/Timer.h" |
33 #include "wtf/HashMap.h" | 32 #include "wtf/HashMap.h" |
34 | 33 |
35 namespace WebCore { | 34 namespace WebCore { |
36 | 35 |
37 class AffineTransform; | 36 class AffineTransform; |
38 class CSSCursorImageValue; | 37 class CSSCursorImageValue; |
(...skipping 13 matching lines...) Expand all Loading... |
52 virtual ~SVGElement(); | 51 virtual ~SVGElement(); |
53 | 52 |
54 bool isOutermostSVGSVGElement() const; | 53 bool isOutermostSVGSVGElement() const; |
55 | 54 |
56 virtual String title() const; | 55 virtual String title() const; |
57 bool hasRelativeLengths() const { return !m_elementsWithRelativeLengths.isEm
pty(); } | 56 bool hasRelativeLengths() const { return !m_elementsWithRelativeLengths.isEm
pty(); } |
58 virtual bool supportsMarkers() const { return false; } | 57 virtual bool supportsMarkers() const { return false; } |
59 PassRefPtr<CSSValue> getPresentationAttribute(const String& name); | 58 PassRefPtr<CSSValue> getPresentationAttribute(const String& name); |
60 bool isKnownAttribute(const QualifiedName&); | 59 bool isKnownAttribute(const QualifiedName&); |
61 static bool isAnimatableCSSProperty(const QualifiedName&); | 60 static bool isAnimatableCSSProperty(const QualifiedName&); |
62 virtual AffineTransform localCoordinateSpaceTransform(SVGLocatable::CTMScope
) const; | 61 enum CTMScope { |
| 62 NearestViewportScope, // Used by SVGGraphicsElement::getCTM() |
| 63 ScreenScope // Used by SVGGraphicsElement::getScreenCTM() |
| 64 }; |
| 65 virtual AffineTransform localCoordinateSpaceTransform(CTMScope) const; |
63 virtual bool needsPendingResourceHandling() const { return true; } | 66 virtual bool needsPendingResourceHandling() const { return true; } |
64 | 67 |
65 bool instanceUpdatesBlocked() const; | 68 bool instanceUpdatesBlocked() const; |
66 void setInstanceUpdatesBlocked(bool); | 69 void setInstanceUpdatesBlocked(bool); |
67 | 70 |
68 String xmlbase() const; | 71 String xmlbase() const; |
69 void setXMLbase(const String&); | 72 void setXMLbase(const String&); |
70 | 73 |
71 SVGSVGElement* ownerSVGElement() const; | 74 SVGSVGElement* ownerSVGElement() const; |
72 SVGElement* viewportElement() const; | 75 SVGElement* viewportElement() const; |
(...skipping 153 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
226 return DefaultHash<QualifiedName>::Hash::hash(key); | 229 return DefaultHash<QualifiedName>::Hash::hash(key); |
227 } | 230 } |
228 static bool equal(const QualifiedName& a, const QualifiedName& b) { return a
.matches(b); } | 231 static bool equal(const QualifiedName& a, const QualifiedName& b) { return a
.matches(b); } |
229 }; | 232 }; |
230 | 233 |
231 DEFINE_NODE_TYPE_CASTS(SVGElement, isSVGElement()); | 234 DEFINE_NODE_TYPE_CASTS(SVGElement, isSVGElement()); |
232 | 235 |
233 } | 236 } |
234 | 237 |
235 #endif | 238 #endif |
OLD | NEW |