diff options
author | JJ | 2022-12-28 06:26:54 +0000 |
---|---|---|
committer | JJ | 2022-12-28 23:31:27 +0000 |
commit | 4d55ecb842fab83e25adfd2cac76bc6b1ba8d0da (patch) | |
tree | f42dc8d25856b1ea0a7decc95c9734842976b235 /src/main/model/layout | |
parent | a1b9e8c5259472ab13b2fd4161d3df8825f52b86 (diff) |
encapsulation is evil
Diffstat (limited to 'src/main/model/layout')
-rw-r--r-- | src/main/model/layout/BlockLayout.java | 22 | ||||
-rw-r--r-- | src/main/model/layout/DocumentLayout.java | 8 | ||||
-rw-r--r-- | src/main/model/layout/InlineLayout.java | 31 | ||||
-rw-r--r-- | src/main/model/layout/Layout.java | 140 |
4 files changed, 57 insertions, 144 deletions
diff --git a/src/main/model/layout/BlockLayout.java b/src/main/model/layout/BlockLayout.java index 9204b61..9264035 100644 --- a/src/main/model/layout/BlockLayout.java +++ b/src/main/model/layout/BlockLayout.java @@ -12,20 +12,20 @@ public class BlockLayout extends Layout { // recursively construct the layout tree public void layout() { - this.setLocation(this.getParent().getLocation()); - this.getPreviousSibling().ifPresent( - sibling -> this.setY(sibling.getY() + sibling.getHeight())); - this.getPreviousSibling().ifPresent( - sibling -> System.out.println("bluh" + sibling.getAssociatedNode().getData())); + this.location = (Point) this.parent.location.clone(); + this.previousSibling.ifPresent( + sibling -> this.location.y = sibling.location.y + sibling.dimension.height); +// this.previousSibling.ifPresent( +// sibling -> System.out.println("bluh" + sibling.associatedNode.data())); -// this.setDimension(this.getParent().getDimension()); +// this.dimension = (Dimension) this.parent.dimension.clone(); - for (Layout child : this.getChildren()) { + for (Layout child : this.children) { child.layout(); - this.setHeight(this.getHeight() + child.getHeight()); + this.dimension.height += child.dimension.height; } -// System.out.println(this.getAssociatedNode().getData() + this.getLocation()); -// System.out.println(System.identityHashCode(this.getLocation())); -// System.out.println(this.getAssociatedNode().getData() + this.getDimension()); +// System.out.println(this.associatedNode.data() + this.location); +// System.out.println(System.identityHashCode(this.location)); +// System.out.println(this.associatedNode.data() + this.dimension); } } diff --git a/src/main/model/layout/DocumentLayout.java b/src/main/model/layout/DocumentLayout.java index 2e9d778..df2a1b9 100644 --- a/src/main/model/layout/DocumentLayout.java +++ b/src/main/model/layout/DocumentLayout.java @@ -15,12 +15,12 @@ public class DocumentLayout extends Layout { // recursively construct the layout tree public void layout() { - this.setLocation(new Point(10, 20)); - this.setDimension(new Dimension(DEFAULT_WIDTH, DEFAULT_HEIGHT)); + this.location = new Point(10, 20); + this.dimension = new Dimension(DEFAULT_WIDTH, DEFAULT_HEIGHT); - for (Layout child : this.getChildren()) { + for (Layout child : this.children) { child.layout(); - this.setHeight(this.getHeight() + child.getHeight()); + this.dimension.height += child.dimension.height; } } } diff --git a/src/main/model/layout/InlineLayout.java b/src/main/model/layout/InlineLayout.java index c4c51b5..845a717 100644 --- a/src/main/model/layout/InlineLayout.java +++ b/src/main/model/layout/InlineLayout.java @@ -2,7 +2,6 @@ package model.layout; import model.html.ElementNode; import model.html.Node; -import model.html.TextNode; import java.awt.*; @@ -17,36 +16,36 @@ public class InlineLayout extends Layout { // recursively construct the layout tree public void layout() { - this.setLocation(this.getParent().getLocation()); - this.getPreviousSibling().ifPresent( - sibling -> this.setY(sibling.getY() + sibling.getHeight())); + this.location = (Point) this.parent.location.clone(); // java moment + this.previousSibling.ifPresent( + sibling -> this.location.y = sibling.location.y + sibling.dimension.height); - this.setWidth(this.getParent().getWidth()); - this.setCursor(this.getX(), this.getY()); + this.dimension.width = this.parent.dimension.width; + this.setCursor(this.location.x, this.location.y); - Node node = this.getAssociatedNode(); + Node node = this.associatedNode; switch (node) { case ElementNode e -> { - if (e.getTag().equals("a")) { - this.setX(this.getX() + this.getParent().getWidth()); + if (e.tag.equals("a")) { + this.location.x += this.parent.dimension.width; } } default -> { - if (node.getData().length() > 5) { - this.setHeight(20); -// this.setWidth(this.getWidth() + node.getData().length()); + if (node.data().length() > 5) { + this.dimension.height = 20; +// this.dimension.width = this.dimension.width + node.data().length(); } } } - for (Layout child : this.getChildren()) { + for (Layout child : this.children) { child.layout(); - this.setHeight(this.getHeight() + child.getHeight()); // fixme + this.dimension.height += child.dimension.height; // fixme } // todo: recurse to calculate cursor -// this.setHeight(cursor.getY() - this.getY()); -// System.out.println(this.getAssociatedNode().getData() + this.getLocation()); +// this.height = cursor.location.y - this.location.y; +// System.out.println(this.associatedNode.data() + this.location); } public void setCursor(Point cursor) { diff --git a/src/main/model/layout/Layout.java b/src/main/model/layout/Layout.java index 5a19302..d9c3954 100644 --- a/src/main/model/layout/Layout.java +++ b/src/main/model/layout/Layout.java @@ -8,17 +8,20 @@ import java.util.*; // Generic Layout class public abstract class Layout { - private Point location; - private Dimension dimension; + // fuck encapsulation all my homies hate encapsulation + // but seriously, what a garbage idea: get a better language + // (please read the above comment in the voice of https://www.youtube.com/watch?v=EdWSg6YwUeo) + public Point location; + public Dimension dimension; - private Node associatedNode; - private Layout parent; - private Optional<Layout> previousSibling; - private Optional<Layout> nextSibling; - private ArrayList<Layout> children; + public final Node associatedNode; + public final Layout parent; + public Optional<Layout> previousSibling; + public Optional<Layout> nextSibling; + public ArrayList<Layout> children; - public static final int DEFAULT_WIDTH = 1920; - public static final int DEFAULT_HEIGHT = 1080; + public static final int DEFAULT_WIDTH = 1000; + public static final int DEFAULT_HEIGHT = 800; // https://developer.mozilla.org/en-US/docs/Web/HTML/Block-level_elements public static final Set<String> BLOCK_ELEMENTS = new HashSet<>( @@ -46,125 +49,36 @@ public abstract class Layout { // eh, probably the best place to put this // parent MAY BE nil: a handy call to Optional.ofNullable allows this public static ArrayList<Layout> constructTree(ArrayList<Node> html, Layout parent) { - ArrayDeque<Layout> result = new ArrayDeque<>(); + var result = new ArrayDeque<Layout>(); for (Node node : html) { Layout layout; - if (node instanceof ElementNode) { - if (BLOCK_ELEMENTS.contains(((ElementNode) node).getTag())) { - layout = new BlockLayout(node, parent); - } else { + switch (node) { + case ElementNode e -> { + if (BLOCK_ELEMENTS.contains(e.tag)) { + layout = new BlockLayout(node, parent); + } else { + layout = new InlineLayout(node, parent); + } + layout.children = constructTree(e.children, layout); + } + default -> { layout = new InlineLayout(node, parent); } - layout.setChildren(constructTree(((ElementNode) node).getChildren(), layout)); - } else { - layout = new InlineLayout(node, parent); } if (result.size() > 0) { - layout.setPreviousSibling(result.getLast()); - result.getLast().setNextSibling(layout); + layout.previousSibling = Optional.of(result.getLast()); + result.getLast().nextSibling = Optional.of(layout); } - result.add(layout); } return new ArrayList<>(result); // haha } public static DocumentLayout constructTree(ArrayList<Node> html) { - DocumentLayout result = new DocumentLayout(); - result.setChildren(constructTree(html, result)); + var result = new DocumentLayout(); + result.children = constructTree(html, result); result.layout(); return result; } - - // man, fuck design patterns, this is so much goddamn code - - public void setLocation(Point point) { - this.location.x = point.x; - this.location.y = point.y; - } - - public void setX(double x) { - this.location.setLocation(x, this.getLocation().getY()); - } - - public void setY(double y) { - this.location.setLocation(this.getLocation().getX(), y); - } - - public void setDimension(Dimension dimension) { - this.dimension = dimension; - } - - public void setDimension(double x, double y) { - this.dimension.setSize(x, y); - } - - public void setWidth(double width) { - this.dimension.setSize(width, this.getDimension().getWidth()); - } - - public void setHeight(double height) { - this.dimension.setSize(this.getDimension().getHeight(), height); - } - - public void setPreviousSibling(Layout sibling) { - this.previousSibling = Optional.ofNullable(sibling); - } - - public void setNextSibling(Layout parent) { - this.nextSibling = Optional.ofNullable(parent); - } - - public void setChildren(ArrayList<Layout> children) { - this.children = children; - } - - public void addChild(Layout child) { - this.children.add(child); - } - - public Node getAssociatedNode() { - return this.associatedNode; - } - - public Point getLocation() { - return this.location; - } - - public double getX() { - return this.location.getX(); - } - - public double getY() { - return this.location.getY(); - } - - public Dimension getDimension() { - return this.dimension; - } - - public double getWidth() { - return this.dimension.getWidth(); - } - - public double getHeight() { - return this.dimension.getHeight(); - } - - public Layout getParent() { - return this.parent; - } - - public Optional<Layout> getPreviousSibling() { - return this.previousSibling; - } - - public Optional<Layout> getNextSibling() { - return this.nextSibling; - } - - public ArrayList<Layout> getChildren() { - return this.children; - } } |