mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-24 00:49:46 +00:00
This ensures that any internal state maintained by the painter gets synchronized appropriately.
75 lines
2.4 KiB
C++
75 lines
2.4 KiB
C++
/*
|
|
* Copyright (c) 2021-2022, Linus Groh <linusg@serenityos.org>
|
|
* Copyright (c) 2022, Sam Atkins <atkinssj@serenityos.org>
|
|
* Copyright (c) 2023, MacDue <macdue@dueutil.tech>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibGfx/Painter.h>
|
|
#include <LibWeb/HTML/Canvas/CanvasState.h>
|
|
|
|
namespace Web::HTML {
|
|
|
|
// https://html.spec.whatwg.org/multipage/canvas.html#dom-context-2d-save
|
|
void CanvasState::save()
|
|
{
|
|
// The save() method steps are to push a copy of the current drawing state onto the drawing state stack.
|
|
m_drawing_state_stack.append(m_drawing_state);
|
|
|
|
if (auto* painter = painter_for_canvas_state())
|
|
painter->save();
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/canvas.html#dom-context-2d-restore
|
|
void CanvasState::restore()
|
|
{
|
|
// The restore() method steps are to pop the top entry in the drawing state stack, and reset the drawing state it describes. If there is no saved state, then the method must do nothing.
|
|
if (m_drawing_state_stack.is_empty())
|
|
return;
|
|
m_drawing_state = m_drawing_state_stack.take_last();
|
|
|
|
if (auto* painter = painter_for_canvas_state())
|
|
painter->restore();
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/canvas.html#dom-context-2d-reset
|
|
void CanvasState::reset()
|
|
{
|
|
// The reset() method steps are to reset the rendering context to its default state.
|
|
reset_to_default_state();
|
|
}
|
|
|
|
// https://html.spec.whatwg.org/multipage/canvas.html#dom-context-2d-iscontextlost
|
|
bool CanvasState::is_context_lost()
|
|
{
|
|
// The isContextLost() method steps are to return this's context lost.
|
|
return m_context_lost;
|
|
}
|
|
|
|
NonnullRefPtr<Gfx::PaintStyle> CanvasState::FillOrStrokeStyle::to_gfx_paint_style()
|
|
{
|
|
return m_fill_or_stroke_style.visit(
|
|
[&](Gfx::Color color) -> NonnullRefPtr<Gfx::PaintStyle> {
|
|
if (!m_color_paint_style)
|
|
m_color_paint_style = Gfx::SolidColorPaintStyle::create(color).release_value_but_fixme_should_propagate_errors();
|
|
return m_color_paint_style.release_nonnull();
|
|
},
|
|
[&](auto handle) {
|
|
return handle->to_gfx_paint_style();
|
|
});
|
|
}
|
|
|
|
Gfx::Color CanvasState::FillOrStrokeStyle::to_color_but_fixme_should_accept_any_paint_style() const
|
|
{
|
|
return as_color().value_or(Gfx::Color::Black);
|
|
}
|
|
|
|
Optional<Gfx::Color> CanvasState::FillOrStrokeStyle::as_color() const
|
|
{
|
|
if (auto* color = m_fill_or_stroke_style.get_pointer<Gfx::Color>())
|
|
return *color;
|
|
return {};
|
|
}
|
|
|
|
}
|