summaryrefslogtreecommitdiffstats
path: root/core/src/ch/asynk/gdx/boardgame/ui
diff options
context:
space:
mode:
Diffstat (limited to 'core/src/ch/asynk/gdx/boardgame/ui')
-rw-r--r--core/src/ch/asynk/gdx/boardgame/ui/Element.java86
-rw-r--r--core/src/ch/asynk/gdx/boardgame/ui/Root.java35
2 files changed, 65 insertions, 56 deletions
diff --git a/core/src/ch/asynk/gdx/boardgame/ui/Element.java b/core/src/ch/asynk/gdx/boardgame/ui/Element.java
index 0a44eef..41adf29 100644
--- a/core/src/ch/asynk/gdx/boardgame/ui/Element.java
+++ b/core/src/ch/asynk/gdx/boardgame/ui/Element.java
@@ -10,7 +10,7 @@ import ch.asynk.gdx.boardgame.Positionable;
import ch.asynk.gdx.boardgame.Touchable;
import ch.asynk.gdx.boardgame.utils.IterableSet;
-public class Element implements Drawable, Paddable, Positionable, Touchable
+public abstract class Element implements Drawable, Paddable, Positionable, Touchable
{
public static boolean DEBUG_GEOMETRY = false;
public static int DEFAULT_CHILD_COUNT = 2;
@@ -95,49 +95,11 @@ public class Element implements Drawable, Paddable, Positionable, Touchable
public void remove(Element e)
{
- if (children.remove(e)) {
- e.setParent(null);
- }
- }
-
- public void taintChildren()
- {
- if (children != null)
- children.forEach( c -> c.taint() );
- }
-
- @Override public void draw(Batch batch)
- {
- if (tainted) computeGeometry();
- children.forEach( c -> c.draw(batch) );
- }
-
- @Override public void drawDebug(ShapeRenderer shapeRenderer)
- {
- shapeRenderer.rect(getX(), getY(), getWidth(), getHeight());
- if (children != null)
- children.forEach( c -> c.drawDebug(shapeRenderer) );
- }
-
- @Override public Element touch(float x, float y)
- {
- if (!blocked && visible && rect.contains(x, y)) {
- if (children != null) {
- for (Element e : children) {
- final Element t = e.touch(x, y);
- if (t != null)
- return t;
- }
+ if (children != null) {
+ if (children.remove(e)) {
+ e.setParent(null);
}
- return this;
}
- return null;
- }
-
- @Override public boolean drag(float x, float y, int dx, int dy)
- {
- if (blocked || !visible) return false;
- return rect.contains(x, y);
}
public void taint()
@@ -146,6 +108,12 @@ public class Element implements Drawable, Paddable, Positionable, Touchable
if (parent != null && taintParent) parent.taint();
}
+ public void taintChildren()
+ {
+ if (children != null)
+ children.forEach( c -> c.taint() );
+ }
+
@Override public void setPosition(float x, float y, float w, float h)
{
this.x = x;
@@ -242,4 +210,38 @@ public class Element implements Drawable, Paddable, Positionable, Touchable
if (DEBUG_GEOMETRY) System.err.println("Geometry]" + print(-1));
this.tainted = false;
}
+
+ public void drawChildren(Batch batch)
+ {
+ if (children != null)
+ children.forEach( c -> c.draw(batch) );
+ }
+
+ @Override public void drawDebug(ShapeRenderer shapeRenderer)
+ {
+ shapeRenderer.rect(getX(), getY(), getWidth(), getHeight());
+ if (children != null)
+ children.forEach( c -> c.drawDebug(shapeRenderer) );
+ }
+
+ @Override public Element touch(float x, float y)
+ {
+ if (!blocked && visible && rect.contains(x, y)) {
+ if (children != null) {
+ for (Element e : children) {
+ final Element t = e.touch(x, y);
+ if (t != null)
+ return t;
+ }
+ }
+ return this;
+ }
+ return null;
+ }
+
+ @Override public boolean drag(float x, float y, int dx, int dy)
+ {
+ if (blocked || !visible) return false;
+ return rect.contains(x, y);
+ }
}
diff --git a/core/src/ch/asynk/gdx/boardgame/ui/Root.java b/core/src/ch/asynk/gdx/boardgame/ui/Root.java
index 4690776..96ea218 100644
--- a/core/src/ch/asynk/gdx/boardgame/ui/Root.java
+++ b/core/src/ch/asynk/gdx/boardgame/ui/Root.java
@@ -1,5 +1,6 @@
package ch.asynk.gdx.boardgame.ui;
+import com.badlogic.gdx.graphics.g2d.Batch;
import com.badlogic.gdx.math.Rectangle;
import ch.asynk.gdx.boardgame.utils.IterableSet;
@@ -14,6 +15,23 @@ public class Root extends Element
this.children = new IterableSet<Element>(c);
}
+ public void resize(Rectangle r)
+ {
+ resize(r.x, r.y, r.width, r.height);
+ }
+
+ public void resize(float width, float height)
+ {
+ resize(getX(), getY(), width, height);
+ }
+
+ public void resize(float x, float y, float width, float height)
+ {
+ setPosition(x, y, width, height);
+ taint();
+ taintChildren();
+ }
+
public Element touched()
{
return touched;
@@ -35,20 +53,9 @@ public class Root extends Element
return false;
}
- public void resize(Rectangle r)
- {
- resize(r.x, r.y, r.width, r.height);
- }
-
- public void resize(float width, float height)
+ @Override public void draw(Batch batch)
{
- resize(getX(), getY(), width, height);
- }
-
- public void resize(float x, float y, float width, float height)
- {
- setPosition(x, y, width, height);
- taint();
- taintChildren();
+ if (tainted) computeGeometry();
+ children.forEach( c -> c.draw(batch) );
}
}