X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavecraft%2Fgame%2FGameWorld.java;h=63169fbb7d5d6b8de1e753398add86cd095fb2e0;hb=08def9aa287e5309c12c6a4110f6b8486afd3a6c;hp=064eca58ffa72052a0b6afd0695aea1772c159c2;hpb=f7cc93fff73659b11d3666cdfd92efca1bf403dd;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java index 064eca5..63169fb 100644 --- a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java +++ b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java @@ -6,20 +6,11 @@ import ru.deadsoftware.cavecraft.Items; 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; } @@ -28,15 +19,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()); @@ -46,12 +41,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()); @@ -61,12 +52,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()); @@ -76,12 +63,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()); @@ -100,8 +83,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; @@ -111,4 +94,21 @@ public class GameWorld { 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(); + } + + public void load() { + GameSaver.loadWorld(); + foreMap = GameSaver.getLoadedForeMap(); + backMap = GameSaver.getLoadedBackMap(); + WIDTH = foreMap.length; + HEIGHT = foreMap[0].length; + } + }