mirror of
https://github.com/RGBCube/serenity
synced 2025-07-26 03:37:43 +00:00
LibHTML: Start fleshing out block layout.
The basic idea of block layout is: width, then children based on width, then height based on height of children.
This commit is contained in:
parent
f1a0e8b8e6
commit
22fec1a250
5 changed files with 32 additions and 2 deletions
|
@ -12,7 +12,19 @@ LayoutBlock::~LayoutBlock()
|
||||||
|
|
||||||
void LayoutBlock::layout()
|
void LayoutBlock::layout()
|
||||||
{
|
{
|
||||||
|
compute_width();
|
||||||
|
|
||||||
LayoutNode::layout();
|
LayoutNode::layout();
|
||||||
|
|
||||||
|
compute_height();
|
||||||
|
}
|
||||||
|
|
||||||
|
void LayoutBlock::compute_width()
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void LayoutBlock::compute_height()
|
||||||
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,4 +14,8 @@ public:
|
||||||
virtual void layout() override;
|
virtual void layout() override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
virtual bool is_block() const override { return true; }
|
||||||
|
|
||||||
|
void compute_width();
|
||||||
|
void compute_height();
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <LibHTML/Layout/LayoutNode.h>
|
#include <LibHTML/Layout/LayoutBlock.h>
|
||||||
#include <LibHTML/DOM/Document.h>
|
#include <LibHTML/DOM/Document.h>
|
||||||
|
|
||||||
class LayoutDocument final : public LayoutNode {
|
class LayoutDocument final : public LayoutBlock {
|
||||||
public:
|
public:
|
||||||
explicit LayoutDocument(const Document&);
|
explicit LayoutDocument(const Document&);
|
||||||
virtual ~LayoutDocument() override;
|
virtual ~LayoutDocument() override;
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
#include <LibHTML/Layout/LayoutBlock.h>
|
||||||
#include <LibHTML/Layout/LayoutNode.h>
|
#include <LibHTML/Layout/LayoutNode.h>
|
||||||
|
|
||||||
LayoutNode::LayoutNode(const Node* node)
|
LayoutNode::LayoutNode(const Node* node)
|
||||||
|
@ -15,3 +16,12 @@ void LayoutNode::layout()
|
||||||
child.layout();
|
child.layout();
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const LayoutBlock* LayoutNode::containing_block() const
|
||||||
|
{
|
||||||
|
for (auto* ancestor = parent(); ancestor; ancestor = ancestor->parent()) {
|
||||||
|
if (ancestor->is_block())
|
||||||
|
return static_cast<const LayoutBlock*>(ancestor);
|
||||||
|
}
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#include <SharedGraphics/Rect.h>
|
#include <SharedGraphics/Rect.h>
|
||||||
|
|
||||||
class Node;
|
class Node;
|
||||||
|
class LayoutBlock;
|
||||||
|
|
||||||
class LayoutNode : public TreeNode<LayoutNode> {
|
class LayoutNode : public TreeNode<LayoutNode> {
|
||||||
public:
|
public:
|
||||||
|
@ -38,9 +39,12 @@ public:
|
||||||
|
|
||||||
virtual const char* class_name() const { return "LayoutNode"; }
|
virtual const char* class_name() const { return "LayoutNode"; }
|
||||||
virtual bool is_text() const { return false; }
|
virtual bool is_text() const { return false; }
|
||||||
|
virtual bool is_block() const { return false; }
|
||||||
|
|
||||||
virtual void layout();
|
virtual void layout();
|
||||||
|
|
||||||
|
const LayoutBlock* containing_block() const;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
explicit LayoutNode(const Node*);
|
explicit LayoutNode(const Node*);
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue