mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 17:17:44 +00:00
LibWeb: Flesh out SVGMaskElement a bit
- Add method to resolve the masking area (based on the target element size) - Parse the maskUnits and maskContentUnits attributes
This commit is contained in:
parent
0af8d81f48
commit
650180811e
5 changed files with 55 additions and 6 deletions
|
@ -1,5 +1,6 @@
|
|||
/*
|
||||
* Copyright (c) 2023, Andreas Kling <kling@serenityos.org>
|
||||
* Copyright (c) 2023, MacDue <macdue@dueutil.tech>
|
||||
*
|
||||
* SPDX-License-Identifier: BSD-2-Clause
|
||||
*/
|
||||
|
@ -7,6 +8,7 @@
|
|||
#include <LibWeb/Bindings/SVGMaskElementPrototype.h>
|
||||
#include <LibWeb/DOM/Document.h>
|
||||
#include <LibWeb/Layout/SVGGraphicsBox.h>
|
||||
#include <LibWeb/SVG/AttributeNames.h>
|
||||
#include <LibWeb/SVG/SVGMaskElement.h>
|
||||
|
||||
namespace Web::SVG {
|
||||
|
@ -29,4 +31,34 @@ JS::GCPtr<Layout::Node> SVGMaskElement::create_layout_node(NonnullRefPtr<CSS::St
|
|||
return heap().allocate_without_realm<Layout::SVGGraphicsBox>(document(), *this, move(style));
|
||||
}
|
||||
|
||||
void SVGMaskElement::attribute_changed(DeprecatedFlyString const& name, DeprecatedString const& value)
|
||||
{
|
||||
SVGGraphicsElement::attribute_changed(name, value);
|
||||
if (name == AttributeNames::maskUnits) {
|
||||
m_mask_units = AttributeParser::parse_units(value);
|
||||
} else if (name == AttributeNames::maskContentUnits) {
|
||||
m_mask_content_units = AttributeParser::parse_units(value);
|
||||
}
|
||||
}
|
||||
|
||||
MaskContentUnits SVGMaskElement::mask_content_units() const
|
||||
{
|
||||
return m_mask_content_units.value_or(MaskContentUnits::UserSpaceOnUse);
|
||||
}
|
||||
|
||||
MaskUnits SVGMaskElement::mask_units() const
|
||||
{
|
||||
return m_mask_units.value_or(MaskUnits::ObjectBoundingBox);
|
||||
}
|
||||
|
||||
CSSPixelRect SVGMaskElement::resolve_masking_area(CSSPixelRect const& mask_target) const
|
||||
{
|
||||
if (mask_units() == SVG::MaskUnits::UserSpaceOnUse) {
|
||||
dbgln("SVG: maskUnits=userSpaceOnUse is not supported");
|
||||
return {};
|
||||
}
|
||||
// TODO: Resolve this based on the x, y, width, and height of the mask.
|
||||
return mask_target.inflated(mask_target.size().scaled(CSSPixels(2) / 10));
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue