Jump to content

Recommended Posts

Posted

I am trying to make a mod where one item turns into another and have achieved this with metadata:

 

@Override

public ItemStack onItemRightClick(ItemStack par1itemstack, World par2world, EntityPlayer par3player) {

if (par1itemstack != null && par1itemstack.getItemDamage() == 0) {

setDamage(par1itemstack, 1);

}else{

if (par1itemstack != null && par1itemstack.getItemDamage() == 1) {

setDamage(par1itemstack, 0);

}

}

 

return super.onItemRightClick(par1itemstack, par2world, par3player);

}

 

I am trying to register (already made) models for these two metadata items, but when I try to register them it doesn't work, and gives the same model for each item.

 

public void registerItemRenderers() {

MinecraftForgeClient.registerItemRenderer (ElementalImperium.Test, 1, 0, (IItemRenderer) new MyRenderClass());

MinecraftForgeClient.registerItemRenderer (ElementalImperium.Test, 1, 0, (IItemRenderer) new MyRenderClass1());

 

Thanks in advance for any help

 

-Whyneb360

Posted

In the renderer, make sure you pass the damage to the model as a parameter, and in the model file, just create the other figure you want the item to transform in and use if statements to tell the model to render one or another.

 

In my case that means:

if(damage==0){

figure1.render(float1)

}else{

figure2.render(float1)
}

Posted

You can only have one renderer per item/block. In the ClientProxy, only register one renderer for this item, giving one item more than one renderer will cause problems. Now, in the renderer, for each model, have a different ResourceLocation, and the same for each texture, now, you would make it select the appropriate resource location depending on the metadata. This could be done in many ways. I personally prefer to use a switch statement.

 

I have not done this for an item before, but recently I did something very similar to this for a block. It can't be much different, in the block, I used the tileEntity parameter in renderTileEntityAt to get the metadata "int meta = tileEntity.getBlockMetadata()", but in the item renderer, you can use the itemStack parameter in the renderItem method (I might have got that methods name wrong) to get the metadata with "int meta = itemStack.getItemDamage()"

 

Now with this, you can do something like:

int meta = itemStack.getItemDamage();

switch (meta) {
        case 0: {
                //Get the correct model
                //Bind the texture from the appropriate resource
                //Do the rest of the rendering stuff here
        }
        case 1: {
                //Get the correct model
                //Bind the texture from the appropriate resource
        }
}

I ask complicated questions, and apparently like to write really long detailed posts. But I also help others when I can.

Posted

So my ClientProxy looks as follows:

 

 

  Reveal hidden contents

 

 

and my render class looks like this:

 

 

  Reveal hidden contents

 

 

My problem is that I can't see the model at all now when I go into the game. The two models are in another package, and I will gladly supply the code for them if need be. Sorry if I have made what seems like an obvious mistake - I am new to modding

 

Many thanks

 

-Whyneb360

Posted

Check your renderer with @Overrides on every method you expect to get called by Minecraft.

I suspect that since you changed the method signature, your renderItem method is not called at all.

Or, you could call it yourself from the Overridden renderItem method.

 

Another question... Why does your method have two (2) ItemStack parameters? You can always get metadata from the original parameter.

Posted

I think you need a break at the end of each switch statement.

 

Also try putting a default statement in too (with a break at the end) and make it do something there. If it is doing whatever you made it do in the default statement (I'd just make it print something like "Can't find model, report as a bug!" and leave it in), then it isn't getting the metadata, or it can't find it, and in that case, it would be -1. If not, put a println at the top of the renderItem method to see if it is actually getting called.

 

Edit: I have just noticed that you have two renderItem methods. Why? I think that in this case, your problem is the renderItem method with the @Override annotation and the "//TODO Auto-generated method stub" is the one that is getting called, and it has nothing in it at all. The one that has your render code in it has two ItemStack parameters, it shouldn't.

 

   @Override
   public void renderItem(ItemRenderType type, ItemStack item, Object... data) {
      // TODO Auto-generated method stub
      //This method shouldn't be empty. This is why you can't see the model now, it isn't getting rendered at all.
   }

 

Hope this helped.

I ask complicated questions, and apparently like to write really long detailed posts. But I also help others when I can.

Posted

Fixed it! Many thanks to you all

 

-Whyneb360

 

EDIT: The only problem I encountered is when I switch between case 1 and case 2, case 1 appears and disappears, but case 2 stays and doesn't go away. Do I need to de-render case 2 somehow?

 

EDIT: Fixed that too. just need breaks at the end of each case. Thank you all for your help -Whyneb360

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.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • No matter how many mods I disable it keeps giving the same error. https://paste.ee/p/1fBHCe9O
    • I did that, and then it crashed again, but this time it said something about ComputerCraft; so I disabled that mod and now it works. Thanks for the help!
    • Update ColdSweat to the latest build: https://www.curseforge.com/minecraft/mc-mods/cold-sweat/files/6450271
    • Veuillez lire la FAQ (le lien est en haut de la page) et les journaux de publication tels que décrits ici. Cela aidera à déterminer ce qui se passe. Ce sont des forums anglais, j'ai utilisé un traducteur pour essayer de vous aider, j'espère que ça se retrouve bien.
    • I tried adding the Create (6.0.4) mod to my modpack which causes it to crash before it finishes loading. I tried removing the mod Cold Sweat because the error said it failed to load due to something in Create but when I removed it, it kept crashing; and I also tried downgrading Create, but nothing helped. I assume there's an incompatible mod that's causing Create to not load correctly, but I can't find it. launcher_log.txt: https://mclo.gs/kn5Qkk2 debug.log: https://mclo.gs/zIKoAaB crash report: https://mclo.gs/j86C10Y The part of debug.log that I think is the crash (after Create mod already loaded incorrectly): [02May2025 14:52:36.813] [Worker-ResourceReload-2/ERROR] [net.minecraftforge.fml.javafmlmod.FMLModContainer/]: Exception caught during firing event: com/simibubi/create/content/redstone/displayLink/DisplayBehaviour Index: 3 Listeners: 0: NORMAL 1: net.minecraftforge.eventbus.EventBus$$Lambda$1770/0x00000008009bc8a0@70223c71 2: ASM: class com.momosoftworks.coldsweat.core.event.PotionRecipes register(Lnet/minecraftforge/fml/event/lifecycle/FMLCommonSetupEvent;)V 3: ASM: class com.momosoftworks.coldsweat.compat.CompatManager$ModEvents setupModEvents(Lnet/minecraftforge/fml/event/lifecycle/FMLCommonSetupEvent;)V java.lang.NoClassDefFoundError: com/simibubi/create/content/redstone/displayLink/DisplayBehaviour at TRANSFORMER/cold_sweat@2.3.12/com.momosoftworks.coldsweat.compat.CompatManager$ModEvents.setupModEvents(CompatManager.java:501) at TRANSFORMER/cold_sweat@2.3.12/com.momosoftworks.coldsweat.compat.__ModEvents_setupModEvents_FMLCommonSetupEvent.invoke(.dynamic) at MC-BOOTSTRAP/net.minecraftforge.eventbus/net.minecraftforge.eventbus.ASMEventHandler.invoke(ASMEventHandler.java:73) at MC-BOOTSTRAP/net.minecraftforge.eventbus/net.minecraftforge.eventbus.EventBus.post(EventBus.java:315) at MC-BOOTSTRAP/net.minecraftforge.eventbus/net.minecraftforge.eventbus.EventBus.post(EventBus.java:296) at LAYER PLUGIN/javafmllanguage@1.20.1-47.4.0/net.minecraftforge.fml.javafmlmod.FMLModContainer.acceptEvent(FMLModContainer.java:121) at LAYER PLUGIN/fmlcore@1.20.1-47.4.0/net.minecraftforge.fml.ModContainer.lambda$buildTransitionHandler$5(ModContainer.java:127) at java.base/java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1804) at java.base/java.util.concurrent.CompletableFuture$AsyncRun.exec(CompletableFuture.java:1796) at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:373) at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1182) at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1655) at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1622) at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:165) Caused by: java.lang.ClassNotFoundException: com.simibubi.create.content.redstone.displayLink.DisplayBehaviour at cpw.mods.securejarhandler/cpw.mods.cl.ModuleClassLoader.loadClass(ModuleClassLoader.java:141) at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:525) ... 14 more [02May2025 14:52:36.972] [Worker-ResourceReload-2/ERROR] [net.minecraftforge.fml.javafmlmod.FMLModContainer/LOADING]: Caught exception during event FMLCommonSetupEvent dispatch for modid cold_sweat java.lang.NoClassDefFoundError: com/simibubi/create/content/redstone/displayLink/DisplayBehaviour at com.momosoftworks.coldsweat.compat.CompatManager$ModEvents.setupModEvents(CompatManager.java:501) ~[ColdSweat-2.3.12.jar%23537!/:2.3.12] at com.momosoftworks.coldsweat.compat.__ModEvents_setupModEvents_FMLCommonSetupEvent.invoke(.dynamic) ~[ColdSweat-2.3.12.jar%23537!/:2.3.12] at net.minecraftforge.eventbus.ASMEventHandler.invoke(ASMEventHandler.java:73) ~[eventbus-6.0.5.jar%2387!/:?] at net.minecraftforge.eventbus.EventBus.post(EventBus.java:315) ~[eventbus-6.0.5.jar%2387!/:?] at net.minecraftforge.eventbus.EventBus.post(EventBus.java:296) ~[eventbus-6.0.5.jar%2387!/:?] at net.minecraftforge.fml.javafmlmod.FMLModContainer.acceptEvent(FMLModContainer.java:121) ~[javafmllanguage-1.20.1-47.4.0.jar%23784!/:?] at net.minecraftforge.fml.ModContainer.lambda$buildTransitionHandler$5(ModContainer.java:127) ~[fmlcore-1.20.1-47.4.0.jar%23783!/:?] at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1804) ~[?:?] at java.util.concurrent.CompletableFuture$AsyncRun.exec(CompletableFuture.java:1796) ~[?:?] at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:373) ~[?:?] at java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1182) ~[?:?] at java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1655) ~[?:?] at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1622) ~[?:?] at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:165) ~[?:?] Caused by: java.lang.ClassNotFoundException: com.simibubi.create.content.redstone.displayLink.DisplayBehaviour at cpw.mods.cl.ModuleClassLoader.loadClass(ModuleClassLoader.java:141) ~[securejarhandler-2.1.10.jar:?] at java.lang.ClassLoader.loadClass(ClassLoader.java:525) ~[?:?] ... 14 more
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.