| 
									
										
										
										
											2022-08-12 14:00:00 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright (c) 2022, Sam Atkins <atkinssj@serenityos.org> | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  |  * Copyright (c) 2023, MacDue <macdue@dueutil.tech> | 
					
						
							| 
									
										
										
										
											2022-08-12 14:00:00 +01:00
										 |  |  |  * | 
					
						
							|  |  |  |  * SPDX-License-Identifier: BSD-2-Clause | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  | #include <AK/Variant.h>
 | 
					
						
							| 
									
										
										
										
											2022-08-12 14:00:00 +01:00
										 |  |  | #include <AK/Vector.h>
 | 
					
						
							|  |  |  | #include <LibGfx/AffineTransform.h>
 | 
					
						
							|  |  |  | #include <LibGfx/Color.h>
 | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  | #include <LibGfx/PaintStyle.h>
 | 
					
						
							| 
									
										
										
										
											2024-03-16 22:12:59 +00:00
										 |  |  | #include <LibGfx/PathClipper.h>
 | 
					
						
							| 
									
										
										
										
											2023-03-29 18:35:02 +02:00
										 |  |  | #include <LibWeb/Bindings/CanvasRenderingContext2DPrototype.h>
 | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  | #include <LibWeb/HTML/CanvasGradient.h>
 | 
					
						
							| 
									
										
										
										
											2023-02-02 20:47:46 +00:00
										 |  |  | #include <LibWeb/HTML/CanvasPattern.h>
 | 
					
						
							| 
									
										
										
										
											2022-08-12 14:00:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Web::HTML { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // https://html.spec.whatwg.org/multipage/canvas.html#canvasstate
 | 
					
						
							|  |  |  | class CanvasState { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     virtual ~CanvasState() = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void save(); | 
					
						
							|  |  |  |     void restore(); | 
					
						
							|  |  |  |     void reset(); | 
					
						
							|  |  |  |     bool is_context_lost(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-02-02 20:47:46 +00:00
										 |  |  |     using FillOrStrokeVariant = Variant<Gfx::Color, JS::Handle<CanvasGradient>, JS::Handle<CanvasPattern>>; | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     struct FillOrStrokeStyle { | 
					
						
							|  |  |  |         FillOrStrokeStyle(Gfx::Color color) | 
					
						
							| 
									
										
										
										
											2023-02-02 20:41:03 +00:00
										 |  |  |             : m_fill_or_stroke_style(color) | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  |         { | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         FillOrStrokeStyle(JS::Handle<CanvasGradient> gradient) | 
					
						
							| 
									
										
										
										
											2023-02-02 20:41:03 +00:00
										 |  |  |             : m_fill_or_stroke_style(gradient) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         FillOrStrokeStyle(JS::Handle<CanvasPattern> pattern) | 
					
						
							|  |  |  |             : m_fill_or_stroke_style(pattern) | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  |         { | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         NonnullRefPtr<Gfx::PaintStyle> to_gfx_paint_style(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         Optional<Gfx::Color> as_color() const; | 
					
						
							|  |  |  |         Gfx::Color to_color_but_fixme_should_accept_any_paint_style() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-09-06 19:41:48 +12:00
										 |  |  |         using JsFillOrStrokeStyle = Variant<String, JS::Handle<CanvasGradient>, JS::Handle<CanvasPattern>>; | 
					
						
							| 
									
										
										
										
											2023-02-02 20:41:03 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         JsFillOrStrokeStyle to_js_fill_or_stroke_style() const | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  |         { | 
					
						
							| 
									
										
										
										
											2023-02-02 20:41:03 +00:00
										 |  |  |             return m_fill_or_stroke_style.visit( | 
					
						
							|  |  |  |                 [&](Gfx::Color color) -> JsFillOrStrokeStyle { | 
					
						
							| 
									
										
										
										
											2023-12-16 17:49:34 +03:30
										 |  |  |                     return MUST(String::from_byte_string(color.to_byte_string())); | 
					
						
							| 
									
										
										
										
											2023-02-02 20:41:03 +00:00
										 |  |  |                 }, | 
					
						
							|  |  |  |                 [&](auto handle) -> JsFillOrStrokeStyle { | 
					
						
							|  |  |  |                     return handle; | 
					
						
							|  |  |  |                 }); | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private: | 
					
						
							| 
									
										
										
										
											2023-02-02 20:41:03 +00:00
										 |  |  |         FillOrStrokeVariant m_fill_or_stroke_style; | 
					
						
							| 
									
										
										
										
											2023-01-19 19:10:00 +01:00
										 |  |  |         RefPtr<Gfx::PaintStyle> m_color_paint_style { nullptr }; | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-08-12 14:00:00 +01:00
										 |  |  |     // https://html.spec.whatwg.org/multipage/canvas.html#drawing-state
 | 
					
						
							|  |  |  |     struct DrawingState { | 
					
						
							|  |  |  |         Gfx::AffineTransform transform; | 
					
						
							| 
									
										
										
										
											2023-01-18 20:10:00 +01:00
										 |  |  |         FillOrStrokeStyle fill_style { Gfx::Color::Black }; | 
					
						
							|  |  |  |         FillOrStrokeStyle stroke_style { Gfx::Color::Black }; | 
					
						
							| 
									
										
										
										
											2022-08-12 14:00:00 +01:00
										 |  |  |         float line_width { 1 }; | 
					
						
							| 
									
										
										
										
											2023-03-29 18:35:02 +02:00
										 |  |  |         bool image_smoothing_enabled { true }; | 
					
						
							|  |  |  |         Bindings::ImageSmoothingQuality image_smoothing_quality { Bindings::ImageSmoothingQuality::Low }; | 
					
						
							| 
									
										
										
										
											2023-05-19 22:42:47 +02:00
										 |  |  |         float global_alpha = { 1 }; | 
					
						
							| 
									
										
										
										
											2024-03-16 22:12:59 +00:00
										 |  |  |         Optional<Gfx::ClipPath> clip; | 
					
						
							| 
									
										
										
										
											2023-08-07 21:48:49 +02:00
										 |  |  |         RefPtr<CSS::StyleValue> font_style_value { nullptr }; | 
					
						
							|  |  |  |         RefPtr<Gfx::Font const> current_font { nullptr }; | 
					
						
							| 
									
										
										
										
											2023-08-03 12:18:17 +02:00
										 |  |  |         Bindings::CanvasTextAlign text_align { Bindings::CanvasTextAlign::Start }; | 
					
						
							|  |  |  |         Bindings::CanvasTextBaseline text_baseline { Bindings::CanvasTextBaseline::Alphabetic }; | 
					
						
							| 
									
										
										
										
											2022-08-12 14:00:00 +01:00
										 |  |  |     }; | 
					
						
							|  |  |  |     DrawingState& drawing_state() { return m_drawing_state; } | 
					
						
							|  |  |  |     DrawingState const& drawing_state() const { return m_drawing_state; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     void clear_drawing_state_stack() { m_drawing_state_stack.clear(); } | 
					
						
							|  |  |  |     void reset_drawing_state() { m_drawing_state = {}; } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     virtual void reset_to_default_state() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | protected: | 
					
						
							|  |  |  |     CanvasState() = default; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     DrawingState m_drawing_state; | 
					
						
							|  |  |  |     Vector<DrawingState> m_drawing_state_stack; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // https://html.spec.whatwg.org/multipage/canvas.html#concept-canvas-context-lost
 | 
					
						
							|  |  |  |     bool m_context_lost { false }; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |