aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpacien2018-01-03 02:29:55 +0100
committerpacien2018-01-03 02:29:55 +0100
commit26223d88d6d184a3c862c2c9b75638fd66e93617 (patch)
tree36e25b9e72afa09b4874dc5257140a11ce71cb91
parent1a9785dca6f875ecf1c34befc1b5abf7829eb9e5 (diff)
downloadwallj-26223d88d6d184a3c862c2c9b75638fd66e93617.tar.gz
Write user manual
Signed-off-by: pacien <pacien.trangirard@pacien.net>
-rw-r--r--src/docs/user.md122
1 files changed, 117 insertions, 5 deletions
diff --git a/src/docs/user.md b/src/docs/user.md
index a680b01..77bbf35 100644
--- a/src/docs/user.md
+++ b/src/docs/user.md
@@ -1,14 +1,24 @@
1--- 1---
2title: "Wall-J User manual" 2title: "BSc IN S5 / OOP with Java / Wall-J / User manual"
3author: [Pacien TRAN-GIRARD, Adam NAILI] 3author: [Pacien TRAN-GIRARD, Adam NAILI]
4date: 2017-12-09 4date: 2018-01-03
5... 5...
6 6
7# Introduction 7# Preamble
8
9"Wall-J: the Space Cleaner" is a game in which a player uses bombs to push garbage into trash cans in user definable
10worlds.
11
12Being part of the "OOP with Java" course at [UPEM](http://www.u-pem.fr/), this application has been entirely
13written in Java and makes use of the Zen5 and [JBox2D](http://www.jbox2d.org/) libraries.
8 14
9## Licensing 15## Licensing
10 16
11## Credits 17This work is licensed under the terms of the
18[Creative Commons BY-NC-SA 4.0 license](https://creativecommons.org/licenses/by-nc-sa/4.0/) by its authors:
19Pacien TRAN-GIRARD and Adam NAILI.
20
21Build-time and embedded run-time dependencies of this program are licensed under their own respective terms.
12 22
13--- 23---
14 24
@@ -16,12 +26,114 @@ date: 2017-12-09
16 26
17## Prerequisites 27## Prerequisites
18 28
29This application requires the Java Runtime Environment version $\geq$ 8.
30
31A graphical session is also needed to display the game window.
32
19## Running the program 33## Running the program
20 34
21--- 35The program can be started by running the following command:
36
37 java -jar wallj.jar
38
39A custom world set contained within a directory can be loaded by supplying its path as command line argument as such:
40
41 java -jar wallj.jar /home/sforthright/bnl/axiom_floors/
42
43World definition files stored within the given directories and named as `level$i.txt`, where `$i` is a padded integer,
44are loaded in alphanumerical order.
45
46\newpage
22 47
23# Game-play 48# Game-play
24 49
25## Rules 50## Rules
26 51
52The player controls a robot, dropping bombs whose explosion can push garbage into trash cans.
53
54Garbage bounce when colliding other elements such as walls, unexploded bombs or other garbage blocks,
55and disappear of the screen when reaching a garbage can.
56
57A stage is considered done once the world has been cleared of all its garbage.
58The player is then allowed to move on to the next stage.
59The game is finished once all stages are completed.
60
61## World
62
63The world is rectangular grid composed of the following type of tiles:
64
65Entity type Appearance Pushable by bomb Traversable by robot
66----------- ------------ ---------------- --------------------
67Wall Black square No No
68Trash can Red square No No
69Free Empty No Yes
70Bomb Black disk No Yes
71Garbage Brown disk Yes Yes
72Robot Blue disk / /
73
74## Controls
75
76Controls are defined as follows:
77
78Trigger Action
79------------------------------- -------------------------------------------------------
80Click on a traversable tile Moves the robot to the pointed location
81`RETURN` on a free tile Drops a bomb at the current location
82`RETURN` on a tile with a bomb Increases the timer of the bomb at the current location
83
84\newpage
85
27## Custom levels 86## Custom levels
87
88Custom world can be defined by the user in plain text files, each of which containing a single world.
89Such a definition file most contain no empty line, leading or trailing tabulation or space.
90
91A tile map is a rectangular character array from the following alphabet:
92
93Block type Character Bounding Must be reachable
94---------- --------- -------- -----------------
95Free (space) No Yes
96Garbage G No Yes
97Trash can T Yes Yes
98Wall W Yes No
99
100A world is defined as valid if its blocks fulfill the following criteria:
101
102* The bounding box of the defined world must be made of bounding blocks.
103* The interior space formed by bounding blocks must be unique and simple.
104* Reachable blocks are either be adjacent or belong to the interior space.
105* The world must contain at least one trash can and one garbage block.
106
107Only valid worlds can be loaded into the game.
108
109The validity of a world may not guaranty the solvability of the puzzle.
110
111\newpage
112
113__Example of invalid world definition:__
114```
115WWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW
116W W W
117W W W T
118 WWWWWWWWWW W
119 W W W
120 W W WWWWWWWWWWW
121 WWWWWWWWWW W
122W W W
123W W W
124WWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW
125```
126
127__Example of valid world definition:__
128```
129WWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW
130W WWWWWWWWWWW
131W WWWWWWWWWWW
132T WWWWWWWWWW WWWWWWWWWWW
133T WWWWWWWWWW GGGGGGGGGGGGG WWWWWWWWWWW
134T WWWWWWWWWW GGGGGGGG G WWWWWWWWWWW
135T WWWWWWWWWW GGGGGGGGGGGGG W
136W W W
137W W W
138WWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW
139```