diff options
| author | shedaniel <daniel@shedaniel.me> | 2020-06-06 16:29:32 +0800 |
|---|---|---|
| committer | shedaniel <daniel@shedaniel.me> | 2020-06-06 16:29:32 +0800 |
| commit | 3802055673e7877d66614791eba6ea0599488c7a (patch) | |
| tree | 8a26efa9c9cea0c0ee1d00234c04eace52771dae /src/main/java/me/shedaniel/rei/impl/SimpleFluidRenderer.java | |
| parent | f7be9668e3b9508497e21ff74cc0f2f2e1b5d931 (diff) | |
| download | RoughlyEnoughItems-3802055673e7877d66614791eba6ea0599488c7a.tar.gz RoughlyEnoughItems-3802055673e7877d66614791eba6ea0599488c7a.tar.bz2 RoughlyEnoughItems-3802055673e7877d66614791eba6ea0599488c7a.zip | |
Improved Search
Signed-off-by: shedaniel <daniel@shedaniel.me>
Diffstat (limited to 'src/main/java/me/shedaniel/rei/impl/SimpleFluidRenderer.java')
| -rw-r--r-- | src/main/java/me/shedaniel/rei/impl/SimpleFluidRenderer.java | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/src/main/java/me/shedaniel/rei/impl/SimpleFluidRenderer.java b/src/main/java/me/shedaniel/rei/impl/SimpleFluidRenderer.java new file mode 100644 index 000000000..8c716dffb --- /dev/null +++ b/src/main/java/me/shedaniel/rei/impl/SimpleFluidRenderer.java @@ -0,0 +1,62 @@ +package me.shedaniel.rei.impl; + +import net.fabricmc.fabric.api.client.render.fluid.v1.FluidRenderHandler; +import net.fabricmc.fabric.api.client.render.fluid.v1.FluidRenderHandlerRegistry; +import net.minecraft.client.MinecraftClient; +import net.minecraft.client.texture.Sprite; +import net.minecraft.fluid.Fluid; +import net.minecraft.util.math.BlockPos; +import org.jetbrains.annotations.ApiStatus; +import org.jetbrains.annotations.Nullable; + +import java.util.HashMap; +import java.util.Map; + +@ApiStatus.Internal +public final class SimpleFluidRenderer { + private static final Map<Fluid, FluidRenderingData> FLUID_DATA = new HashMap<>(); + + private SimpleFluidRenderer() {} + + @Nullable + public static FluidRenderingData fromFluid(Fluid fluid) { + return FLUID_DATA.computeIfAbsent(fluid, FluidRenderingDataImpl::from); + } + + public interface FluidRenderingData { + Sprite getSprite(); + + int getColor(); + } + + public static final class FluidRenderingDataImpl implements FluidRenderingData { + private final Sprite sprite; + private final int color; + + public FluidRenderingDataImpl(Sprite sprite, int color) { + this.sprite = sprite; + this.color = color; + } + + public static FluidRenderingData from(Fluid fluid) { + FluidRenderHandler fluidRenderHandler = FluidRenderHandlerRegistry.INSTANCE.get(fluid); + if (fluidRenderHandler == null) + return null; + Sprite[] sprites = fluidRenderHandler.getFluidSprites(MinecraftClient.getInstance().world, MinecraftClient.getInstance().world == null ? null : BlockPos.ORIGIN, fluid.getDefaultState()); + int color = -1; + if (MinecraftClient.getInstance().world != null) + color = fluidRenderHandler.getFluidColor(MinecraftClient.getInstance().world, BlockPos.ORIGIN, fluid.getDefaultState()); + return new FluidRenderingDataImpl(sprites[0], color); + } + + @Override + public Sprite getSprite() { + return sprite; + } + + @Override + public int getColor() { + return color; + } + } +} |
