diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java
index daa00c004af21ce8356aeec57d0f276d18865376..4ed875de4e4f87b705d7301f6c80645293948fe1 100644 (file)
public class GameWorld {
- private final int WIDTH, HEIGHT;
+ private int WIDTH, HEIGHT;
private int[][] foreMap;
private int[][] backMap;
- public GameWorld(int w, int h) {
- WIDTH = w;
- HEIGHT = h;
- WorldGen.genWorld(WIDTH,HEIGHT);
- foreMap = WorldGen.getForeMap();
- backMap = WorldGen.getBackMap();
- WorldGen.clear();
- }
-
public int getWidth() {
return WIDTH;
}
}
}
- public Vector2 getSpawnPoint() {
- float x=0, y=0;
+ public Vector2 getSpawnPoint(int x) {
+ int y=0;
+ while (true) {
+ y++;
+ if (getForeMap(x,y)>0 && Items.BLOCKS.getValueAt(getForeMap(x,y)).collision) break;
+ }
x = x*16 + 4;
- y *= 16;
+ y = y*16 - 32;
return new Vector2(x,y);
}
+ public void generate(int w, int h) {
+ WIDTH = w;
+ HEIGHT = h;
+ WorldGen.genWorld(WIDTH,HEIGHT);
+ foreMap = WorldGen.getForeMap();
+ backMap = WorldGen.getBackMap();
+ WorldGen.clear();
+ save();
+ }
+
+ public void save() {
+ WorldSaver.save(foreMap, backMap);
+ }
+
+ public void load() {
+ WorldSaver.load();
+ foreMap = WorldSaver.getLoadedForeMap();
+ backMap = WorldSaver.getLoadedBackMap();
+ WIDTH = foreMap.length;
+ HEIGHT = foreMap[0].length;
+ }
+
}