aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/java/fr/umlv/java/wallj/block/BombBlock.java36
-rw-r--r--src/main/java/fr/umlv/java/wallj/block/GarbageBlock.java26
-rw-r--r--src/main/java/fr/umlv/java/wallj/block/RobotBlock.java73
-rw-r--r--src/main/java/fr/umlv/java/wallj/block/TrashBlock.java16
-rw-r--r--src/main/java/fr/umlv/java/wallj/block/WallBlock.java18
-rw-r--r--src/main/java/fr/umlv/java/wallj/context/Game.java12
-rw-r--r--src/main/java/fr/umlv/java/wallj/context/Stage.java35
-rw-r--r--src/main/java/fr/umlv/java/wallj/context/Updateable.java20
-rw-r--r--src/main/java/fr/umlv/java/wallj/context/Updateables.java40
-rw-r--r--src/main/java/fr/umlv/java/wallj/viewer/Viewer.java3
10 files changed, 166 insertions, 113 deletions
diff --git a/src/main/java/fr/umlv/java/wallj/block/BombBlock.java b/src/main/java/fr/umlv/java/wallj/block/BombBlock.java
index ac63a87..4f310eb 100644
--- a/src/main/java/fr/umlv/java/wallj/block/BombBlock.java
+++ b/src/main/java/fr/umlv/java/wallj/block/BombBlock.java
@@ -3,6 +3,7 @@ package fr.umlv.java.wallj.block;
3import fr.umlv.java.wallj.board.TileVec2; 3import fr.umlv.java.wallj.board.TileVec2;
4import fr.umlv.java.wallj.context.Context; 4import fr.umlv.java.wallj.context.Context;
5import fr.umlv.java.wallj.context.GraphicsContext; 5import fr.umlv.java.wallj.context.GraphicsContext;
6import fr.umlv.java.wallj.context.Updateables;
6import fr.umlv.java.wallj.event.*; 7import fr.umlv.java.wallj.event.*;
7import fr.umlv.java.wallj.event.Event; 8import fr.umlv.java.wallj.event.Event;
8import org.jbox2d.common.Vec2; 9import org.jbox2d.common.Vec2;
@@ -10,10 +11,8 @@ import org.jbox2d.dynamics.BodyType;
10 11
11import java.awt.*; 12import java.awt.*;
12import java.time.Duration; 13import java.time.Duration;
13import java.util.Arrays;
14import java.util.Collections;
15import java.util.List;
16import java.util.Objects; 14import java.util.Objects;
15import java.util.stream.Stream;
17 16
18/** 17/**
19 * A bomb block. 18 * A bomb block.
@@ -42,32 +41,35 @@ public class BombBlock extends JBoxBlock {
42 } 41 }
43 42
44 @Override 43 @Override
45 public List<Event> update(Context context) { 44 public Stream<Event> update(Context context) {
46 handleBombConfiguration(context.getEvents()); 45 return Updateables.updateAll(context,
47 paint(context.getGraphicsContext()); 46 this::handleBombConfiguration,
48 return consume(context.getTimeDelta()); 47 this::consume,
48 this::paint);
49 } 49 }
50 50
51 private void handleBombConfiguration(List<Event> events) { 51 private Stream<Event> handleBombConfiguration(Context context) {
52 Events.findFirst(events, BombTimerIncrEvent.class) 52 Events.findFirst(context.getEvents(), BombTimerIncrEvent.class)
53 .filter(event -> Objects.equals(event.getPos(), TileVec2.of(getPos()))) 53 .filter(event -> Objects.equals(event.getPos(), TileVec2.of(getPos())))
54 .ifPresent(event -> incrementTimer()); 54 .ifPresent(event -> incrementTimer());
55 return Stream.empty();
55 } 56 }
56 57
57 private List<Event> consume(Duration timeDelta) { 58 private Stream<Event> consume(Context context) {
58 decrementTimer(timeDelta); 59 decrementTimer(context.getTimeDelta());
59 60 return timer.isNegative() ?
60 if (timer.isNegative()) 61 Stream.of(new BombExplosionEvent(TileVec2.of(getPos())), new BlockDestroyEvent(this)) :
61 return Arrays.asList(new BombExplosionEvent(TileVec2.of(getPos())), new BlockDestroyEvent(this)); 62 Stream.empty();
62 else
63 return Collections.emptyList();
64 } 63 }
65 64
66 private void paint(GraphicsContext graphicsContext) { 65 private Stream<Event> paint(Context context) {
66 GraphicsContext graphicsContext = context.getGraphicsContext();
67 graphicsContext.paintCircle(Color.BLACK, getPos(), TileVec2.TILE_DIM); 67 graphicsContext.paintCircle(Color.BLACK, getPos(), TileVec2.TILE_DIM);
68 Vec2 textPosition = getPos(); 68 Vec2 textPosition = getPos();
69 textPosition.x += TileVec2.TILE_DIM / 4.0f; 69 textPosition.x += TileVec2.TILE_DIM / 4.0f;
70 textPosition.y += 3 * TileVec2.TILE_DIM / 4.0f; 70 textPosition.y += 3 * TileVec2.TILE_DIM / 4.0f;
71 graphicsContext.paintString(Color.RED, textPosition, Long.toString(timer.getSeconds())); 71 graphicsContext.paintString(Color.RED, textPosition, Long.toString(timer.getSeconds()));
72
73 return Stream.empty();
72 } 74 }
73} 75}
diff --git a/src/main/java/fr/umlv/java/wallj/block/GarbageBlock.java b/src/main/java/fr/umlv/java/wallj/block/GarbageBlock.java
index 9338888..362e680 100644
--- a/src/main/java/fr/umlv/java/wallj/block/GarbageBlock.java
+++ b/src/main/java/fr/umlv/java/wallj/block/GarbageBlock.java
@@ -2,19 +2,17 @@ package fr.umlv.java.wallj.block;
2 2
3import fr.umlv.java.wallj.board.TileVec2; 3import fr.umlv.java.wallj.board.TileVec2;
4import fr.umlv.java.wallj.context.Context; 4import fr.umlv.java.wallj.context.Context;
5import fr.umlv.java.wallj.context.GraphicsContext; 5import fr.umlv.java.wallj.context.Updateables;
6import fr.umlv.java.wallj.event.BombExplosionEvent; 6import fr.umlv.java.wallj.event.BombExplosionEvent;
7import fr.umlv.java.wallj.event.Event; 7import fr.umlv.java.wallj.event.Event;
8import fr.umlv.java.wallj.event.Events; 8import fr.umlv.java.wallj.event.Events;
9import org.jbox2d.common.Vec2; 9import org.jbox2d.common.Vec2;
10import org.jbox2d.dynamics.BodyType; 10import org.jbox2d.dynamics.BodyType;
11import org.jbox2d.dynamics.Fixture; 11import org.jbox2d.dynamics.Fixture;
12import org.jbox2d.dynamics.World;
13 12
14import java.awt.*; 13import java.awt.*;
15import java.util.Collections;
16import java.util.List;
17import java.util.Objects; 14import java.util.Objects;
15import java.util.stream.Stream;
18 16
19/** 17/**
20 * A garbage block. 18 * A garbage block.
@@ -31,24 +29,26 @@ public class GarbageBlock extends JBoxBlock {
31 } 29 }
32 30
33 @Override 31 @Override
34 public List<Event> update(Context context) { 32 public Stream<Event> update(Context context) {
35 handleExplosionBlasts(context.getEvents(), context.getGame().getCurrentStage().getWorld()); 33 return Updateables.updateAll(context,
36 paint(context.getGraphicsContext()); 34 this::handleExplosionBlasts,
37 return Collections.emptyList(); 35 this::paint);
38 } 36 }
39 37
40 private void handleExplosionBlasts(List<Event> events, World world) { 38 private Stream<Event> handleExplosionBlasts(Context context) {
41 Events.filter(events, BombExplosionEvent.class).forEach(explosion -> { 39 Events.filter(context.getEvents(), BombExplosionEvent.class).forEach(explosion -> {
42 Vec2 source = explosion.getSource().toVec2(); 40 Vec2 source = explosion.getSource().toVec2();
43 world.raycast((fixture, point, normal, fraction) -> { 41 context.getGame().getCurrentStage().getWorld().raycast((fixture, point, normal, fraction) -> {
44 if (isSelf(fixture)) getBody().applyForceToCenter(computeBlastForce(source)); 42 if (isSelf(fixture)) getBody().applyForceToCenter(computeBlastForce(source));
45 return STOP_RAYCAST; 43 return STOP_RAYCAST;
46 }, source, getPos()); 44 }, source, getPos());
47 }); 45 });
46 return Stream.empty();
48 } 47 }
49 48
50 private void paint(GraphicsContext graphicsContext) { 49 private Stream<Event> paint(Context context) {
51 graphicsContext.paintCircle(COLOR, getPos(), TileVec2.TILE_DIM); 50 context.getGraphicsContext().paintCircle(COLOR, getPos(), TileVec2.TILE_DIM);
51 return Stream.empty();
52 } 52 }
53 53
54 private boolean isSelf(Fixture fixture) { 54 private boolean isSelf(Fixture fixture) {
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 f81f423..11cf25f 100644
--- a/src/main/java/fr/umlv/java/wallj/block/RobotBlock.java
+++ b/src/main/java/fr/umlv/java/wallj/block/RobotBlock.java
@@ -4,17 +4,16 @@ import fr.umlv.java.wallj.board.Board;
4import fr.umlv.java.wallj.board.PathFinder; 4import fr.umlv.java.wallj.board.PathFinder;
5import fr.umlv.java.wallj.board.TileVec2; 5import fr.umlv.java.wallj.board.TileVec2;
6import fr.umlv.java.wallj.context.Context; 6import fr.umlv.java.wallj.context.Context;
7import fr.umlv.java.wallj.context.GraphicsContext;
8import fr.umlv.java.wallj.context.Stage; 7import fr.umlv.java.wallj.context.Stage;
8import fr.umlv.java.wallj.context.Updateables;
9import fr.umlv.java.wallj.event.*; 9import fr.umlv.java.wallj.event.*;
10import fr.umlv.java.wallj.event.Event; 10import fr.umlv.java.wallj.event.Event;
11import org.jbox2d.common.Vec2; 11import org.jbox2d.common.Vec2;
12import org.jbox2d.dynamics.World; 12import org.jbox2d.dynamics.World;
13 13
14import java.awt.*; 14import java.awt.*;
15import java.time.Duration;
16import java.util.*; 15import java.util.*;
17import java.util.List; 16import java.util.stream.Stream;
18 17
19/** 18/**
20 * A robot block. 19 * A robot block.
@@ -50,47 +49,55 @@ public class RobotBlock extends Block {
50 } 49 }
51 50
52 @Override 51 @Override
53 public List<Event> update(Context context) { 52 public Stream<Event> update(Context context) {
54 Events.findFirst(context.getEvents(), MoveRobotOrder.class) 53 return Updateables.updateAll(context,
55 .ifPresent(event -> updatePath(context.getGame().getCurrentStage().getBoard(), event.getTarget())); 54 this::updatePath,
56 55 this::move,
57 move(context.getTimeDelta()); 56 this::paint,
58 paint(context.getGraphicsContext()); 57 this::setupBomb);
59 return setupBomb(context.getEvents(), context.getGame().getCurrentStage());
60 } 58 }
61</