From 407a3cfabed3869b38527153e8b3322a824f1263 Mon Sep 17 00:00:00 2001 From: Anthony Hilyard Date: Wed, 13 Oct 2021 22:51:23 -0700 Subject: Initial commit for 1.17.1 version. --- .../iceberg/registry/RendererRegistrar.java | 27 +++++++++++++++++----- 1 file changed, 21 insertions(+), 6 deletions(-) (limited to 'src/main/java/com/anthonyhilyard/iceberg/registry/RendererRegistrar.java') diff --git a/src/main/java/com/anthonyhilyard/iceberg/registry/RendererRegistrar.java b/src/main/java/com/anthonyhilyard/iceberg/registry/RendererRegistrar.java index e77fd1f..1b0a053 100644 --- a/src/main/java/com/anthonyhilyard/iceberg/registry/RendererRegistrar.java +++ b/src/main/java/com/anthonyhilyard/iceberg/registry/RendererRegistrar.java @@ -1,21 +1,36 @@ package com.anthonyhilyard.iceberg.registry; -import net.minecraft.entity.Entity; -import net.minecraftforge.fml.client.registry.IRenderFactory; -import net.minecraftforge.fml.client.registry.RenderingRegistry; +import java.util.HashMap; +import java.util.Map; + +import net.minecraft.world.entity.Entity; +import net.minecraft.world.entity.EntityType; +import net.minecraft.client.renderer.entity.EntityRendererProvider; +import net.minecraftforge.client.event.EntityRenderersEvent; public abstract class RendererRegistrar { - protected static void registerRenderer(String name, IRenderFactory renderFactory) + private static Map, EntityRendererProvider> entityRenderers = new HashMap<>(); + + protected static void registerRenderer(String name, EntityRendererProvider rendererProvider) { if (AutoRegistry.isEntityTypeRegistered(name)) { - // Register the rendering handler. - RenderingRegistry.registerEntityRenderingHandler(AutoRegistry.getEntityType(name), renderFactory); + // Store this renderer provider. + entityRenderers.put(AutoRegistry.getEntityType(name), rendererProvider); } else { throw new RuntimeException("Tried to register a renderer for an unregistered entity type! Make sure you register renderers after entities."); } } + + @SuppressWarnings({"unchecked", "unused"}) + private void onEntityCreation(EntityRenderersEvent.RegisterRenderers event) + { + for (EntityType entityType : entityRenderers.keySet()) + { + event.registerEntityRenderer((EntityType)entityType, (EntityRendererProvider)entityRenderers.get(entityType)); + } + } } -- cgit