diff options
author | Adam NAILI | 2018-02-02 23:00:04 +0100 |
---|---|---|
committer | Adam NAILI | 2018-02-02 23:00:04 +0100 |
commit | 960662d7bf433d7bbfb93bf7ca58a85645110fe5 (patch) | |
tree | 9f258fffa0777a14719975ed3f06287a2671f1c6 | |
parent | 088376cba305934dd090c0dc9047a2a1ac9fa0f6 (diff) | |
parent | a627b2f4591147dadd82f802bc8391333034b4b8 (diff) | |
download | wallj-960662d7bf433d7bbfb93bf7ca58a85645110fe5.tar.gz |
Merge branch 'master' of https://github.com/pacien/upem-java-wallj
7 files changed, 43 insertions, 30 deletions
diff --git a/src/docs/class.puml b/src/docs/class.puml index a889371..d8c6e81 100644 --- a/src/docs/class.puml +++ b/src/docs/class.puml | |||
@@ -101,7 +101,6 @@ package event { | |||
101 | } | 101 | } |
102 | 102 | ||
103 | class GameOverEvent implements GameEvent | 103 | class GameOverEvent implements GameEvent |
104 | class StageClearedEvent implements GameEvent | ||
105 | class BlockCreateEvent implements GameEvent | 104 | class BlockCreateEvent implements GameEvent |
106 | class BlockDestroyEvent implements GameEvent | 105 | class BlockDestroyEvent implements GameEvent |
107 | } | 106 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/block/Block.java b/src/main/java/fr/umlv/java/wallj/block/Block.java index 7ae9c06..003c782 100644 --- a/src/main/java/fr/umlv/java/wallj/block/Block.java +++ b/src/main/java/fr/umlv/java/wallj/block/Block.java | |||
@@ -45,4 +45,9 @@ public abstract class Block implements Updateable { | |||
45 | * @param world a JBox2D world | 45 | * @param world a JBox2D world |
46 | */ | 46 | */ |
47 | public abstract void link(World world); | 47 | public abstract void link(World world); |
48 | |||
49 | /** | ||
50 | * @param world a JBox2D world | ||
51 | */ | ||
52 | public abstract void unlink(World world); | ||
48 | } | 53 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/block/JBoxBlock.java b/src/main/java/fr/umlv/java/wallj/block/JBoxBlock.java index 06ecca3..f0f2834 100644 --- a/src/main/java/fr/umlv/java/wallj/block/JBoxBlock.java +++ b/src/main/java/fr/umlv/java/wallj/block/JBoxBlock.java | |||
@@ -33,4 +33,10 @@ public abstract class JBoxBlock extends Block { | |||
33 | body.createFixture(fixtureDef); | 33 | body.createFixture(fixtureDef); |
34 | body.setUserData(this); | 34 | body.setUserData(this); |
35 | } | 35 | } |
36 | |||
37 | @Override | ||
38 | public void unlink(World world) { | ||
39 | if (body == null) throw new IllegalStateException("Block has not yet been linked."); | ||
40 | world.destroyBody(body); | ||
41 | } | ||
36 | } | 42 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/block/RobotBlock.java b/src/main/java/fr/umlv/java/wallj/block/RobotBlock.java index 7d370e5..45ed5bd 100644 --- a/src/main/java/fr/umlv/java/wallj/block/RobotBlock.java +++ b/src/main/java/fr/umlv/java/wallj/block/RobotBlock.java | |||
@@ -45,6 +45,11 @@ public class RobotBlock extends Block { | |||
45 | } | 45 | } |
46 | 46 | ||
47 | @Override | 47 | @Override |
48 | public void unlink(World world) { | ||
49 | // no-op | ||
50 | } | ||
51 | |||
52 | @Override | ||
48 | public List<Event> update(Context context) { | 53 | public List<Event> update(Context context) { |
49 | Events.findFirst(context.getEvents(), MoveRobotOrder.class) | 54 | Events.findFirst(context.getEvents(), MoveRobotOrder.class) |
50 | .ifPresent(event -> updatePath(context.getGame().getCurrentStage().getBoard(), event.getTarget())); | 55 | .ifPresent(event -> updatePath(context.getGame().getCurrentStage().getBoard(), event.getTarget())); |
diff --git a/src/main/java/fr/umlv/java/wallj/context/Stage.java b/src/main/java/fr/umlv/java/wallj/context/Stage.java index 860f451..8852568 100644 --- a/src/main/java/fr/umlv/java/wallj/context/Stage.java +++ b/src/main/java/fr/umlv/java/wallj/context/Stage.java | |||
@@ -1,6 +1,8 @@ | |||
1 | package fr.umlv.java.wallj.context; | 1 | package fr.umlv.java.wallj.context; |
2 | 2 | ||
3 | import fr.umlv.java.wallj.block.Block; | 3 | import fr.umlv.java.wallj.block.Block; |
4 | import fr.umlv.java.wallj.block.BlockFactory; | ||
5 | import fr.umlv.java.wallj.block.BlockType; | ||
4 | import fr.umlv.java.wallj.board.Board; | 6 | import fr.umlv.java.wallj.board.Board; |
5 | import fr.umlv.java.wallj.board.BoardConverter; | 7 | import fr.umlv.java.wallj.board.BoardConverter; |
6 | import fr.umlv.java.wallj.event.*; | 8 | import fr.umlv.java.wallj.event.*; |
@@ -8,7 +10,6 @@ import org.jbox2d.common.Vec2; | |||
8 | import org.jbox2d.dynamics.World; | 10 | import org.jbox2d.dynamics.World; |
9 | 11 | ||
10 | import java.time.Duration; | 12 | import java.time.Duration; |
11 | import java.util.Collections; | ||
12 | import java.util.List; | 13 | import java.util.List; |
13 | import java.util.Objects; | 14 | import java.util.Objects; |
14 | 15 | ||
@@ -23,38 +24,47 @@ public class Stage implements Updateable { | |||
23 | private final Board board; | 24 | private final Board board; |
24 | private final List<Block> blocks; | 25 | private final List<Block> blocks; |
25 | 26 | ||
27 | /** | ||
28 | * @param board the base board | ||
29 | */ | ||
26 | public Stage(Board board) { | 30 | public Stage(Board board) { |
27 | this.board = Objects.requireNonNull(board); | 31 | this.board = Objects.requireNonNull(board); |
28 | this.blocks = BoardConverter.boardToWorld(board); | 32 | blocks = BoardConverter.boardToWorld(board); |
29 | // TODO: link blocks to world | 33 | blocks.forEach(block -> block.link(world)); |
30 | } | 34 | } |
31 | 35 | ||
36 | /** | ||
37 | * @return the JBox2D world | ||
38 | */ | ||
32 | public World getWorld() { | 39 | public World getWorld() { |
33 | return world; | 40 | return world; |
34 | } | 41 | } |
35 | 42 | ||
36 | /** | 43 | /** |
37 | * @return the current board of the game | 44 | * @return the base board |
38 | */ | 45 | */ |
39 | public Board getBoard() { | 46 | public Board getBoard() { |
40 | return board; | 47 | return board; |
41 | } | 48 | } |
42 | 49 | ||
43 | private boolean isCleared() { | 50 | /** |
44 | // TODO | 51 | * @return T(this stage is cleared, i.e. does not contain any garbage block) |
45 | return false; | 52 | * @implNote TODO: profile this and consider a garbage block counter |
53 | */ | ||
54 | public boolean isCleared() { | ||
55 | return blocks.stream().noneMatch(block -> block.getType() == BlockType.GARBAGE); | ||
46 | } | 56 | } |
47 | 57 | ||
48 | /** | 58 | /** |
49 | * @param context the current context | 59 | * @param context the current context |
50 | * @return a list of new events to perform | 60 | * @return the list of newly generated events |
51 | */ | 61 | */ |
52 | @Override | 62 | @Override |
53 | public List<Event> update(Context context) { | 63 | public List<Event> update(Context context) { |
54 | updatePhysicalWorld(context.getTimeDelta()); | 64 | updatePhysicalWorld(context.getTimeDelta()); |
55 | handleBlockDestruction(context.getEvents()); | 65 | handleBlockDestruction(context.getEvents()); |
56 | handleBlockCreation(context.getEvents()); | 66 | handleBlockCreation(context.getEvents()); |
57 | return generateEvents(); | 67 | return Updateable.updateAll(blocks, context); |
58 | } | 68 | } |
59 | 69 | ||
60 | private void updatePhysicalWorld(Duration timeDelta) { | 70 | private void updatePhysicalWorld(Duration timeDelta) { |
@@ -64,18 +74,15 @@ public class Stage implements Updateable { | |||
64 | 74 | ||
65 | private void handleBlockDestruction(List<Event> events) { | 75 | private void handleBlockDestruction(List<Event> events) { |
66 | Events.filter(events, BlockDestroyEvent.class).forEach(event -> { | 76 | Events.filter(events, BlockDestroyEvent.class).forEach(event -> { |
67 | }); // TODO | 77 | if (blocks.remove(event.getBlock())) event.getBlock().unlink(world); |
78 | }); | ||
68 | } | 79 | } |
69 | 80 | ||
70 | private void handleBlockCreation(List<Event> events) { | 81 | private void handleBlockCreation(List<Event> events) { |
71 | Events.filter(events, BlockCreateEvent.class).forEach(event -> { | 82 | Events.filter(events, BlockCreateEvent.class).forEach(event -> { |
72 | }); // TODO | 83 | Block block = BlockFactory.build(event.getBlockType(), event.getPos()); |
73 | } | 84 | blocks.add(block); |
74 | 85 | block.link(world); | |
75 | private List<Event> generateEvents() { | 86 | }); |
76 | if (isCleared()) | ||
77 | return Collections.singletonList(new StageClearedEvent()); | ||
78 | else | ||
79 | return Collections.emptyList(); | ||
80 | } | 87 | } |
81 | } | 88 | } |
diff --git a/src/main/java/fr/umlv/java/wallj/context/Updateable.java b/src/main/java/fr/umlv/java/wallj/context/Updateable.java index 468fe2c..45c217e 100644 --- a/src/main/java/fr/umlv/java/wallj/context/Updateable.java +++ b/src/main/java/fr/umlv/java/wallj/context/Updateable.java | |||
@@ -18,9 +18,10 @@ public interface Updateable { | |||
18 | /** | 18 | /** |
19 | * @param updateables list of updateables | 19 | * @param updateables list of updateables |
20 | * @param context an update context | 20 | * @param context an update context |
21 | * @param <T> the updateable type | ||
21 | * @return a list of collected generated events | 22 | * @return a list of collected generated events |
22 | */ | 23 | */ |
23 | static List<Event> updateAll(List<Updateable> updateables, Context context) { | 24 | static <T extends Updateable> List<Event> updateAll(List<T> updateables, Context context) { |
24 | return updateables.stream() | 25 | return updateables.stream() |
25 | .flatMap(u -> u.update(context).stream()) | 26 | .flatMap(u -> u.update(context).stream()) |
26 | .collect(Collectors.toList()); | 27 | .collect(Collectors.toList()); |
diff --git a/src/main/java/fr/umlv/java/wallj/event/StageClearedEvent.java b/src/main/java/fr/umlv/java/wallj/event/StageClearedEvent.java deleted file mode 100644 index 2543ad9..0000000 --- a/src/main/java/fr/umlv/java/wallj/event/StageClearedEvent.java +++ /dev/null | |||
@@ -1,10 +0,0 @@ | |||
1 | package fr.umlv.java.wallj.event; | ||
2 | |||
3 | /** | ||
4 | * Signals that a stage is cleared. | ||
5 | * | ||
6 | * @author Pacien TRAN-GIRARD | ||
7 | */ | ||
8 | public final class StageClearedEvent implements GameEvent { | ||
9 | // void | ||
10 | } | ||