mirror of
https://github.com/RGBCube/serenity
synced 2025-07-25 22:57:44 +00:00
LibWeb: Convert Layout Boxes to new pixel units
This commit is contained in:
parent
c70dcaefcd
commit
65cdf89a8b
11 changed files with 29 additions and 28 deletions
|
@ -25,8 +25,8 @@ RefPtr<Painting::Paintable> SVGSVGBox::create_paintable() const
|
|||
void SVGSVGBox::prepare_for_replaced_layout()
|
||||
{
|
||||
if (dom_node().has_attribute(HTML::AttributeNames::width) && dom_node().has_attribute(HTML::AttributeNames::height)) {
|
||||
Optional<float> w;
|
||||
Optional<float> h;
|
||||
Optional<CSSPixels> w;
|
||||
Optional<CSSPixels> h;
|
||||
if (auto width = HTML::parse_dimension_value(dom_node().attribute(HTML::AttributeNames::width))) {
|
||||
if (width->has_length())
|
||||
w = width->to_length().to_px(*this);
|
||||
|
@ -38,14 +38,14 @@ void SVGSVGBox::prepare_for_replaced_layout()
|
|||
if (w.has_value() && h.has_value()) {
|
||||
set_intrinsic_width(*w);
|
||||
set_intrinsic_height(*h);
|
||||
set_intrinsic_aspect_ratio(*w / *h);
|
||||
set_intrinsic_aspect_ratio(w->value() / h->value());
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
Optional<Gfx::FloatRect> united_rect;
|
||||
Optional<CSSPixelRect> united_rect;
|
||||
|
||||
auto add_to_united_rect = [&](Gfx::FloatRect const& rect) {
|
||||
auto add_to_united_rect = [&](CSSPixelRect const& rect) {
|
||||
if (united_rect.has_value())
|
||||
united_rect = united_rect->united(rect);
|
||||
else
|
||||
|
@ -55,7 +55,7 @@ void SVGSVGBox::prepare_for_replaced_layout()
|
|||
for_each_in_subtree_of_type<SVGGeometryBox>([&](SVGGeometryBox const& geometry_box) {
|
||||
auto& dom_node = const_cast<SVG::SVGGeometryElement&>(geometry_box.dom_node());
|
||||
if (dom_node.has_attribute(HTML::AttributeNames::width) && dom_node.has_attribute(HTML::AttributeNames::height)) {
|
||||
Gfx::FloatRect rect;
|
||||
CSSPixelRect rect;
|
||||
// FIXME: Allow for relative lengths here
|
||||
rect.set_width(computed_values().width().resolved(*this, CSS::Length::make_px(0)).to_px(*this));
|
||||
rect.set_height(computed_values().height().resolved(*this, CSS::Length::make_px(0)).to_px(*this));
|
||||
|
@ -64,7 +64,7 @@ void SVGSVGBox::prepare_for_replaced_layout()
|
|||
}
|
||||
|
||||
auto& path = dom_node.get_path();
|
||||
auto path_bounding_box = path.bounding_box();
|
||||
auto path_bounding_box = path.bounding_box().to_type<CSSPixels>();
|
||||
|
||||
// Stroke increases the path's size by stroke_width/2 per side.
|
||||
auto stroke_width = geometry_box.dom_node().stroke_width().value_or(0);
|
||||
|
@ -74,7 +74,7 @@ void SVGSVGBox::prepare_for_replaced_layout()
|
|||
|
||||
if (maybe_view_box.has_value()) {
|
||||
auto view_box = maybe_view_box.value();
|
||||
Gfx::FloatRect rect(view_box.min_x, view_box.min_y, view_box.width, view_box.height);
|
||||
CSSPixelRect rect(view_box.min_x, view_box.min_y, view_box.width, view_box.height);
|
||||
add_to_united_rect(rect);
|
||||
return IterationDecision::Continue;
|
||||
}
|
||||
|
@ -86,7 +86,7 @@ void SVGSVGBox::prepare_for_replaced_layout()
|
|||
if (united_rect.has_value()) {
|
||||
set_intrinsic_width(united_rect->width());
|
||||
set_intrinsic_height(united_rect->height());
|
||||
set_intrinsic_aspect_ratio(united_rect->width() / united_rect->height());
|
||||
set_intrinsic_aspect_ratio(united_rect->width().value() / united_rect->height().value());
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue