diff options
Diffstat (limited to 'src/jrummikub')
-rw-r--r-- | src/jrummikub/JRummikub.java | 12 | ||||
-rw-r--r-- | src/jrummikub/view/IBoard.java | 2 | ||||
-rw-r--r-- | src/jrummikub/view/ITable.java | 5 | ||||
-rw-r--r-- | src/jrummikub/view/impl/Board.java | 13 | ||||
-rw-r--r-- | src/jrummikub/view/impl/Table.java | 15 |
5 files changed, 39 insertions, 8 deletions
diff --git a/src/jrummikub/JRummikub.java b/src/jrummikub/JRummikub.java index 93cef06..da2a0e9 100644 --- a/src/jrummikub/JRummikub.java +++ b/src/jrummikub/JRummikub.java @@ -1,6 +1,7 @@ package jrummikub; import java.util.ArrayList; +import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; @@ -59,10 +60,13 @@ public class JRummikub { stones.put(new Stone(9, StoneColor.RED, false), new Position(0.5f, 1)); stones.put(new Stone(7, StoneColor.BLACK, false), new Position(1.75f, 1)); - stones.put(new Stone(0, StoneColor.RED, true), new Position(2.5f, 0)); + Stone stoneJoker = new Stone(0, StoneColor.RED, true); + stones.put(stoneJoker, new Position(2.5f, 0)); stones.put(new Stone(0, StoneColor.BLACK, true), new Position(3.5f, 0)); - + view.getPlayerPanel().getBoard().setStones(stones); + view.getPlayerPanel().getBoard().setHighlightedStones(Collections.singleton(stoneJoker)); + view.getPlayerPanel().getBoard().getClickEvent().add(new IListener1<Position>(){ @Override @@ -87,13 +91,15 @@ public class JRummikub { List<Stone> stoneList = new ArrayList<Stone>(); stoneList.add(new Stone(7, StoneColor.BLACK, false)); - stoneList.add(new Stone(8, StoneColor.BLACK, false)); + Stone stone8 = new Stone(8, StoneColor.BLACK, false); + stoneList.add(stone8); stoneList.add(new Stone(9, StoneColor.BLACK, false)); stoneList.add(new Stone(10, StoneColor.BLACK, false)); stoneSets.put(new StoneSet(stoneList), new Position(3.5f, 4)); view.getTable().setStoneSets(stoneSets); + view.getTable().setHighlightedStones(Collections.singleton(stone8)); } diff --git a/src/jrummikub/view/IBoard.java b/src/jrummikub/view/IBoard.java index 237518f..deb2735 100644 --- a/src/jrummikub/view/IBoard.java +++ b/src/jrummikub/view/IBoard.java @@ -1,5 +1,6 @@ package jrummikub.view; +import java.util.Collection; import java.util.Map; import jrummikub.model.Position; @@ -8,6 +9,7 @@ import jrummikub.util.IEvent1; public interface IBoard { public void setStones(Map<Stone, Position> stones); + public void setHighlightedStones(Collection<Stone> stones); public IEvent1<Position> getClickEvent(); } diff --git a/src/jrummikub/view/ITable.java b/src/jrummikub/view/ITable.java index 9781f78..628b56f 100644 --- a/src/jrummikub/view/ITable.java +++ b/src/jrummikub/view/ITable.java @@ -1,8 +1,10 @@ package jrummikub.view; +import java.util.Collection; import java.util.Map; import jrummikub.model.Position; +import jrummikub.model.Stone; import jrummikub.model.StoneSet; import jrummikub.util.IEvent1; @@ -10,6 +12,9 @@ public interface ITable { public void setLeftPlayerName(String playerName); public void setTopPlayerName(String playerName); public void setRightPlayerName(String playerName); + public void setStoneSets(Map<StoneSet, Position> stoneSets); + public void setHighlightedStones(Collection<Stone> stones); + public IEvent1<Position> getClickEvent(); }
\ No newline at end of file diff --git a/src/jrummikub/view/impl/Board.java b/src/jrummikub/view/impl/Board.java index 82794b3..be5ec26 100644 --- a/src/jrummikub/view/impl/Board.java +++ b/src/jrummikub/view/impl/Board.java @@ -7,6 +7,7 @@ import java.awt.Insets; import java.awt.RenderingHints; import java.awt.event.MouseAdapter; import java.awt.event.MouseEvent; +import java.util.Collection; import java.util.Collections; import java.util.Map; @@ -24,6 +25,8 @@ public class Board extends JPanel implements IBoard { private final static ImageIcon background = new ImageIcon(Board.class.getResource("/jrummikub/resource/wood.png")); private Map<Stone, Position> stones = Collections.emptyMap(); + private Collection<Stone> highlightedStones = Collections.emptyList(); + private StonePainter stonePainter = new StonePainter(StonePainter.BOARD_SCALE); private Event1<Position> clickEvent = new Event1<Position>(); @@ -65,8 +68,9 @@ public class Board extends JPanel implements IBoard { g.setRenderingHint(RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON); - for (Map.Entry<Stone, Position> stone : stones.entrySet()) { - stonePainter.paintStone(g, stone.getKey(), stone.getValue(), false); + for (Map.Entry<Stone, Position> entry : stones.entrySet()) { + stonePainter.paintStone(g, entry.getKey(), entry.getValue(), + highlightedStones.contains(entry.getKey())); } } @@ -74,4 +78,9 @@ public class Board extends JPanel implements IBoard { public void setStones(Map<Stone, Position> stones) { this.stones = stones; } + + @Override + public void setHighlightedStones(Collection<Stone> stones) { + highlightedStones = stones; + } } diff --git a/src/jrummikub/view/impl/Table.java b/src/jrummikub/view/impl/Table.java index e4601c5..653167e 100644 --- a/src/jrummikub/view/impl/Table.java +++ b/src/jrummikub/view/impl/Table.java @@ -8,6 +8,7 @@ import java.awt.Insets; import java.awt.RenderingHints; import java.awt.event.MouseAdapter; import java.awt.event.MouseEvent; +import java.util.Collection; import java.util.Collections; import java.util.Map; @@ -33,6 +34,7 @@ public class Table extends JPanel implements ITable { private StonePainter stonePainter = new StonePainter(1); private Map<StoneSet, Position> stoneSets = Collections.emptyMap(); + private Collection<Stone> highlightedStones = Collections.emptyList(); private Event1<Position> clickEvent = new Event1<Position>(); @@ -58,6 +60,12 @@ public class Table extends JPanel implements ITable { } @Override + public void setHighlightedStones(Collection<Stone> stones) { + highlightedStones = stones; + + } + + @Override public IEvent1<Position> getClickEvent() { return clickEvent; } @@ -97,9 +105,10 @@ public class Table extends JPanel implements ITable { public void paintStoneSet(Graphics2D g, StoneSet stoneSet, Position pos) { float x = pos.getX(); - - for(Stone stone : stoneSet){ - stonePainter.paintStone(g, stone, new Position(x, pos.getY()), false); + + for (Stone stone : stoneSet) { + stonePainter.paintStone(g, stone, new Position(x, pos.getY()), + highlightedStones.contains(stone)); x++; } } |