X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Fworld%2FGameWorld.java;h=43fc1641033616ec6645795ead6daed286dc82e3;hb=546c7c80eb7884183a3df1db7bb5627a18396dca;hp=a908971baef7191e0f105a1dd7589978de3816a3;hpb=ec0477587e1b23712b9b7f5dd27fd924b9933b96;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 a908971..43fc164 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/world/GameWorld.java +++ b/core/src/ru/deadsoftware/cavedroid/game/world/GameWorld.java @@ -1,7 +1,7 @@ package ru.deadsoftware.cavedroid.game.world; import com.badlogic.gdx.utils.Disposable; -import com.badlogic.gdx.utils.TimeUtils; +import com.badlogic.gdx.utils.Timer; import kotlin.Pair; import ru.deadsoftware.cavedroid.game.GameItems; import ru.deadsoftware.cavedroid.game.GameScope; @@ -14,14 +14,10 @@ import ru.deadsoftware.cavedroid.game.objects.DropController; import javax.annotation.CheckForNull; import javax.inject.Inject; -import java.sql.Time; -import java.util.Timer; @GameScope public class GameWorld implements Disposable { - private static final int DEFAULT_WIDTH = 1024; - private static final int DEFAULT_HEIGHT = 256; private static final int UPDATE_RANGE = 16; private final DropController mDropController; @@ -50,9 +46,10 @@ public class GameWorld implements Disposable { boolean isNewGame = foreMap == null || backMap == null; if (isNewGame) { - mWidth = DEFAULT_WIDTH; - mHeight = DEFAULT_HEIGHT; - Pair maps = new GameWorldGenerator(WorldGeneratorConfig.Companion.getDefaultWithSeed(TimeUtils.millis())).generate(); + final WorldGeneratorConfig config = WorldGeneratorConfig.Companion.getDefault(); + mWidth = config.getWidth(); + mHeight = config.getHeight(); + Pair maps = new GameWorldGenerator(config).generate(); mForeMap = maps.getFirst(); mBackMap = maps.getSecond(); mMobsController.getPlayer().respawn(this); @@ -66,7 +63,7 @@ public class GameWorld implements Disposable { mGameFluidsThread = new GameFluidsThread(this, mMobsController); mGameFluidsTimer = new Timer(); - mGameFluidsTimer.scheduleAtFixedRate(mGameFluidsThread, 0, GameFluidsThread.FLUID_UPDATE_INTERVAL_MS); + mGameFluidsTimer.scheduleTask(mGameFluidsThread, 0, GameFluidsThread.FLUID_UPDATE_INTERVAL_SEC); } public int getWidth() { @@ -216,7 +213,7 @@ public class GameWorld implements Disposable { if (getForeMap(x, y) == 10) { if (!hasForeAt(x, y + 1) || !getForeMapBlock(x, y + 1).hasCollision()) { setForeMap(x, y, 0); - mMobsController.addMob(FallingSand.class, x * 16, y * 16); + mMobsController.addMob(new FallingSand(x * 16, y * 16)); updateBlock(x, y - 1); } } @@ -224,7 +221,7 @@ public class GameWorld implements Disposable { if (getForeMap(x, y) == 11) { if (!hasForeAt(x, y + 1) || !getForeMapBlock(x, y + 1).hasCollision()) { setForeMap(x, y, 0); - mMobsController.addMob(FallingGravel.class, x * 16, y * 16); + mMobsController.addMob(new FallingGravel(x * 16, y * 16)); updateBlock(x, y - 1); } } @@ -257,6 +254,6 @@ public class GameWorld implements Disposable { @Override public void dispose() { - mGameFluidsTimer.cancel(); + mGameFluidsThread.cancel(); } } \ No newline at end of file