MrNegaBlox Posted December 14, 2014 Posted December 14, 2014 Hi, so I'm making a custom model for an item. But when I launch the game, I merely get the black and purple error texture on a flat square. I think it may be something wrong with my proxies. I am rather new to coding so please forgive me of any stupid mistakes. Main.class package io.github.mrnegablox.mythos; import net.minecraft.client.Minecraft; import net.minecraftforge.common.MinecraftForge; import cpw.mods.fml.common.Mod; import cpw.mods.fml.common.Mod.EventHandler; import cpw.mods.fml.common.Mod.Instance; import cpw.mods.fml.common.SidedProxy; import cpw.mods.fml.common.event.FMLInitializationEvent; import cpw.mods.fml.common.event.FMLPostInitializationEvent; import cpw.mods.fml.common.event.FMLPreInitializationEvent; import cpw.mods.fml.common.network.NetworkRegistry; import cpw.mods.fml.common.registry.GameRegistry; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; import io.github.mrnegablox.mythos.gui.GuiBook; import io.github.mrnegablox.mythos.gui.GuiHandler; import io.github.mrnegablox.mythos.items.ModItems; import io.github.mrnegablox.mythos.omnomicon.CatagoriesBase; @Mod(modid = Main.MODID, name = Main.MODNAME, version = Main.VERSION) public class Main { //public CatagoriesBase bc = CatagoriesBase.Instance; public static final String MODID = "mythosnega"; public static final String MODNAME = "Mythos"; public static final String VERSION = "1.0.0"; @Instance public static Main instance = new Main(); @SidedProxy(clientSide="io.github.mrnegablox.mythos.ClientProxy", serverSide="io.github.mrnegablox.mythos.ServerProxy") public static CommonProxy proxy; /** * Run before anything else. Read your config, create blocks, items, etc, and * register them with the GameRegistry. */ @EventHandler public void preInit(FMLPreInitializationEvent e) { ModItems.init(); } /** * Do your mod setup. Build whatever data structures you care about. Register recipes. */ @EventHandler public void init(FMLInitializationEvent e) { proxy.registerRenderers(); //bc.RegisterCatagories(); } /** * Handle interaction with other mods, complete your setup based on this. */ @EventHandler public void postInit(FMLPostInitializationEvent e) { NetworkRegistry.INSTANCE.registerGuiHandler(this, new GuiHandler()); } } Common Proxy package io.github.mrnegablox.mythos; import io.github.mrnegablox.mythos.items.ItemOmnomicon; import io.github.mrnegablox.mythos.items.ItemSoulJar; import io.github.mrnegablox.mythos.render.RenderSoulJar; import net.minecraftforge.client.IItemRenderer; import net.minecraftforge.client.MinecraftForgeClient; public class CommonProxy { private ItemSoulJar isj; public void registerRenderers(){ MinecraftForgeClient.registerItemRenderer(isj, (IItemRenderer)new RenderSoulJar()); } } Client Proxy package io.github.mrnegablox.mythos; import io.github.mrnegablox.mythos.items.ItemOmnomicon; import io.github.mrnegablox.mythos.items.ItemSoulJar; import io.github.mrnegablox.mythos.render.RenderSoulJar; import net.minecraftforge.client.IItemRenderer; import net.minecraftforge.client.MinecraftForgeClient; import cpw.mods.fml.client.registry.ClientRegistry; import cpw.mods.fml.common.event.FMLInitializationEvent; import cpw.mods.fml.common.event.FMLPostInitializationEvent; import cpw.mods.fml.common.event.FMLPreInitializationEvent; public class ClientProxy extends CommonProxy { private ItemSoulJar isj; public ClientProxy(){ isj = new ItemSoulJar(); } @Override public void registerRenderers(){ MinecraftForgeClient.registerItemRenderer(isj, (IItemRenderer)new RenderSoulJar()); } } Item package io.github.mrnegablox.mythos.items; import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.SideOnly; import io.github.mrnegablox.mythos.Main; import net.minecraft.client.renderer.texture.IIconRegister; import net.minecraft.init.Items; import net.minecraft.item.Item; import net.minecraft.item.ItemStack; import net.minecraft.util.IIcon; public class ItemSoulJar extends Item { public ItemSoulJar() { } @Override @SideOnly(Side.CLIENT) public void registerIcons(IIconRegister iconRegister) { itemIcon = iconRegister.registerIcon(Main.MODID + ":textures/model/ModelSoulJar.png"); } } ModItems package io.github.mrnegablox.mythos.items; import io.github.mrnegablox.mythos.Main; import cpw.mods.fml.common.registry.GameRegistry; import net.minecraft.creativetab.CreativeTabs; import net.minecraft.item.Item; public class ModItems { public static Item ItemOmnomicon; public static Item ItemSoulJar; public static void init(){ ItemOmnomicon = new ItemOmnomicon().setFull3D().setUnlocalizedName("mythosomnomicon").setCreativeTab(CreativeTabs.tabMisc).setTextureName(Main.MODID + ":mythosomnomicon"); ItemSoulJar = new ItemSoulJar().setFull3D().setCreativeTab(CreativeTabs.tabMisc).setUnlocalizedName("mythossouljar").setTextureName(Main.MODID + ":mythosOmnomicon"); RegisterItems(); } private static void RegisterItems() { GameRegistry.registerItem(ItemOmnomicon, "mythosonomicon"); GameRegistry.registerItem(ItemSoulJar, "mythossouljar"); } } Renderer package io.github.mrnegablox.mythos.render; import io.github.mrnegablox.mythos.Main; import org.lwjgl.opengl.GL11; import net.minecraft.client.Minecraft; import net.minecraft.client.renderer.entity.RenderItem; import net.minecraft.entity.Entity; import net.minecraft.item.ItemStack; import net.minecraft.util.ResourceLocation; import net.minecraftforge.client.IItemRenderer; public class RenderSoulJar implements IItemRenderer{ protected ModelSoulJar souljarmodel; private static RenderItem renderItem = new RenderItem(); public RenderSoulJar(){ souljarmodel = new ModelSoulJar(); } @Override public boolean handleRenderType(ItemStack item, ItemRenderType type) { // TODO Auto-generated method stub switch(type) { case EQUIPPED: return true; default: return false; } } @Override public boolean shouldUseRenderHelper(ItemRenderType type, ItemStack item, ItemRendererHelper helper) { return false; } @Override public void renderItem(ItemRenderType type, ItemStack item, Object... data) { System.out.println("render!"); switch(type) { case EQUIPPED: { GL11.glPushMatrix(); Minecraft.getMinecraft().renderEngine.bindTexture(new ResourceLocation(Main.MODID, "textures/model/ModelSoulJar.png")); souljarmodel.render((Entity)data[1], 0.0F, 0.0F, 0.0F, 0.0F, 0.0F, 0.0625F); GL11.glPopMatrix(); } default: break; } } } model // Date: 12/13/2014 7:48:41 AM // Template version 1.1 // Java generated by Techne // Keep in mind that you still need to fill in some blanks // - ZeuX package io.github.mrnegablox.mythos.render; import net.minecraft.client.model.ModelBase; import net.minecraft.client.model.ModelRenderer; import net.minecraft.entity.Entity; public class ModelSoulJar extends ModelBase { //fields public ModelRenderer Top; public ModelRenderer Side_3; public ModelRenderer Side_1; public ModelRenderer Side_2; public ModelRenderer Side_4; public ModelRenderer Base; public ModelRenderer Cap; public ModelRenderer Shape1; public ModelSoulJar() { textureWidth = 64; textureHeight = 32; Top = new ModelRenderer(this, 0, 0); Top.addBox(0F, 0F, 0F, 9, 1, 9); Top.setRotationPoint(-1F, -11F, -1F); Top.setTextureSize(64, 32); Top.mirror = true; setRotation(Top, 0F, 0F, 0F); Side_3 = new ModelRenderer(this, 36, 0); Side_3.addBox(0F, 0F, 0F, 7, 10, 0); Side_3.setRotationPoint(0F, -10F, 0F); Side_3.setTextureSize(64, 32); Side_3.mirror = true; setRotation(Side_3, 0F, 0F, 0F); Side_1 = new ModelRenderer(this, 36, 0); Side_1.addBox(0F, 0F, 0F, 7, 10, 0); Side_1.setRotationPoint(0F, -10F, 7F); Side_1.setTextureSize(64, 32); Side_1.mirror = true; setRotation(Side_1, 0F, 0F, 0F); Side_2 = new ModelRenderer(this, 36, -7); Side_2.addBox(0F, 0F, 0F, 0, 10, 7); Side_2.setRotationPoint(0F, -10F, 0F); Side_2.setTextureSize(64, 32); Side_2.mirror = true; setRotation(Side_2, 0F, 0F, 0F); Side_4 = new ModelRenderer(this, 36, -7); Side_4.addBox(0F, 0F, 0F, 0, 10, 7); Side_4.setRotationPoint(7F, -10F, 0F); Side_4.setTextureSize(64, 32); Side_4.mirror = true; setRotation(Side_4, 0F, 0F, 0F); Base = new ModelRenderer(this, 0, 0); Base.addBox(0F, 0F, 0F, 9, 1, 9); Base.setRotationPoint(-1F, 0F, -1F); Base.setTextureSize(64, 32); Base.mirror = true; setRotation(Base, 0F, 0F, 0F); Cap = new ModelRenderer(this, 0, 10); Cap.addBox(0F, 0F, 0F, 5, 1, 5); Cap.setRotationPoint(1F, -12F, 1F); Cap.setTextureSize(64, 32); Cap.mirror = true; setRotation(Cap, 0F, 0F, 0F); Shape1 = new ModelRenderer(this, 20, 10); Shape1.addBox(0F, 0F, 0F, 5, 8, 5); Shape1.setRotationPoint(1F, -9F, 1F); Shape1.setTextureSize(64, 32); Shape1.mirror = true; setRotation(Shape1, 0F, 0F, 0F); } public void render(Entity entity, float f, float f1, float f2, float f3, float f4, float f5) { super.render(entity, f, f1, f2, f3, f4, f5); setRotationAngles(f, f1, f2, f3, f4, f5, entity); Top.render(f5); Side_3.render(f5); Side_1.render(f5); Side_2.render(f5); Side_4.render(f5); Base.render(f5); Cap.render(f5); } private void setRotation(ModelRenderer model, float x, float y, float z) { model.rotateAngleX = x; model.rotateAngleY = y; model.rotateAngleZ = z; } public void setRotationAngles(float f, float f1, float f2, float f3, float f4, float f5, Entity ent) { super.setRotationAngles(f, f1, f2, f3, f4, f5, ent); } } Thank you in advance Quote
Ernio Posted December 14, 2014 Posted December 14, 2014 Renderers should't be called on common proxy, never ever. It should look like this: (notice that i am refering to Item object registered by your mod, not a new one like you did in proxy) public class CommonProxy { public void registerRenderers(){} } public class ClientProxy extends CommonProxy { @Override public void registerRenderers(){ MinecraftForgeClient.registerItemRenderer(ModItems.ItemSoulJar, (IItemRenderer)new RenderSoulJar()); } } Is your renderer ever called? (I only took a glance on code, so if it still won't work I ll check it in eclipse) Quote 1.7.10 is no longer supported by forge, you are on your own.
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.