X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavecraft%2Fgame%2FGameWorld.java;h=5f5a407d44a68c03e23a7ddeb848c61dd3abb26d;hb=e14d8af238926a5cbfc067cfc9a9b032e51f1cac;hp=7885d2e8ea4bf98d5d18a3e237d3b100e950e490;hpb=e7be8067d83f2a39c237ec7afbe115a846a74f3d;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java index 7885d2e..5f5a407 100644 --- a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java +++ b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java @@ -2,11 +2,13 @@ package ru.deadsoftware.cavecraft.game; import com.badlogic.gdx.Gdx; import com.badlogic.gdx.math.Vector2; +import com.badlogic.gdx.utils.ArrayMap; public class GameWorld { private int WIDTH, HEIGHT; + public ArrayMap metaMap; private int[][] foreMap; private int[][] backMap; @@ -70,6 +72,16 @@ public class GameWorld { } } + 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); @@ -77,7 +89,7 @@ public class GameWorld { } 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); } } @@ -99,6 +111,7 @@ public class GameWorld { WorldGen.genWorld(WIDTH,HEIGHT); foreMap = WorldGen.getForeMap(); backMap = WorldGen.getBackMap(); + metaMap = new ArrayMap(); WorldGen.clear(); }