X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Fworld%2FGameWorld.java;h=0d5a80ae49cf7fccbf9d7c3aff5723e451bf5c84;hb=c447b95aeb883113ff1d53a3178828929c1eb92f;hp=39ae5d39e070c4ec8d24312c21300bd5361214a4;hpb=1c004c0ce7e183e773b5b486295c25e39732e899;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavedroid/game/world/GameWorld.java b/core/src/ru/deadsoftware/cavedroid/game/world/GameWorld.java index 39ae5d3..0d5a80a 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/world/GameWorld.java +++ b/core/src/ru/deadsoftware/cavedroid/game/world/GameWorld.java @@ -1,13 +1,17 @@ package ru.deadsoftware.cavedroid.game.world; import kotlin.Pair; -import ru.deadsoftware.cavedroid.game.GameItems; import ru.deadsoftware.cavedroid.game.GameItemsHolder; import ru.deadsoftware.cavedroid.game.GameScope; import ru.deadsoftware.cavedroid.game.mobs.MobsController; import ru.deadsoftware.cavedroid.game.model.block.Block; +import ru.deadsoftware.cavedroid.game.model.item.InventoryItem; +import ru.deadsoftware.cavedroid.game.model.item.Item; import ru.deadsoftware.cavedroid.game.model.world.generator.WorldGeneratorConfig; -import ru.deadsoftware.cavedroid.game.objects.DropController; +import ru.deadsoftware.cavedroid.game.objects.drop.DropController; +import ru.deadsoftware.cavedroid.game.objects.furnace.Furnace; +import ru.deadsoftware.cavedroid.game.objects.furnace.FurnaceController; +import ru.deadsoftware.cavedroid.misc.utils.MeasureUnitsUtilsKt; import javax.annotation.CheckForNull; import javax.inject.Inject; @@ -18,29 +22,33 @@ public class GameWorld { private final DropController mDropController; private final MobsController mMobsController; private final GameItemsHolder mGameItemsHolder; + private final FurnaceController mFurnaceController; private final int mWidth; private final int mHeight; private final Block[][] mForeMap; private final Block[][] mBackMap; + private final WorldGeneratorConfig mWorldConfig = WorldGeneratorConfig.Companion.getDefault(); + @Inject public GameWorld(DropController dropController, MobsController mobsController, GameItemsHolder gameItemsHolder, + FurnaceController furnaceController, @CheckForNull Block[][] foreMap, @CheckForNull Block[][] backMap) { mDropController = dropController; mMobsController = mobsController; mGameItemsHolder = gameItemsHolder; + mFurnaceController = furnaceController; boolean isNewGame = foreMap == null || backMap == null; if (isNewGame) { - final WorldGeneratorConfig config = WorldGeneratorConfig.Companion.getDefault(); - mWidth = config.getWidth(); - mHeight = config.getHeight(); - Pair maps = new GameWorldGenerator(config, mGameItemsHolder).generate(); + mWidth = mWorldConfig.getWidth(); + mHeight = mWorldConfig.getHeight(); + Pair maps = new GameWorldGenerator(mWorldConfig, mGameItemsHolder).generate(); mForeMap = maps.getFirst(); mBackMap = maps.getSecond(); mMobsController.getPlayer().respawn(this, mGameItemsHolder); @@ -60,12 +68,20 @@ public class GameWorld { return mHeight; } + /** + * @deprecated for kotlin use {@link MeasureUnitsUtilsKt#getPx } extension val + */ + @Deprecated public float getWidthPx() { - return mWidth * 16f; + return MeasureUnitsUtilsKt.getPx(mWidth); } + /** + * @deprecated for kotlin use {@link MeasureUnitsUtilsKt#getPx } extension val + */ + @Deprecated public float getHeightPx() { - return mHeight * 16f; + return MeasureUnitsUtilsKt.getPx(mHeight); } public Block[][] getFullForeMap() { @@ -86,26 +102,49 @@ public class GameWorld { private Block getMap(int x, int y, int layer) { Block map = mGameItemsHolder.getFallbackBlock(); - try { - x = transformX(x); - map = (layer == 0) ? mForeMap[x][y] : mBackMap[x][y]; - } catch (ArrayIndexOutOfBoundsException ignored) { + + if (y < 0 || y >= getHeight()) { + return map; + } + + x = transformX(x); + + if (x < 0 || x >= getWidth()) { + return map; } + + map = (layer == 0) ? mForeMap[x][y] : mBackMap[x][y]; + return map; } private void setMap(int x, int y, int layer, Block value) { - try { - x = transformX(x); - if (layer == 0) { - mForeMap[x][y] = value; - } else { - mBackMap[x][y] = value; - } - } catch (ArrayIndexOutOfBoundsException ignored) { + if (y < 0 || y >= getHeight()) { + return; + } + + x = transformX(x); + + if (x < 0 || x >= getWidth()) { + return; + } + + if (layer == 0) { + mForeMap[x][y] = value; + } else { + mBackMap[x][y] = value; } } + private boolean isSameSlab(Block slab1, Block slab2) { + if (!(slab1 instanceof Block.Slab) || !(slab2 instanceof Block.Slab)) { + return false; + } + + return slab1.getParams().getKey().equals(((Block.Slab) slab2).getOtherPartBlockKey()) + || slab1.getParams().getKey().equals(slab2.getParams().getKey()); + } + public boolean hasForeAt(int x, int y) { return getMap(x, y, 0) != mGameItemsHolder.getFallbackBlock(); } @@ -134,34 +173,89 @@ public class GameWorld { setMap(x, y, 1, block); } - public void placeToForeground(int x, int y, Block value) { + public boolean placeToForeground(int x, int y, Block value) { if (!hasForeAt(x, y) || value == mGameItemsHolder.getFallbackBlock() || !getForeMap(x, y).hasCollision()) { + + if (value.isFurnace()) { + mFurnaceController.addFurnace(x, y, 0); + } + setForeMap(x, y, value); - } else if (value instanceof Block.Slab && getForeMap(x, y) == value) { + return true; + } else if (value instanceof Block.Slab && isSameSlab(value, getForeMap(x, y))) { setForeMap(x, y, mGameItemsHolder.getBlock(((Block.Slab) value).getFullBlockKey())); + return true; } + return false; } - public void placeToBackground(int x, int y, Block value) { + public boolean placeToBackground(int x, int y, Block value) { if (value == mGameItemsHolder.getFallbackBlock() || (getBackMap(x, y) == mGameItemsHolder.getFallbackBlock() && value.hasCollision()) && (!value.isTransparent() || value == mGameItemsHolder.getBlock("glass"))) { + if (value.isFurnace()) { + mFurnaceController.addFurnace(x, y, 1); + } setBackMap(x, y, value); + return true; + } + return false; + } + + private void playerDurateTool() { + final InventoryItem playerCurrentItem = mMobsController.getPlayer().inventory.getActiveItem(); + if (playerCurrentItem.getItem().isTool()) { + mMobsController.getPlayer().decreaseCurrentItemCount(mGameItemsHolder); } } + private boolean shouldDrop(Block block) { + final Item item = mMobsController.getPlayer().inventory.getActiveItem().getItem(); + int toolLevel = item.isTool() ? ((Item.Tool) item).getLevel() : 0; + if (item.isTool() && block.getParams().getToolType() != item.getClass()) { + toolLevel = 0; + } + return toolLevel >= block.getParams().getToolLevel(); + } + public void destroyForeMap(int x, int y) { Block block = getForeMap(x, y); - if (block.hasDrop()) { - mDropController.addDrop(transformX(x) * 16 + 4, y * 16 + 4, GameItems.getItemId(block.getDrop())); + if (block.isFurnace()) { + mFurnaceController.destroyFurnace(x, y, 0, mDropController); } + if (block.hasDrop() && shouldDrop(block)) { + for (int i = 0; i < block.getParams().getDropInfo().getCount(); i++) { + mDropController.addDrop(transformX(x) * 16 + 4, y * 16 + 4, mGameItemsHolder.getItem(block.getDrop())); + } + } + playerDurateTool(); placeToForeground(x, y, mGameItemsHolder.getFallbackBlock()); } + public WorldGeneratorConfig getWorldConfig() { + return mWorldConfig; + } + public void destroyBackMap(int x, int y) { Block block = getBackMap(x, y); - if (block.hasDrop()) { - mDropController.addDrop(transformX(x) * 16 + 4, y * 16 + 4, GameItems.getItemId(block.getDrop())); + if (block.isFurnace()) { + mFurnaceController.destroyFurnace(x, y, 0, mDropController); + } + if (block.hasDrop() && shouldDrop(block)) { + for (int i = 0; i < block.getParams().getDropInfo().getCount(); i++) { + mDropController.addDrop(transformX(x) * 16 + 4, y * 16 + 4, mGameItemsHolder.getItem(block.getDrop())); + } } + playerDurateTool(); placeToBackground(x, y, mGameItemsHolder.getFallbackBlock()); } + + @CheckForNull + public Furnace getForegroundFurnace(int x, int y) { + return mFurnaceController.getFurnace(x, y, 0); + } + + @CheckForNull + public Furnace getBackgroundFurnace(int x, int y) { + return mFurnaceController.getFurnace(x, y, 1); + } } \ No newline at end of file