diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java
index 92973e18192e64de711c2408af2abe0af075c0b2..5f5a407d44a68c03e23a7ddeb848c61dd3abb26d 100644 (file)
import com.badlogic.gdx.Gdx;
import com.badlogic.gdx.math.Vector2;
-import ru.deadsoftware.cavecraft.Items;
+import com.badlogic.gdx.utils.ArrayMap;
public class GameWorld {
private int WIDTH, HEIGHT;
+ public ArrayMap<String, Integer> metaMap;
private int[][] foreMap;
private int[][] backMap;
}
}
+ public int getMeta(int x, int y) {
+ if (metaMap.containsKey(x+"_"+y)) return metaMap.get(x+"_"+y);
+ else return 0;
+ }
+
+ public void setMeta(int x, int y, int value) {
+ if (metaMap.containsKey(x+"_"+y)) metaMap.removeKey(x+"_"+y);
+ metaMap.put(x+"_"+y, value);
+ }
+
public void placeToForeground(int x, int y, int value) {
if (getForeMap(x,y) == 0 || value == 0) {
setForeMap(x,y,value);
}
public void placeToBackground(int x, int y, int value) {
- if (value==0 || (getBackMap(x,y) == 0 && !Items.BLOCKS.getValueAt(value).foreground)) {
+ if (value==0 || (getBackMap(x,y) == 0 && !Items.BLOCKS.getValueAt(value).background)) {
setBackMap(x,y,value);
}
}
WorldGen.genWorld(WIDTH,HEIGHT);
foreMap = WorldGen.getForeMap();
backMap = WorldGen.getBackMap();
+ metaMap = new ArrayMap<String, Integer>();
WorldGen.clear();
}
- public void load() {
- GameSaver.loadMap();
- foreMap = GameSaver.getLoadedForeMap();
- backMap = GameSaver.getLoadedBackMap();
+ public void setMaps(int[][] foreMap, int[][] backMap) {
+ this.foreMap = foreMap.clone();
+ this.backMap = backMap.clone();
WIDTH = foreMap.length;
HEIGHT = foreMap[0].length;
}