aboutsummaryrefslogtreecommitdiff
path: root/src/main/model/layout
diff options
context:
space:
mode:
authorJJ2022-12-28 06:26:54 +0000
committerJJ2022-12-28 23:31:27 +0000
commit4d55ecb842fab83e25adfd2cac76bc6b1ba8d0da (patch)
treef42dc8d25856b1ea0a7decc95c9734842976b235 /src/main/model/layout
parenta1b9e8c5259472ab13b2fd4161d3df8825f52b86 (diff)
encapsulation is evil
Diffstat (limited to 'src/main/model/layout')
-rw-r--r--src/main/model/layout/BlockLayout.java22
-rw-r--r--src/main/model/layout/DocumentLayout.java8
-rw-r--r--src/main/model/layout/InlineLayout.java31
-rw-r--r--src/main/model/layout/Layout.java140
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;
- }
}