X-Git-Url: https://deadsoftware.ru/gitweb?a=blobdiff_plain;f=core%2Fsrc%2Fru%2Fdeadsoftware%2Fcavedroid%2Fgame%2Fmodel%2Fblock%2FBlock.kt;h=9669a5378c5f84dbafd7be4a58bc801522f2a3d7;hb=36f78fdd1d4f8b9a1c77f8fbedc05e5675a5c288;hp=2411a6352d963823bb921f1a8a741172150fddfb;hpb=121928e90bdfa3a9d9c8bd708b9f8da28d3807c0;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 2411a63..9669a53 100644 --- a/core/src/ru/deadsoftware/cavedroid/game/model/block/Block.kt +++ b/core/src/ru/deadsoftware/cavedroid/game/model/block/Block.kt @@ -16,8 +16,8 @@ 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 @@ -104,6 +104,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, @@ -113,7 +118,9 @@ sealed class Block { ) } - + data class None( + override val params: CommonBlockParams + ) : Block() data class Normal( override val params: CommonBlockParams, @@ -122,6 +129,7 @@ sealed class Block { data class Slab( override val params: CommonBlockParams, val fullBlockKey: String, + val otherPartBlockKey: String, ): Block() sealed class Fluid: Block() { @@ -158,7 +166,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