X-Git-Url: https://deadsoftware.ru/gitweb?p=cavedroid.git;a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavecraft%2Fgame%2FGameWorld.java;h=0c3ac52f40fc1804d29017470e315eaffda5ee0c;hp=faf0322ed38491d995f717417069d4f46a291722;hb=4617ae53584520a741f45770e17a2a253717f83a;hpb=5f7d6ee2ded67d412e861f09e102b52efb74d12c diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java index faf0322..0c3ac52 100644 --- a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java +++ b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java @@ -1,22 +1,15 @@ package ru.deadsoftware.cavecraft.game; import com.badlogic.gdx.Gdx; +import com.badlogic.gdx.math.Vector2; 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; } @@ -25,18 +18,30 @@ public class GameWorld { return HEIGHT; } + public int[][] getFullForeMap() { + return foreMap; + } + + public int[][] getFullBackMap() { + return backMap; + } + public int getForeMap(int x, int y) { - int ret = 0; + int map = 0; try { - ret = foreMap[x][y]; + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); + map = foreMap[x][y]; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld",e.toString()); } - return ret; + return map; } public void setForeMap(int x, int y, int value) { try { + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); foreMap[x][y] = value; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld", e.toString()); @@ -44,17 +49,21 @@ public class GameWorld { } public int getBackMap(int x, int y) { - int ret = 0; + int map = 0; try { - ret = backMap[x][y]; + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); + map = backMap[x][y]; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld",e.toString()); } - return ret; + return map; } public void setBackMap(int x, int y, int value) { try { + x = x%getWidth(); + if (x<0) x=getWidth()-Math.abs(x); backMap[x][y] = value; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld", e.toString()); @@ -62,11 +71,42 @@ public class GameWorld { } public void placeToForeground(int x, int y, int value) { - if (getForeMap(x,y) == 0 || value == 0) setForeMap(x,y,value); + if (getForeMap(x,y) == 0 || value == 0) { + setForeMap(x,y,value); + } } public void placeToBackground(int x, int y, int value) { - if (getBackMap(x,y) == 0 || value == 0) setBackMap(x,y,value); + if (value==0 || (getBackMap(x,y) == 0 && !Items.BLOCKS.getValueAt(value).background)) { + setBackMap(x,y,value); + } + } + + public Vector2 getSpawnPoint() { + int x=0,y=0; + while (true) { + y++; + if (getForeMap(x,y)>0 && Items.BLOCKS.getValueAt(getForeMap(x,y)).collision) break; + } + x = x*16 + 4; + 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(); + } + + public void setMaps(int[][] foreMap, int[][] backMap) { + this.foreMap = foreMap.clone(); + this.backMap = backMap.clone(); + WIDTH = foreMap.length; + HEIGHT = foreMap[0].length; } }