mirror of
https://gitlab.bixilon.de/bixilon/minosoft.git
synced 2025-09-18 03:44:54 -04:00
move some fluid blocks, WaterloggableBlock, fix fluid rendering
This commit is contained in:
parent
432d783849
commit
217e78dd9a
@ -17,7 +17,7 @@ import de.bixilon.minosoft.data.registries.blocks.settings.BlockSettings
|
|||||||
import de.bixilon.minosoft.data.registries.blocks.types.Block
|
import de.bixilon.minosoft.data.registries.blocks.types.Block
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.air.AirBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.air.AirBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.fluid.LavaFluidBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.LavaFluidBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.fluid.WaterFluidBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.water.WaterFluidBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.stone.RockBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.stone.RockBlock
|
||||||
import de.bixilon.minosoft.data.registries.factory.DefaultFactory
|
import de.bixilon.minosoft.data.registries.factory.DefaultFactory
|
||||||
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
||||||
|
@ -19,7 +19,6 @@ import de.bixilon.minosoft.data.registries.blocks.light.CustomLightProperties
|
|||||||
import de.bixilon.minosoft.data.registries.blocks.settings.BlockSettings
|
import de.bixilon.minosoft.data.registries.blocks.settings.BlockSettings
|
||||||
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.Block
|
import de.bixilon.minosoft.data.registries.blocks.types.Block
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidFilled
|
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.LightedBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.LightedBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.ShapedBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.ShapedBlock
|
||||||
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
||||||
@ -29,7 +28,7 @@ import de.bixilon.minosoft.gui.rendering.util.vec.vec3.Vec3Util.EMPTY
|
|||||||
import de.bixilon.minosoft.protocol.network.connection.play.PlayConnection
|
import de.bixilon.minosoft.protocol.network.connection.play.PlayConnection
|
||||||
import java.util.*
|
import java.util.*
|
||||||
|
|
||||||
abstract class FluidBlock(identifier: ResourceLocation, settings: BlockSettings) : Block(identifier, settings), FluidFilled, ShapedBlock, LightedBlock {
|
abstract class FluidBlock(identifier: ResourceLocation, settings: BlockSettings) : Block(identifier, settings), FluidHolder, ShapedBlock, LightedBlock {
|
||||||
|
|
||||||
override fun getOutlineShape(connection: PlayConnection, blockState: BlockState): VoxelShape {
|
override fun getOutlineShape(connection: PlayConnection, blockState: BlockState): VoxelShape {
|
||||||
return VoxelShape(mutableListOf(AABB(Vec3.EMPTY, Vec3(1.0f, fluid.getHeight(blockState), 1.0f))))
|
return VoxelShape(mutableListOf(AABB(Vec3.EMPTY, Vec3(1.0f, fluid.getHeight(blockState), 1.0f))))
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer
|
package de.bixilon.minosoft.data.registries.blocks.types.fluid
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A block that is fluid filled, e.g. water or kelp (filled with water)
|
* A block that is fluid filled, e.g. water or kelp (filled with water)
|
@ -11,7 +11,7 @@
|
|||||||
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer
|
package de.bixilon.minosoft.data.registries.blocks.types.fluid
|
||||||
|
|
||||||
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
||||||
|
|
@ -11,16 +11,17 @@
|
|||||||
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package de.bixilon.minosoft.data.registries.blocks.types.fluid
|
package de.bixilon.minosoft.data.registries.blocks.types.fluid.water
|
||||||
|
|
||||||
import de.bixilon.kutil.cast.CastUtil.unsafeNull
|
import de.bixilon.kutil.cast.CastUtil.unsafeNull
|
||||||
import de.bixilon.minosoft.data.registries.blocks.factory.BlockFactory
|
import de.bixilon.minosoft.data.registries.blocks.factory.BlockFactory
|
||||||
import de.bixilon.minosoft.data.registries.blocks.settings.BlockSettings
|
import de.bixilon.minosoft.data.registries.blocks.settings.BlockSettings
|
||||||
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidBlock
|
||||||
import de.bixilon.minosoft.data.registries.fluid.fluids.flowable.water.WaterFluid
|
import de.bixilon.minosoft.data.registries.fluid.fluids.flowable.water.WaterFluid
|
||||||
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
||||||
import de.bixilon.minosoft.data.registries.registries.Registries
|
import de.bixilon.minosoft.data.registries.registries.Registries
|
||||||
|
|
||||||
class WaterFluidBlock(identifier: ResourceLocation = this.identifier, settings: BlockSettings) : FluidBlock(identifier, settings) {
|
class WaterFluidBlock(identifier: ResourceLocation = Companion.identifier, settings: BlockSettings) : FluidBlock(identifier, settings) {
|
||||||
override val fluid: WaterFluid = unsafeNull()
|
override val fluid: WaterFluid = unsafeNull()
|
||||||
|
|
||||||
init {
|
init {
|
@ -0,0 +1,16 @@
|
|||||||
|
/*
|
||||||
|
* Minosoft
|
||||||
|
* Copyright (C) 2020-2023 Moritz Zwerger
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
* This software is not affiliated with Mojang AB, the original developer of Minecraft.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package de.bixilon.minosoft.data.registries.blocks.types.fluid.water
|
||||||
|
|
||||||
|
interface WaterloggableBlock
|
@ -26,6 +26,7 @@ import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
|||||||
import de.bixilon.minosoft.data.registries.blocks.state.builder.BlockStateBuilder
|
import de.bixilon.minosoft.data.registries.blocks.state.builder.BlockStateBuilder
|
||||||
import de.bixilon.minosoft.data.registries.blocks.state.builder.BlockStateSettings
|
import de.bixilon.minosoft.data.registries.blocks.state.builder.BlockStateSettings
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.Block
|
import de.bixilon.minosoft.data.registries.blocks.types.Block
|
||||||
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.water.WaterloggableBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.FrictionBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.FrictionBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.JumpBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.JumpBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.ReplaceableBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.ReplaceableBlock
|
||||||
@ -49,7 +50,7 @@ open class PixLyzerBlock(
|
|||||||
identifier: ResourceLocation,
|
identifier: ResourceLocation,
|
||||||
registries: Registries,
|
registries: Registries,
|
||||||
data: Map<String, Any>,
|
data: Map<String, Any>,
|
||||||
) : Block(identifier, BlockSettings(soundGroup = data["sound_group"]?.toInt()?.let { registries.soundGroup[it] }, item = data["item"]?.toInt())), FrictionBlock, JumpBlock, VelocityBlock, RandomOffsetBlock, ShapedBlock, BlockStateBuilder, ReplaceableBlock, PotentialFullOpaqueBlock {
|
) : Block(identifier, BlockSettings(soundGroup = data["sound_group"]?.toInt()?.let { registries.soundGroup[it] }, item = data["item"]?.toInt())), FrictionBlock, JumpBlock, VelocityBlock, RandomOffsetBlock, ShapedBlock, BlockStateBuilder, ReplaceableBlock, PotentialFullOpaqueBlock, WaterloggableBlock {
|
||||||
|
|
||||||
override val randomOffset: RandomOffsetTypes? = data["offset_type"].nullCast<String>()?.let { RandomOffsetTypes[it] }
|
override val randomOffset: RandomOffsetTypes? = data["offset_type"].nullCast<String>()?.let { RandomOffsetTypes[it] }
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.water
|
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.water
|
||||||
|
|
||||||
import de.bixilon.minosoft.data.registries.blocks.factory.PixLyzerBlockFactory
|
import de.bixilon.minosoft.data.registries.blocks.factory.PixLyzerBlockFactory
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidFilled
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidFilled
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.PixLyzerBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.PixLyzerBlock
|
||||||
import de.bixilon.minosoft.data.registries.fluid.DefaultFluids
|
import de.bixilon.minosoft.data.registries.fluid.DefaultFluids
|
||||||
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.water
|
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.water
|
||||||
|
|
||||||
import de.bixilon.minosoft.data.registries.blocks.factory.PixLyzerBlockFactory
|
import de.bixilon.minosoft.data.registries.blocks.factory.PixLyzerBlockFactory
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidFilled
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidFilled
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.PixLyzerBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.PixLyzerBlock
|
||||||
import de.bixilon.minosoft.data.registries.fluid.DefaultFluids
|
import de.bixilon.minosoft.data.registries.fluid.DefaultFluids
|
||||||
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.water
|
package de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.water
|
||||||
|
|
||||||
import de.bixilon.minosoft.data.registries.blocks.factory.PixLyzerBlockFactory
|
import de.bixilon.minosoft.data.registries.blocks.factory.PixLyzerBlockFactory
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidFilled
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidFilled
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.PixLyzerBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.PixLyzerBlock
|
||||||
import de.bixilon.minosoft.data.registries.factory.clazz.MultiClassFactory
|
import de.bixilon.minosoft.data.registries.factory.clazz.MultiClassFactory
|
||||||
import de.bixilon.minosoft.data.registries.fluid.DefaultFluids
|
import de.bixilon.minosoft.data.registries.fluid.DefaultFluids
|
||||||
|
@ -21,8 +21,8 @@ import de.bixilon.minosoft.data.registries.blocks.properties.BlockProperties
|
|||||||
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
||||||
import de.bixilon.minosoft.data.registries.blocks.state.PropertyBlockState
|
import de.bixilon.minosoft.data.registries.blocks.state.PropertyBlockState
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidFilled
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidFilled
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidHolder
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidHolder
|
||||||
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
import de.bixilon.minosoft.data.registries.identified.ResourceLocation
|
||||||
import de.bixilon.minosoft.data.registries.registries.registry.RegistryItem
|
import de.bixilon.minosoft.data.registries.registries.registry.RegistryItem
|
||||||
import de.bixilon.minosoft.gui.rendering.models.unbaked.fluid.FluidModel
|
import de.bixilon.minosoft.gui.rendering.models.unbaked.fluid.FluidModel
|
||||||
|
@ -22,6 +22,7 @@ import de.bixilon.minosoft.data.entities.entities.player.local.LocalPlayerEntity
|
|||||||
import de.bixilon.minosoft.data.registries.blocks.properties.BlockProperties
|
import de.bixilon.minosoft.data.registries.blocks.properties.BlockProperties
|
||||||
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
||||||
import de.bixilon.minosoft.data.registries.blocks.state.PropertyBlockState
|
import de.bixilon.minosoft.data.registries.blocks.state.PropertyBlockState
|
||||||
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.water.WaterloggableBlock
|
||||||
import de.bixilon.minosoft.data.registries.effects.movement.MovementEffect
|
import de.bixilon.minosoft.data.registries.effects.movement.MovementEffect
|
||||||
import de.bixilon.minosoft.data.registries.enchantment.armor.ArmorEnchantment
|
import de.bixilon.minosoft.data.registries.enchantment.armor.ArmorEnchantment
|
||||||
import de.bixilon.minosoft.data.registries.fluid.FluidFactory
|
import de.bixilon.minosoft.data.registries.fluid.FluidFactory
|
||||||
@ -133,6 +134,7 @@ class WaterFluid(resourceLocation: ResourceLocation = this.identifier) : Flowabl
|
|||||||
|
|
||||||
|
|
||||||
fun BlockState.isWaterlogged(): Boolean {
|
fun BlockState.isWaterlogged(): Boolean {
|
||||||
|
if (this.block !is WaterloggableBlock) return false
|
||||||
if (this !is PropertyBlockState) return false
|
if (this !is PropertyBlockState) return false
|
||||||
return properties[BlockProperties.WATERLOGGED]?.toBoolean() ?: return false
|
return properties[BlockProperties.WATERLOGGED]?.toBoolean() ?: return false
|
||||||
}
|
}
|
||||||
|
@ -17,7 +17,8 @@ import de.bixilon.minosoft.data.Axes
|
|||||||
import de.bixilon.minosoft.data.direction.Directions
|
import de.bixilon.minosoft.data.direction.Directions
|
||||||
import de.bixilon.minosoft.data.registries.blocks.cube.CubeDirections
|
import de.bixilon.minosoft.data.registries.blocks.cube.CubeDirections
|
||||||
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidFilled
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidBlock
|
||||||
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidFilled
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.FullOpaqueBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.FullOpaqueBlock
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.PotentialFullOpaqueBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.PotentialFullOpaqueBlock
|
||||||
import de.bixilon.minosoft.data.registries.fluid.fluids.flowable.water.WaterFluid.Companion.isWaterlogged
|
import de.bixilon.minosoft.data.registries.fluid.fluids.flowable.water.WaterFluid.Companion.isWaterlogged
|
||||||
@ -85,7 +86,7 @@ class BlockSectionDataProvider(
|
|||||||
|
|
||||||
private fun BlockState?.isFluid(): Boolean {
|
private fun BlockState?.isFluid(): Boolean {
|
||||||
if (this == null) return false
|
if (this == null) return false
|
||||||
if (this.block is FluidFilled) {
|
if (this.block is FluidFilled || this.block is FluidBlock) {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
if (this.isWaterlogged()) {
|
if (this.isWaterlogged()) {
|
||||||
|
@ -22,7 +22,7 @@ import de.bixilon.kotlinglm.vec3.Vec3i
|
|||||||
import de.bixilon.kutil.cast.CastUtil.nullCast
|
import de.bixilon.kutil.cast.CastUtil.nullCast
|
||||||
import de.bixilon.minosoft.data.direction.Directions
|
import de.bixilon.minosoft.data.direction.Directions
|
||||||
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
import de.bixilon.minosoft.data.registries.blocks.state.BlockState
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.pixlyzer.FluidHolder
|
import de.bixilon.minosoft.data.registries.blocks.types.fluid.FluidHolder
|
||||||
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.PotentialFullOpaqueBlock
|
import de.bixilon.minosoft.data.registries.blocks.types.properties.shape.PotentialFullOpaqueBlock
|
||||||
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
import de.bixilon.minosoft.data.registries.fluid.fluids.Fluid
|
||||||
import de.bixilon.minosoft.data.registries.fluid.fluids.flowable.FlowableFluid
|
import de.bixilon.minosoft.data.registries.fluid.fluids.flowable.FlowableFluid
|
||||||
@ -283,8 +283,8 @@ class FluidCullSectionPreparer(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!fluid.matches(blockState)) {
|
if (!fluid.matches(blockState)) {
|
||||||
// TODO: this was blockState.material.solid
|
// TODO: this was !blockState.material.solid
|
||||||
if (blockState.block is PotentialFullOpaqueBlock && blockState.block.isFullOpaque(blockState)) {
|
if (blockState.block !is PotentialFullOpaqueBlock || !blockState.block.isFullOpaque(blockState)) {
|
||||||
count++
|
count++
|
||||||
}
|
}
|
||||||
continue
|
continue
|
||||||
|
Loading…
x
Reference in New Issue
Block a user