mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-12-04 13:30:31 +00:00
LibWeb: Resolve SVG "scaled viewport size" without triggering layout
Percentage stroke widths are resolved against the scaled viewport size which we were retrieving by calling client_width() and client_height() on the element. Now that those accessors may trigger layout, this means that we can't use them from the stroke_width() getter, which is itself used *from within* layout.
This commit is contained in:
parent
5e35167e05
commit
b5faeb7840
Notes:
sideshowbarker
2024-07-17 12:08:25 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/b5faeb7840
1 changed files with 11 additions and 1 deletions
|
@ -6,7 +6,9 @@
|
|||
*/
|
||||
|
||||
#include <LibWeb/CSS/Parser/Parser.h>
|
||||
#include <LibWeb/Layout/Node.h>
|
||||
#include <LibWeb/SVG/SVGGraphicsElement.h>
|
||||
#include <LibWeb/SVG/SVGSVGElement.h>
|
||||
|
||||
namespace Web::SVG {
|
||||
|
||||
|
@ -64,7 +66,15 @@ Optional<float> SVGGraphicsElement::stroke_width() const
|
|||
if (auto width = layout_node()->computed_values().stroke_width(); width.has_value()) {
|
||||
// Resolved relative to the "Scaled viewport size": https://www.w3.org/TR/2017/WD-fill-stroke-3-20170413/#scaled-viewport-size
|
||||
// FIXME: This isn't right, but it's something.
|
||||
auto scaled_viewport_size = CSS::Length::make_px((client_width() + client_height()) * 0.5f);
|
||||
float viewport_width = 0;
|
||||
float viewport_height = 0;
|
||||
if (auto* svg_svg_element = first_ancestor_of_type<SVGSVGElement>()) {
|
||||
if (auto* svg_svg_layout_node = svg_svg_element->layout_node()) {
|
||||
viewport_width = svg_svg_layout_node->computed_values().width().value().resolved(*svg_svg_layout_node, { 0, CSS::Length::Type::Px }).to_px(*svg_svg_layout_node);
|
||||
viewport_height = svg_svg_layout_node->computed_values().height().value().resolved(*svg_svg_layout_node, { 0, CSS::Length::Type::Px }).to_px(*svg_svg_layout_node);
|
||||
}
|
||||
}
|
||||
auto scaled_viewport_size = CSS::Length::make_px((viewport_width + viewport_height) * 0.5f);
|
||||
return width->resolved(*layout_node(), scaled_viewport_size).to_px(*layout_node());
|
||||
}
|
||||
return {};
|
||||
|
|
Loading…
Reference in a new issue