X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Fmodel%2Fblock%2FBlock.kt;h=76c6ac580c0df1a6604c447e3f1c0e930496f456;hb=387ad284ceb79b07cba3726fa7350b7e83916815;hp=440d258eb94bbb832df8bedd9e060c3661382079;hpb=6a71a9abc5bc34547c0e4bea7ab19a6bee628a3c;p=cavedroid.git diff --git a/core/src/ru/deadsoftware/cavedroid/game/model/block/Block.kt b/core/src/ru/deadsoftware/cavedroid/game/model/block/Block.kt index 440d258..76c6ac5 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/model/block/Block.kt +++ b/core/src/ru/deadsoftware/cavedroid/game/model/block/Block.kt @@ -4,6 +4,8 @@ import com.badlogic.gdx.graphics.g2d.Sprite import com.badlogic.gdx.graphics.g2d.SpriteBatch import com.badlogic.gdx.math.Rectangle import com.badlogic.gdx.utils.TimeUtils +import ru.deadsoftware.cavedroid.game.model.item.Item +import ru.deadsoftware.cavedroid.misc.utils.colorFromHexString import kotlin.contracts.ExperimentalContracts import kotlin.contracts.contract @@ -15,16 +17,19 @@ sealed class Block { val width: Float get() = 16f - params.collisionMargins.left - params.collisionMargins.right val height: Float get() = 16f - params.collisionMargins.top - params.collisionMargins.bottom - private val spriteWidth: Float get() = 16f - params.spriteMargins.left - params.spriteMargins.right - private val spriteHeight: Float get() = 16f - params.spriteMargins.top - params.spriteMargins.bottom + val spriteWidth: Float get() = 16f - params.spriteMargins.left - params.spriteMargins.right + val spriteHeight: Float get() = 16f - params.spriteMargins.top - params.spriteMargins.bottom private var animation: Array? = null - private var sprite: Sprite? = null + private var _sprite: Sprite? = null get() { return animation?.get(currentAnimationFrame) ?: field } + val sprite: Sprite + get() = requireNotNull(_sprite) { "null sprite for block '${params.key}'" } + private val currentAnimationFrame: Int get() { return params.animationInfo?.let { animInfo -> @@ -32,6 +37,14 @@ sealed class Block { } ?: 0 } + override fun hashCode(): Int { + return params.key.hashCode() + } + + override fun equals(other: Any?): Boolean { + return params.key == (other as Item).params.key + } + fun initialize() { initAnimation() initSprite() @@ -44,24 +57,30 @@ sealed class Block { val width = 16 - params.spriteMargins.left - params.spriteMargins.right val height = 16 - params.spriteMargins.top - params.spriteMargins.bottom Sprite(params.texture, params.spriteMargins.left, 16 * y + params.spriteMargins.top, width, height) - .apply { flip(false, true) } + .apply { + flip(false, true) + params.tint?.let { tint -> color = colorFromHexString(tint) } + } } } } private fun initSprite() { - sprite = animation?.get(0) ?: params.texture?.let { tex -> + _sprite = animation?.get(0) ?: params.texture?.let { tex -> val width = 16 - params.spriteMargins.left - params.spriteMargins.right val height = 16 - params.spriteMargins.top - params.spriteMargins.bottom Sprite(tex, params.spriteMargins.left, params.spriteMargins.top, width, height) - .apply { flip(false, true) } + .apply { + flip(false, true) + params.tint?.let { tint -> color = colorFromHexString(tint) } + } } } fun requireSprite() = requireNotNull(sprite) fun draw(spriter: SpriteBatch, x: Float, y: Float) { - sprite?.apply { + sprite.apply { setBounds( /* x = */ x + params.spriteMargins.left, /* y = */ y + params.spriteMargins.top, @@ -92,6 +111,11 @@ sealed class Block { return this is Slab } + fun isNone(): Boolean { + contract { returns(true) implies (this@Block is None) } + return this is None + } + fun getRectangle(x: Int, y: Int): Rectangle { return Rectangle( /* x = */ x * 16f + params.collisionMargins.left, @@ -101,7 +125,9 @@ sealed class Block { ) } - + data class None( + override val params: CommonBlockParams + ) : Block() data class Normal( override val params: CommonBlockParams, @@ -110,20 +136,21 @@ sealed class Block { data class Slab( override val params: CommonBlockParams, val fullBlockKey: String, + val otherPartBlockKey: String, ): Block() - abstract class Fluid: Block() { - abstract val statesCount: Int + sealed class Fluid: Block() { + abstract val state: Int } data class Water( override val params: CommonBlockParams, - override val statesCount: Int + override val state: Int, ) : Fluid() data class Lava( override val params: CommonBlockParams, - override val statesCount: Int + override val state: Int, ) : Fluid() /* Legacy accessors below */ @@ -146,7 +173,6 @@ sealed class Block { @Deprecated(LEGACY_ACCESSOR_DEPRECATION) fun isTransparent() = params.isTransparent @Deprecated(LEGACY_ACCESSOR_DEPRECATION) fun getTexture() = sprite - companion object { private const val LEGACY_ACCESSOR_DEPRECATION = "legacy accessors will be removed" private const val ANIMATION_FRAME_DURATION_MS = 100L