X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavecraft%2Fgame%2FGameWorld.java;h=7885d2e8ea4bf98d5d18a3e237d3b100e950e490;hb=e7be8067d83f2a39c237ec7afbe115a846a74f3d;hp=4ed875de4e4f87b705d7301f6c80645293948fe1;hpb=7217e9b86d6e44604703ffb9956bcade97cfe9c9;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java index 4ed875d..7885d2e 100644 --- a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java +++ b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java @@ -2,7 +2,6 @@ package ru.deadsoftware.cavecraft.game; import com.badlogic.gdx.Gdx; import com.badlogic.gdx.math.Vector2; -import ru.deadsoftware.cavecraft.Items; public class GameWorld { @@ -19,15 +18,19 @@ public class GameWorld { return HEIGHT; } + public int[][] getFullForeMap() { + return foreMap; + } + + public int[][] getFullBackMap() { + return backMap; + } + public int getForeMap(int x, int y) { int map = 0; try { - if (x<0) { - x = x % (getWidth()); - x = getWidth()- Math.abs(x); - } else if (x>0) { - x = x % (getWidth()); - } + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); map = foreMap[x][y]; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld",e.toString()); @@ -37,12 +40,8 @@ public class GameWorld { public void setForeMap(int x, int y, int value) { try { - if (x<0) { - x = x % (getWidth()); - x = getWidth()- Math.abs(x); - } else if (x>0) { - x = x % (getWidth()); - } + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); foreMap[x][y] = value; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld", e.toString()); @@ -52,12 +51,8 @@ public class GameWorld { public int getBackMap(int x, int y) { int map = 0; try { - if (x<0) { - x = x % (getWidth()); - x = getWidth()- Math.abs(x); - } else if (x>0) { - x = x % (getWidth()); - } + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); map = backMap[x][y]; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld",e.toString()); @@ -67,12 +62,8 @@ public class GameWorld { public void setBackMap(int x, int y, int value) { try { - if (x<0) { - x = x % (getWidth()); - x = getWidth()- Math.abs(x); - } else if (x>0) { - x = x % (getWidth()); - } + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); backMap[x][y] = value; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld", e.toString()); @@ -91,8 +82,8 @@ public class GameWorld { } } - public Vector2 getSpawnPoint(int x) { - int y=0; + public Vector2 getSpawnPoint() { + int x=0,y=0; while (true) { y++; if (getForeMap(x,y)>0 && Items.BLOCKS.getValueAt(getForeMap(x,y)).collision) break; @@ -109,17 +100,11 @@ public class GameWorld { 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(); + public void setMaps(int[][] foreMap, int[][] backMap) { + this.foreMap = foreMap.clone(); + this.backMap = backMap.clone(); WIDTH = foreMap.length; HEIGHT = foreMap[0].length; }