mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-05-21 02:22:51 +00:00
This patch adds a bunch of Paintable subclasses, each corresponding to the Layout::Node subclasses that had a paint() override. All painting logic is moved from layout nodes into their corresponding paintables. Paintables are now created by asking a Layout::Box to produce one: static NonnullOwnPtr<Paintable> Layout::Box::create_paintable() Note that inline nodes still have their painting logic. Since they are not boxes, and all paintables have a corresponding box, we'll need to come up with some other solution for them.
38 lines
1 KiB
C++
38 lines
1 KiB
C++
/*
|
|
* Copyright (c) 2018-2022, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibGfx/StylePainter.h>
|
|
#include <LibWeb/Painting/ProgressPaintable.h>
|
|
|
|
namespace Web::Painting {
|
|
|
|
NonnullOwnPtr<ProgressPaintable> ProgressPaintable::create(Layout::Progress const& layout_box)
|
|
{
|
|
return adopt_own(*new ProgressPaintable(layout_box));
|
|
}
|
|
|
|
ProgressPaintable::ProgressPaintable(Layout::Progress const& layout_box)
|
|
: Paintable(layout_box)
|
|
{
|
|
}
|
|
|
|
Layout::Progress const& ProgressPaintable::layout_box() const
|
|
{
|
|
return static_cast<Layout::Progress const&>(m_layout_box);
|
|
}
|
|
|
|
void ProgressPaintable::paint(PaintContext& context, PaintPhase phase) const
|
|
{
|
|
if (!is_visible())
|
|
return;
|
|
|
|
if (phase == PaintPhase::Foreground) {
|
|
// FIXME: This does not support floating point value() and max()
|
|
Gfx::StylePainter::paint_progressbar(context.painter(), enclosing_int_rect(absolute_rect()), context.palette(), 0, layout_box().dom_node().max(), layout_box().dom_node().value(), "");
|
|
}
|
|
}
|
|
|
|
}
|