mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 06:12:43 +00:00 
			
		
		
		
	 1051624084
			
		
	
	
		1051624084
		
	
	
	
	
		
			
			Calculate a "preferred aspect ratio" based on the value of `aspect-ratio` and the presence of a natural aspect ratio, and use that in layout. This is by no means complete or perfect, but we do now apply the given aspect-ratio to things. The spec is a bit vague, just saying to calculate sizes for aspect-ratio'ed boxes the same as you would for replaced elements. My naive solution here is to find everywhere we were checking for a ReplacedBox, and then also accept a regular Box with a preferred aspect ratio. This gets us pretty far. :^) https://www.w3.org/TR/css-sizing-4/#aspect-ratio-minimum is not at all implemented.
		
			
				
	
	
		
			77 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2018-2022, Andreas Kling <kling@serenityos.org>
 | |
|  *
 | |
|  * SPDX-License-Identifier: BSD-2-Clause
 | |
|  */
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <AK/OwnPtr.h>
 | |
| #include <LibGfx/Rect.h>
 | |
| #include <LibJS/Heap/Cell.h>
 | |
| #include <LibWeb/Layout/Node.h>
 | |
| 
 | |
| namespace Web::Layout {
 | |
| 
 | |
| struct LineBoxFragmentCoordinate {
 | |
|     size_t line_box_index { 0 };
 | |
|     size_t fragment_index { 0 };
 | |
| };
 | |
| 
 | |
| class Box : public NodeWithStyleAndBoxModelMetrics {
 | |
|     JS_CELL(Box, NodeWithStyleAndBoxModelMetrics);
 | |
| 
 | |
| public:
 | |
|     Painting::PaintableBox const* paintable_box() const;
 | |
| 
 | |
|     virtual void set_needs_display() override;
 | |
| 
 | |
|     bool is_body() const;
 | |
| 
 | |
|     // https://www.w3.org/TR/css-images-3/#natural-dimensions
 | |
|     Optional<CSSPixels> natural_width() const { return m_natural_width; }
 | |
|     Optional<CSSPixels> natural_height() const { return m_natural_height; }
 | |
|     Optional<float> natural_aspect_ratio() const { return m_natural_aspect_ratio; }
 | |
| 
 | |
|     bool has_natural_width() const { return natural_width().has_value(); }
 | |
|     bool has_natural_height() const { return natural_height().has_value(); }
 | |
|     bool has_natural_aspect_ratio() const { return natural_aspect_ratio().has_value(); }
 | |
| 
 | |
|     void set_natural_width(Optional<CSSPixels> width) { m_natural_width = width; }
 | |
|     void set_natural_height(Optional<CSSPixels> height) { m_natural_height = height; }
 | |
|     void set_natural_aspect_ratio(Optional<float> ratio) { m_natural_aspect_ratio = ratio; }
 | |
| 
 | |
|     // https://www.w3.org/TR/css-sizing-4/#preferred-aspect-ratio
 | |
|     Optional<float> preferred_aspect_ratio() const;
 | |
|     bool has_preferred_aspect_ratio() const { return preferred_aspect_ratio().has_value(); }
 | |
| 
 | |
|     virtual ~Box() override;
 | |
| 
 | |
|     virtual void did_set_content_size() { }
 | |
| 
 | |
|     virtual JS::GCPtr<Painting::Paintable> create_paintable() const override;
 | |
| 
 | |
|     bool is_scroll_container() const;
 | |
| 
 | |
|     bool is_scrollable() const;
 | |
|     CSSPixelPoint scroll_offset() const { return m_scroll_offset; }
 | |
|     void set_scroll_offset(CSSPixelPoint);
 | |
| 
 | |
| protected:
 | |
|     Box(DOM::Document&, DOM::Node*, NonnullRefPtr<CSS::StyleProperties>);
 | |
|     Box(DOM::Document&, DOM::Node*, CSS::ComputedValues);
 | |
| 
 | |
| private:
 | |
|     virtual bool is_box() const final { return true; }
 | |
| 
 | |
|     CSSPixelPoint m_scroll_offset;
 | |
| 
 | |
|     Optional<CSSPixels> m_natural_width;
 | |
|     Optional<CSSPixels> m_natural_height;
 | |
|     Optional<float> m_natural_aspect_ratio;
 | |
| };
 | |
| 
 | |
| template<>
 | |
| inline bool Node::fast_is<Box>() const { return is_box(); }
 | |
| 
 | |
| }
 |