
This will allow resolving paths that use sizes that are relative to the viewport. This necessarily removes the on element caching, which has been redundant for a while as computed paths are stored on the paintable.
41 lines
1 KiB
C++
41 lines
1 KiB
C++
/*
|
|
* Copyright (c) 2022, Sam Atkins <atkinssj@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibWeb/SVG/SVGAnimatedLength.h>
|
|
#include <LibWeb/SVG/SVGGeometryElement.h>
|
|
|
|
namespace Web::SVG {
|
|
|
|
class SVGLineElement final : public SVGGeometryElement {
|
|
WEB_PLATFORM_OBJECT(SVGLineElement, SVGGeometryElement);
|
|
JS_DECLARE_ALLOCATOR(SVGLineElement);
|
|
|
|
public:
|
|
virtual ~SVGLineElement() override = default;
|
|
|
|
virtual void attribute_changed(FlyString const& name, Optional<String> const& value) override;
|
|
|
|
virtual Gfx::Path get_path(CSSPixelSize viewport_size) override;
|
|
|
|
JS::NonnullGCPtr<SVGAnimatedLength> x1() const;
|
|
JS::NonnullGCPtr<SVGAnimatedLength> y1() const;
|
|
JS::NonnullGCPtr<SVGAnimatedLength> x2() const;
|
|
JS::NonnullGCPtr<SVGAnimatedLength> y2() const;
|
|
|
|
private:
|
|
SVGLineElement(DOM::Document&, DOM::QualifiedName);
|
|
|
|
virtual void initialize(JS::Realm&) override;
|
|
|
|
Optional<float> m_x1;
|
|
Optional<float> m_y1;
|
|
Optional<float> m_x2;
|
|
Optional<float> m_y2;
|
|
};
|
|
|
|
}
|