89 lines
3.8 KiB
Kotlin
89 lines
3.8 KiB
Kotlin
package mods.betterfoliage.client.render
|
|
|
|
import mods.betterfoliage.BetterFoliageMod
|
|
import mods.betterfoliage.client.config.Config
|
|
import mods.octarinecore.client.render.BlockContext
|
|
import mods.octarinecore.client.resource.ModelVariant
|
|
import mods.octarinecore.client.resource.TextureListModelProcessor
|
|
import mods.octarinecore.client.resource.registerSprite
|
|
import mods.octarinecore.common.config.ConfigurableBlockMatcher
|
|
import mods.octarinecore.common.config.ModelTextureList
|
|
import mods.octarinecore.findFirst
|
|
import mods.octarinecore.tryDefault
|
|
import net.minecraft.block.BlockLog
|
|
import net.minecraft.block.state.IBlockState
|
|
import net.minecraft.client.renderer.texture.TextureMap
|
|
import net.minecraft.util.EnumFacing.Axis
|
|
import net.minecraftforge.common.MinecraftForge
|
|
import net.minecraftforge.fml.relauncher.Side
|
|
import net.minecraftforge.fml.relauncher.SideOnly
|
|
|
|
|
|
class RenderLog : AbstractRenderColumn(BetterFoliageMod.MOD_ID) {
|
|
|
|
override val addToCutout: Boolean get() = false
|
|
|
|
override fun isEligible(ctx: BlockContext) =
|
|
Config.enabled && Config.roundLogs.enabled &&
|
|
Config.blocks.logClasses.matchesClass(ctx.block)
|
|
|
|
override val registry: IColumnRegistry get() = LogRegistry
|
|
|
|
override val blockPredicate = { state: IBlockState -> Config.blocks.logClasses.matchesClass(state.block) }
|
|
override val surroundPredicate = { state: IBlockState -> state.isOpaqueCube && !Config.blocks.logClasses.matchesClass(state.block) }
|
|
|
|
override val connectPerpendicular: Boolean get() = Config.roundLogs.connectPerpendicular
|
|
override val connectSolids: Boolean get() = Config.roundLogs.connectSolids
|
|
override val lenientConnect: Boolean get() = Config.roundLogs.lenientConnect
|
|
override val radiusLarge: Double get() = Config.roundLogs.radiusLarge
|
|
override val radiusSmall: Double get() = Config.roundLogs.radiusSmall
|
|
|
|
}
|
|
|
|
@SideOnly(Side.CLIENT)
|
|
object LogRegistry : IColumnRegistry {
|
|
val subRegistries: MutableList<IColumnRegistry> = mutableListOf()
|
|
override fun get(state: IBlockState, rand: Int) = subRegistries.findFirst { it[state, rand] }
|
|
}
|
|
|
|
@SideOnly(Side.CLIENT)
|
|
object StandardLogSupport : TextureListModelProcessor<IColumnTextureInfo>, IColumnRegistry {
|
|
|
|
init {
|
|
LogRegistry.subRegistries.add(this)
|
|
MinecraftForge.EVENT_BUS.register(this)
|
|
}
|
|
|
|
override var variants = mutableMapOf<IBlockState, MutableList<ModelVariant>>()
|
|
override var variantToKey = mutableMapOf<ModelVariant, List<String>>()
|
|
override var variantToValue = mapOf<ModelVariant, IColumnTextureInfo>()
|
|
|
|
override val logger = BetterFoliageMod.logDetail
|
|
override val logName = "StandardLogSupport"
|
|
override val matchClasses: ConfigurableBlockMatcher get() = Config.blocks.logClasses
|
|
override val modelTextures: List<ModelTextureList> get() = Config.blocks.logModels.list
|
|
|
|
override fun processStitch(variant: ModelVariant, key: List<String>, atlas: TextureMap): IColumnTextureInfo? {
|
|
val topTex = atlas.registerSprite(key[0])
|
|
val bottomTex = atlas.registerSprite(key[1])
|
|
val sideTexList = key.drop(2).map { atlas.registerSprite(it) }
|
|
if (sideTexList.isEmpty()) return null
|
|
return StaticColumnInfo(getAxis(variant.state), topTex, bottomTex, sideTexList)
|
|
}
|
|
|
|
override fun get(state: IBlockState, rand: Int): IColumnTextureInfo? {
|
|
val variant = getVariant(state, rand) ?: return null
|
|
return variantToValue[variant]
|
|
}
|
|
|
|
fun getAxis(state: IBlockState): Axis? {
|
|
val axis = tryDefault(null) { state.getValue(BlockLog.LOG_AXIS).toString() } ?:
|
|
state.properties.entries.find { it.key.getName().toLowerCase() == "axis" }?.value?.toString()
|
|
return when (axis) {
|
|
"x" -> Axis.X
|
|
"y" -> Axis.Y
|
|
"z" -> Axis.Z
|
|
else -> null
|
|
}
|
|
}
|
|
} |