X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavecraft%2Fgame%2FGameWorld.java;h=064eca58ffa72052a0b6afd0695aea1772c159c2;hb=f7cc93fff73659b11d3666cdfd92efca1bf403dd;hp=97d05cb2d41f5767cd88482f27c238453da61f41;hpb=a7ae39b1ed142e467b11689cd47010e5b9f90ceb;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java index 97d05cb..064eca5 100644 --- a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java +++ b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java @@ -7,6 +7,7 @@ import ru.deadsoftware.cavecraft.Items; public class GameWorld { private final int WIDTH, HEIGHT; + private int[][] foreMap; private int[][] backMap; @@ -28,17 +29,29 @@ public class GameWorld { } public int getForeMap(int x, int y) { - int ret = 0; + int map = 0; try { - ret = foreMap[x][y]; + if (x<0) { + x = x % (getWidth()); + x = getWidth()- Math.abs(x); + } else if (x>0) { + x = x % (getWidth()); + } + 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 { + if (x<0) { + x = x % (getWidth()); + x = getWidth()- Math.abs(x); + } else if (x>0) { + x = x % (getWidth()); + } foreMap[x][y] = value; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld", e.toString()); @@ -46,17 +59,29 @@ public class GameWorld { } public int getBackMap(int x, int y) { - int ret = 0; + int map = 0; try { - ret = backMap[x][y]; + if (x<0) { + x = x % (getWidth()); + x = getWidth()- Math.abs(x); + } else if (x>0) { + x = x % (getWidth()); + } + 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 { + if (x<0) { + x = x % (getWidth()); + x = getWidth()- Math.abs(x); + } else if (x>0) { + x = x % (getWidth()); + } backMap[x][y] = value; } catch (ArrayIndexOutOfBoundsException e) { Gdx.app.error("GameWorld", e.toString()); @@ -64,31 +89,25 @@ 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 (value==0 || (getBackMap(x,y) == 0 && !Items.BLOCKS.getValueAt(value).foreground)) - setBackMap(x,y,value); + if (value==0 || (getBackMap(x,y) == 0 && !Items.BLOCKS.getValueAt(value).foreground)) { + setBackMap(x,y,value); + } } - public Vector2 getSpawnPoint() { - float x=0, y=0; - boolean found = false; - x = getWidth()/2; - while (!found) { - for (int i = 0; i < getHeight(); i++) { - if (getForeMap((int)x, i)>0 && - Items.BLOCKS.getValueAt(getForeMap((int)x, i)).collision) { - y = i-3; - found = true; - break; - } - } - if (!found) x--; + public Vector2 getSpawnPoint(int x) { + int y=0; + while (true) { + y++; + if (getForeMap(x,y)>0 && Items.BLOCKS.getValueAt(getForeMap(x,y)).collision) break; } x = x*16 + 4; - y *= 16; + y = y*16 - 32; return new Vector2(x,y); }