From 3600c34c1dbd11cb61f0e09f96195b7464370fa4 Mon Sep 17 00:00:00 2001 From: MacDue Date: Mon, 4 Jul 2022 21:08:27 +0100 Subject: [PATCH] LibWeb: Support adding a border-radius to elements --- Userland/Libraries/LibWeb/Painting/CanvasPaintable.cpp | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/Userland/Libraries/LibWeb/Painting/CanvasPaintable.cpp b/Userland/Libraries/LibWeb/Painting/CanvasPaintable.cpp index 6699673f31..ea211666b1 100644 --- a/Userland/Libraries/LibWeb/Painting/CanvasPaintable.cpp +++ b/Userland/Libraries/LibWeb/Painting/CanvasPaintable.cpp @@ -31,14 +31,17 @@ void CanvasPaintable::paint(PaintContext& context, PaintPhase phase) const PaintableBox::paint(context, phase); if (phase == PaintPhase::Foreground) { + auto canvas_rect = absolute_rect().to_rounded(); + ScopedCornerRadiusClip corner_clip { context.painter(), canvas_rect, normalized_border_radii_data() }; + // FIXME: This should be done at a different level. Also rect() does not include padding etc! - if (!context.viewport_rect().intersects(enclosing_int_rect(absolute_rect()))) + if (!context.viewport_rect().intersects(canvas_rect)) return; if (layout_box().dom_node().bitmap()) { // FIXME: Remove this const_cast. const_cast(layout_box().dom_node()).present(); - context.painter().draw_scaled_bitmap(absolute_rect().to_rounded(), *layout_box().dom_node().bitmap(), layout_box().dom_node().bitmap()->rect(), 1.0f, to_gfx_scaling_mode(computed_values().image_rendering())); + context.painter().draw_scaled_bitmap(canvas_rect, *layout_box().dom_node().bitmap(), layout_box().dom_node().bitmap()->rect(), 1.0f, to_gfx_scaling_mode(computed_values().image_rendering())); } } }