X-Git-Url: https://deadsoftware.ru/gitweb?p=cavedroid.git;a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavecraft%2Fgame%2FGameWorld.java;h=25d3660fc1cf29d9a01b25560e9a2b16baaa4a46;hp=88f435b78631f11c1296087bd6b697ca29989d61;hb=cef4b5a9985bcbdfea6dc652147ecde0721d7fdc;hpb=7f1f702250f9cd05c1d7f5492e09ba16a56270ae diff --git a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java index 88f435b..25d3660 100644 --- a/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java +++ b/core/src/ru/deadsoftware/cavecraft/game/GameWorld.java @@ -1,7 +1,6 @@ package ru.deadsoftware.cavecraft.game; -import com.badlogic.gdx.Gdx; -import com.badlogic.gdx.math.Vector2; +import ru.deadsoftware.cavecraft.game.objects.Drop; public class GameWorld { @@ -17,6 +16,14 @@ public class GameWorld { return HEIGHT; } + public float getWidthPx() { + return WIDTH * 16f; + } + + public float getHeightPx() { + return HEIGHT * 16f; + } + public int[][] getFullForeMap() { return foreMap; } @@ -26,8 +33,8 @@ public class GameWorld { } private int transformX(int x) { - x = x%getWidth(); - if (x<0) x=getWidth()-Math.abs(x); + x = x % getWidth(); + if (x < 0) x = getWidth() - Math.abs(x); return x; } @@ -95,38 +102,39 @@ public class GameWorld { } public void placeToForeground(int x, int y, int value) { - if (getForeMap(x,y) == 0 || value == 0 || !Items.BLOCKS.getValueAt(getForeMap(x, y)).collision) { + if (getForeMap(x, y) == 0 || value == 0 || !GameItems.getBlock(getForeMap(x, y)).hasCollision()) { setForeMap(x, y, value); - } else if (Items.isSlab(value) && getForeMap(x, y) == value) { + } else if (GameItems.isSlab(value) && getForeMap(x, y) == value) { placeSlab(x, y, value); } - GameProc.UPD_X = x-8; - GameProc.UPD_Y = y-8; + GameProc.UPD_X = x - 8; + GameProc.UPD_Y = y - 8; GameProc.DO_UPD = true; } public void placeToBackground(int x, int y, int value) { - if (value==0 || (getBackMap(x,y) == 0 && Items.BLOCKS.getValueAt(value).collision) && - (!Items.BLOCKS.getValueAt(value).transparent || value == 18)) { - setBackMap(x,y,value); + if (value == 0 || (getBackMap(x, y) == 0 && GameItems.getBlock(value).hasCollision()) && + (!GameItems.getBlock(value).isTransparent() || value == 18)) { + 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 destroyForeMap(int x, int y, GameProc gp) { + if (GameItems.getBlock(getForeMap(x, y)).getDrop() > 0) + gp.drops.add(new Drop(transformX(x) * 16 + 4, y * 16 + 4, GameItems.getBlock(getForeMap(x, y)).getDrop())); + placeToForeground(x, y, 0); + } + + public void destroyBackMap(int x, int y, GameProc gp) { + if (GameItems.getBlock(getBackMap(x, y)).getDrop() > 0) + gp.drops.add(new Drop(transformX(x) * 16 + 4, y * 16 + 4, GameItems.getBlock(getBackMap(x, y)).getDrop())); + placeToBackground(x, y, 0); } public void generate(int w, int h) { WIDTH = w; HEIGHT = h; - WorldGen.genWorld(WIDTH,HEIGHT); + WorldGen.genWorld(WIDTH, HEIGHT); foreMap = WorldGen.getForeMap(); backMap = WorldGen.getBackMap(); WorldGen.clear();