SVGGraphicsElement.h [plain text]
#pragma once
#include "SVGAnimatedTransformList.h"
#include "SVGElement.h"
#include "SVGTests.h"
#include "SVGTransformable.h"
namespace WebCore {
class AffineTransform;
class Path;
class SVGRect;
class SVGMatrix;
class SVGGraphicsElement : public SVGElement, public SVGTransformable, public SVGTests {
WTF_MAKE_ISO_ALLOCATED(SVGGraphicsElement);
public:
virtual ~SVGGraphicsElement();
Ref<SVGMatrix> getCTMForBindings();
AffineTransform getCTM(StyleUpdateStrategy = AllowStyleUpdate) override;
Ref<SVGMatrix> getScreenCTMForBindings();
AffineTransform getScreenCTM(StyleUpdateStrategy = AllowStyleUpdate) override;
SVGElement* nearestViewportElement() const override;
SVGElement* farthestViewportElement() const override;
AffineTransform localCoordinateSpaceTransform(SVGLocatable::CTMScope mode) const override { return SVGTransformable::localCoordinateSpaceTransform(mode); }
AffineTransform animatedLocalTransform() const override;
AffineTransform* supplementalTransform() override;
Ref<SVGRect> getBBoxForBindings();
FloatRect getBBox(StyleUpdateStrategy = AllowStyleUpdate) override;
bool shouldIsolateBlending() const { return m_shouldIsolateBlending; }
void setShouldIsolateBlending(bool isolate) { m_shouldIsolateBlending = isolate; }
virtual Path toClipPath();
RenderPtr<RenderElement> createElementRenderer(RenderStyle&&, const RenderTreePosition&) override;
size_t approximateMemoryCost() const override { return sizeof(*this); }
using AttributeOwnerProxy = SVGAttributeOwnerProxyImpl<SVGGraphicsElement, SVGElement, SVGTests>;
static auto& attributeRegistry() { return AttributeOwnerProxy::attributeRegistry(); }
const auto& transform() const { return m_transform.currentValue(attributeOwnerProxy()); }
auto transformAnimated() { return m_transform.animatedProperty(attributeOwnerProxy()); }
protected:
SVGGraphicsElement(const QualifiedName&, Document&);
bool supportsFocus() const override { return Element::supportsFocus() || hasFocusEventListeners(); }
void parseAttribute(const QualifiedName&, const AtomicString&) override;
void svgAttributeChanged(const QualifiedName&) override;
private:
bool isSVGGraphicsElement() const override { return true; }
const SVGAttributeOwnerProxy& attributeOwnerProxy() const override { return m_attributeOwnerProxy; }
static void registerAttributes();
static bool isKnownAttribute(const QualifiedName& attributeName) { return AttributeOwnerProxy::isKnownAttribute(attributeName); }
std::unique_ptr<AffineTransform> m_supplementalTransform;
bool m_shouldIsolateBlending;
AttributeOwnerProxy m_attributeOwnerProxy { *this };
SVGAnimatedTransformListAttribute m_transform;
};
}
SPECIALIZE_TYPE_TRAITS_BEGIN(WebCore::SVGGraphicsElement)
static bool isType(const WebCore::SVGElement& element) { return element.isSVGGraphicsElement(); }
static bool isType(const WebCore::Node& node) { return is<WebCore::SVGElement>(node) && isType(downcast<WebCore::SVGElement>(node)); }
SPECIALIZE_TYPE_TRAITS_END()