2020-10-19 22:07:05 +02:00
|
|
|
package com.simibubi.create;
|
|
|
|
|
2022-08-01 22:37:39 +02:00
|
|
|
import java.util.function.Consumer;
|
|
|
|
|
2020-12-03 20:41:55 +01:00
|
|
|
import javax.annotation.Nullable;
|
|
|
|
|
2021-06-26 09:30:01 +02:00
|
|
|
import com.simibubi.create.AllTags.AllFluidTags;
|
2020-12-03 20:41:55 +01:00
|
|
|
import com.simibubi.create.content.contraptions.fluids.VirtualFluid;
|
2020-10-19 22:07:05 +02:00
|
|
|
import com.simibubi.create.content.contraptions.fluids.potion.PotionFluid;
|
2022-08-01 22:37:39 +02:00
|
|
|
import com.simibubi.create.content.contraptions.fluids.potion.PotionFluid.PotionFluidType;
|
2021-12-04 04:17:42 +01:00
|
|
|
import com.simibubi.create.content.palettes.AllPaletteStoneTypes;
|
2020-10-19 22:07:05 +02:00
|
|
|
import com.simibubi.create.foundation.data.CreateRegistrate;
|
2021-05-23 03:00:10 +02:00
|
|
|
import com.tterrag.registrate.util.entry.FluidEntry;
|
2020-10-19 22:07:05 +02:00
|
|
|
|
2021-11-02 00:08:20 +01:00
|
|
|
import net.minecraft.client.renderer.ItemBlockRenderTypes;
|
2021-11-02 06:18:30 +01:00
|
|
|
import net.minecraft.client.renderer.RenderType;
|
2021-11-02 00:08:20 +01:00
|
|
|
import net.minecraft.core.BlockPos;
|
2022-08-01 22:37:39 +02:00
|
|
|
import net.minecraft.resources.ResourceLocation;
|
2021-11-02 00:08:20 +01:00
|
|
|
import net.minecraft.world.level.BlockAndTintGetter;
|
2021-11-02 06:18:30 +01:00
|
|
|
import net.minecraft.world.level.block.state.BlockState;
|
|
|
|
import net.minecraft.world.level.material.Fluid;
|
|
|
|
import net.minecraft.world.level.material.FluidState;
|
2020-12-03 20:41:55 +01:00
|
|
|
import net.minecraftforge.api.distmarker.Dist;
|
|
|
|
import net.minecraftforge.api.distmarker.OnlyIn;
|
2022-08-01 22:37:39 +02:00
|
|
|
import net.minecraftforge.client.extensions.common.IClientFluidTypeExtensions;
|
|
|
|
import net.minecraftforge.fluids.FluidStack;
|
|
|
|
import net.minecraftforge.fluids.FluidType;
|
2020-12-03 20:41:55 +01:00
|
|
|
import net.minecraftforge.fluids.ForgeFlowingFluid;
|
|
|
|
|
2020-10-19 22:07:05 +02:00
|
|
|
public class AllFluids {
|
|
|
|
|
|
|
|
private static final CreateRegistrate REGISTRATE = Create.registrate();
|
|
|
|
|
2021-06-26 09:30:01 +02:00
|
|
|
public static final FluidEntry<PotionFluid> POTION =
|
2022-08-01 22:37:39 +02:00
|
|
|
REGISTRATE.virtualFluid("potion", PotionFluidType::new, PotionFluid::new)
|
|
|
|
.lang(f -> "fluid.create.potion", "Potion")
|
|
|
|
.register();
|
2020-12-03 20:41:55 +01:00
|
|
|
|
2021-06-26 09:30:01 +02:00
|
|
|
public static final FluidEntry<VirtualFluid> TEA = REGISTRATE.virtualFluid("tea")
|
2022-08-01 22:37:39 +02:00
|
|
|
.lang(f -> "fluid.create.tea", "Builder's Tea")
|
|
|
|
.tag(AllTags.forgeFluidTag("tea"))
|
|
|
|
.register();
|
2020-12-03 20:41:55 +01:00
|
|
|
|
2021-06-26 09:30:01 +02:00
|
|
|
public static final FluidEntry<ForgeFlowingFluid.Flowing> HONEY =
|
2022-08-01 22:37:39 +02:00
|
|
|
REGISTRATE.standardFluid("honey", NoColorFluidAttributes::new)
|
|
|
|
.lang(f -> "fluid.create.honey", "Honey")
|
|
|
|
.properties(b -> b.viscosity(2000)
|
|
|
|
.density(1400))
|
|
|
|
.fluidProperties(p -> p.levelDecreasePerBlock(2)
|
|
|
|
.tickRate(25)
|
|
|
|
.slopeFindDistance(3)
|
|
|
|
.explosionResistance(100f))
|
|
|
|
.tag(AllFluidTags.HONEY.tag)
|
|
|
|
.source(ForgeFlowingFluid.Source::new) // TODO: remove when Registrate fixes FluidBuilder
|
|
|
|
.bucket()
|
|
|
|
.tag(AllTags.forgeItemTag("buckets/honey"))
|
|
|
|
.build()
|
|
|
|
.register();
|
2020-10-19 22:07:05 +02:00
|
|
|
|
2021-06-26 09:30:01 +02:00
|
|
|
public static final FluidEntry<ForgeFlowingFluid.Flowing> CHOCOLATE =
|
2022-08-01 22:37:39 +02:00
|
|
|
REGISTRATE.standardFluid("chocolate", NoColorFluidAttributes::new)
|
|
|
|
.lang(f -> "fluid.create.chocolate", "Chocolate")
|
|
|
|
.tag(AllTags.forgeFluidTag("chocolate"))
|
|
|
|
.properties(b -> b.viscosity(1500)
|
|
|
|
.density(1400))
|
|
|
|
.fluidProperties(p -> p.levelDecreasePerBlock(2)
|
|
|
|
.tickRate(25)
|
|
|
|
.slopeFindDistance(3)
|
|
|
|
.explosionResistance(100f))
|
|
|
|
.register();
|
2020-10-19 22:07:05 +02:00
|
|
|
|
|
|
|
// Load this class
|
|
|
|
|
|
|
|
public static void register() {}
|
|
|
|
|
2020-12-03 20:41:55 +01:00
|
|
|
@OnlyIn(Dist.CLIENT)
|
2020-12-04 23:31:12 +01:00
|
|
|
public static void assignRenderLayers() {}
|
2020-12-03 20:41:55 +01:00
|
|
|
|
|
|
|
@OnlyIn(Dist.CLIENT)
|
2021-05-23 03:00:10 +02:00
|
|
|
private static void makeTranslucent(FluidEntry<?> entry) {
|
2020-12-03 20:41:55 +01:00
|
|
|
ForgeFlowingFluid fluid = entry.get();
|
2021-11-02 00:08:20 +01:00
|
|
|
ItemBlockRenderTypes.setRenderLayer(fluid, RenderType.translucent());
|
|
|
|
ItemBlockRenderTypes.setRenderLayer(fluid.getSource(), RenderType.translucent());
|
2020-12-03 20:41:55 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Nullable
|
2020-12-05 11:42:14 +01:00
|
|
|
public static BlockState getLavaInteraction(FluidState fluidState) {
|
2021-07-15 11:32:03 +02:00
|
|
|
Fluid fluid = fluidState.getType();
|
2021-12-04 04:17:42 +01:00
|
|
|
if (fluid.isSame(HONEY.get()))
|
|
|
|
return AllPaletteStoneTypes.LIMESTONE.getBaseBlock()
|
|
|
|
.get()
|
|
|
|
.defaultBlockState();
|
|
|
|
if (fluid.isSame(CHOCOLATE.get()))
|
|
|
|
return AllPaletteStoneTypes.SCORIA.getBaseBlock()
|
|
|
|
.get()
|
|
|
|
.defaultBlockState();
|
2020-12-03 20:41:55 +01:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2022-08-01 22:37:39 +02:00
|
|
|
public static abstract class TintedFluidType extends FluidType {
|
|
|
|
|
|
|
|
protected static final int NO_TINT = 0xffffffff;
|
|
|
|
private ResourceLocation stillTexture;
|
|
|
|
private ResourceLocation flowingTexture;
|
|
|
|
|
|
|
|
public TintedFluidType(Properties properties, ResourceLocation stillTexture, ResourceLocation flowingTexture) {
|
|
|
|
super(properties);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void initializeClient(Consumer<IClientFluidTypeExtensions> consumer) {
|
|
|
|
consumer.accept(new IClientFluidTypeExtensions() {
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public ResourceLocation getFlowingTexture() {
|
|
|
|
return flowingTexture;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public ResourceLocation getStillTexture() {
|
|
|
|
return stillTexture;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getTintColor(FluidStack stack) {
|
|
|
|
return getTintColor(stack);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getTintColor(FluidState state, BlockAndTintGetter getter, BlockPos pos) {
|
|
|
|
return getTintColor(state, getter, pos);
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
protected abstract int getTintColor(FluidStack stack);
|
|
|
|
|
|
|
|
protected abstract int getTintColor(FluidState state, BlockAndTintGetter getter, BlockPos pos);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2020-12-04 23:31:12 +01:00
|
|
|
/**
|
|
|
|
* Removing alpha from tint prevents optifine from forcibly applying biome
|
|
|
|
* colors to modded fluids (Makes translucent fluids disappear)
|
|
|
|
*/
|
2022-08-01 22:37:39 +02:00
|
|
|
private static class NoColorFluidAttributes extends TintedFluidType {
|
2020-12-04 23:31:12 +01:00
|
|
|
|
2022-08-01 22:37:39 +02:00
|
|
|
public NoColorFluidAttributes(Properties properties, ResourceLocation stillTexture,
|
|
|
|
ResourceLocation flowingTexture) {
|
|
|
|
super(properties, stillTexture, flowingTexture);
|
2020-12-04 23:31:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2022-08-01 22:37:39 +02:00
|
|
|
public int getTintColor(FluidState state, BlockAndTintGetter world, BlockPos pos) {
|
2020-12-04 23:31:12 +01:00
|
|
|
return 0x00ffffff;
|
|
|
|
}
|
|
|
|
|
2022-08-01 22:37:39 +02:00
|
|
|
@Override
|
|
|
|
protected int getTintColor(FluidStack stack) {
|
|
|
|
return NO_TINT;
|
|
|
|
}
|
|
|
|
|
2020-12-04 23:31:12 +01:00
|
|
|
}
|
2022-08-01 22:37:39 +02:00
|
|
|
|
2020-10-19 22:07:05 +02:00
|
|
|
}
|