mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 09:04:59 +00:00
LibWeb+WebContent: Move paint recording init into Navigable
This refactoring makes WebContent less aware of LibWeb internals. The code that initializes paint recording commands now resides in `Navigable::paint()`. Additionally, we no longer need to reuse PaintContext across iframes, allowing us to avoid saving and restoring its state before recursing into an iframe.
This commit is contained in:
parent
72dd37438d
commit
cc447c9c80
6 changed files with 65 additions and 47 deletions
|
@ -171,48 +171,18 @@ Web::Layout::Viewport* PageClient::layout_root()
|
|||
return document->layout_node();
|
||||
}
|
||||
|
||||
Gfx::Color PageClient::background_color() const
|
||||
{
|
||||
auto document = page().top_level_browsing_context().active_document();
|
||||
if (!document)
|
||||
return Gfx::Color::Transparent;
|
||||
return document->background_color();
|
||||
}
|
||||
|
||||
void PageClient::paint(Web::DevicePixelRect const& content_rect, Gfx::Bitmap& target, Web::PaintOptions paint_options)
|
||||
{
|
||||
Gfx::IntRect bitmap_rect { {}, content_rect.size().to_type<int>() };
|
||||
|
||||
auto document = page().top_level_browsing_context().active_document();
|
||||
if (document) {
|
||||
document->update_layout();
|
||||
}
|
||||
|
||||
auto background_color = this->background_color();
|
||||
|
||||
Web::Painting::RecordingPainter recording_painter;
|
||||
Web::PaintContext context(recording_painter, palette(), device_pixels_per_css_pixel());
|
||||
|
||||
if (background_color.alpha() < 255)
|
||||
recording_painter.fill_rect(bitmap_rect, Web::CSS::SystemColor::canvas());
|
||||
recording_painter.fill_rect(bitmap_rect, background_color);
|
||||
Gfx::IntRect bitmap_rect { {}, content_rect.size().to_type<int>() };
|
||||
recording_painter.fill_rect(bitmap_rect, Web::CSS::SystemColor::canvas());
|
||||
|
||||
if (!document->paintable())
|
||||
return;
|
||||
|
||||
context.set_should_show_line_box_borders(m_should_show_line_box_borders);
|
||||
context.set_should_paint_overlay(paint_options.paint_overlay == Web::PaintOptions::PaintOverlay::Yes);
|
||||
context.set_device_viewport_rect(content_rect);
|
||||
context.set_has_focus(m_has_focus);
|
||||
|
||||
document->paintable()->collect_scroll_frames(context);
|
||||
document->paintable()->paint_all_phases(context);
|
||||
|
||||
Vector<Gfx::IntPoint> scroll_offsets_by_frame_id;
|
||||
scroll_offsets_by_frame_id.resize(context.scroll_frames().size());
|
||||
for (auto [_, scrollable_frame] : context.scroll_frames())
|
||||
scroll_offsets_by_frame_id[scrollable_frame.id] = context.rounded_device_point(scrollable_frame.offset).to_type<int>();
|
||||
recording_painter.apply_scroll_offsets(scroll_offsets_by_frame_id);
|
||||
Web::HTML::Navigable::PaintConfig paint_config;
|
||||
paint_config.paint_overlay = paint_options.paint_overlay == Web::PaintOptions::PaintOverlay::Yes;
|
||||
paint_config.should_show_line_box_borders = m_should_show_line_box_borders;
|
||||
paint_config.has_focus = m_has_focus;
|
||||
page().top_level_traversable()->paint(recording_painter, paint_config);
|
||||
|
||||
if (s_use_gpu_painter) {
|
||||
#ifdef HAS_ACCELERATED_GRAPHICS
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue