mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-08-12 19:19:30 +00:00
LibWeb: Implement clip property
Implement clip when it is defined in the css property 'clip' as a rect according to spec; only when the div is absolutely positioned.
This commit is contained in:
parent
8163ee1500
commit
5049a56d96
Notes:
sideshowbarker
2024-07-17 08:22:57 +09:00
Author: https://github.com/martinfalisse
Commit: 5049a56d96
Pull-request: https://github.com/SerenityOS/serenity/pull/14730
Reviewed-by: https://github.com/AtkinsSJ
Reviewed-by: https://github.com/MacDue ✅
Reviewed-by: https://github.com/awesomekling
3 changed files with 33 additions and 0 deletions
|
@ -113,7 +113,15 @@ void PaintableBox::paint(PaintContext& context, PaintPhase phase) const
|
|||
if (!is_visible())
|
||||
return;
|
||||
|
||||
auto clip_rect = computed_values().clip();
|
||||
auto should_clip_rect = clip_rect.is_rect() && computed_values().position() == CSS::Position::Absolute;
|
||||
|
||||
if (phase == PaintPhase::Background) {
|
||||
if (should_clip_rect) {
|
||||
context.painter().save();
|
||||
auto border_box = absolute_border_box_rect();
|
||||
context.painter().add_clip_rect(clip_rect.to_rect().resolved(Paintable::layout_node(), border_box).to_rounded<int>());
|
||||
}
|
||||
paint_background(context);
|
||||
paint_box_shadow(context);
|
||||
}
|
||||
|
@ -122,6 +130,9 @@ void PaintableBox::paint(PaintContext& context, PaintPhase phase) const
|
|||
paint_border(context);
|
||||
}
|
||||
|
||||
if (phase == PaintPhase::Overlay && should_clip_rect)
|
||||
context.painter().restore();
|
||||
|
||||
if (phase == PaintPhase::Overlay && layout_box().dom_node() && layout_box().document().inspected_node() == layout_box().dom_node()) {
|
||||
auto content_rect = absolute_rect();
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue