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

    • But your Launcher does not find it   Java path is: /run/user/1000/doc/3f910b8/java Checking Java version... Java checker returned some invalid data we don't understand: Check the Azul Zulu site and select your OS and download the latest Java 8 build for Linux https://www.azul.com/downloads/?version=java-8-lts&package=jre#zulu After installation, check the path and put this path into your Launcher Java settings (Java Executable)
    • Try other builds of pehkui and origins++ until you find a working combination
    • Some Create addons are only compatible with Create 6 or Create 5 - so not both versions at the same time Try older builds of Create Stuff and Additions This is the last build before the Create 6 update: https://www.curseforge.com/minecraft/mc-mods/create-stuff-additions/files/6168370
    • ✅ Crobo Coupon Code: 51k3b0je — Get Your \$25 Amazon Gift Card Bonus! If you’re new to Crobo and want to make the most out of your first transaction, you’ve come to the right place. The **Crobo coupon code: 51k3b0je** is a fantastic way to get started. By using this code, you can unlock an exclusive **\$25 Amazon gift card** after completing your first eligible transfer. Let’s dive deep into how the **Crobo coupon code: 51k3b0je** works, why you should use it, and how to claim your reward. --- 🌟 What is Crobo? Crobo is a trusted, modern platform designed for **international money transfers**. It offers fast, secure, and low-cost transactions, making it a favorite choice for individuals and businesses alike. Crobo is committed to transparency, low fees, and competitive exchange rates. And with promo deals like the **Crobo coupon code: 51k3b0je**, it becomes even more attractive. Crobo focuses on providing customers with: * Quick transfer speeds * Minimal fees * Safe, encrypted transactions * Great referral and promo code rewards When you choose Crobo, you’re choosing a platform that values your time, money, and loyalty. And now with the **Crobo coupon code: 51k3b0je**, you can start your Crobo journey with a **bonus reward**! ---# 💥 What is the Crobo Coupon Code: 51k3b0je? The **Crobo coupon code: 51k3b0je** is a **special promotional code** designed for new users. By entering this code during signup, you’ll be eligible for: ✅ A **\$25 Amazon gift card** after your first qualifying transfer. ✅ Access to Crobo’s referral system to earn more rewards. ✅ The ability to combine with future seasonal Crobo discounts. Unlike generic promo codes that just offer small fee reductions, the **Crobo coupon code: 51k3b0je** directly gives you a tangible, valuable reward — perfect for online shopping or gifting. --- ### 🎯 Why Use Crobo Coupon Code: 51k3b0je? There are many reasons why users choose to apply the **Crobo coupon code: 51k3b0je**: 🌟 **Free bonus reward** — Your first transfer can instantly earn you a \$25 Amazon gift card. 🌟 **Trusted platform** — Crobo is known for secure, fast, and affordable transfers. 🌟 **Easy to apply** — Simply enter **Crobo coupon code: 51k3b0je** at signup — no complicated steps. 🌟 **Referral opportunities** — Once you’ve used **Crobo coupon code: 51k3b0je**, you can invite friends and earn more rewards. 🌟 **Stackable savings** — Pair **Crobo coupon code: 51k3b0je** with Crobo’s ongoing offers or holiday deals for even more benefits. --- ### 📝 How to Use Crobo Coupon Code: 51k3b0je Getting started with **Crobo coupon code: 51k3b0je** is quick and easy. Just follow these steps: 1️⃣ **Download the Crobo app** (available on Google Play Store and Apple App Store) or visit the official Crobo website. 2️⃣ **Start the sign-up process** by entering your basic details (name, email, phone number, etc.). 3️⃣ When prompted, enter **Crobo coupon code: 51k3b0je** in the promo code or coupon code field. 4️⃣ Complete your first transaction — be sure to meet the minimum amount required to qualify for the reward (usually specified in Crobo’s promo terms). 5️⃣ After the transaction is verified, receive your **\$25 Amazon gift card** directly via email or within your Crobo account. --- ### 💡 Tips to Maximize Your Crobo Coupon Code: 51k3b0je Bonus 👉 **Transfer the minimum qualifying amount or more** — this ensures you meet the conditions for the gift card. 👉 **Refer friends after your signup** — Crobo allows users who’ve signed up with codes like **Crobo coupon code: 51k3b0je** to share their own code for extra bonuses. 👉 **Check for additional Crobo promotions** — sometimes Crobo offers seasonal or regional deals that stack with the coupon code. 👉 **Complete your transaction soon after signup** — many bonuses have time limits, so act quickly! --- ### 🚀 Frequently Asked Questions about Crobo Coupon Code: 51k3b0je **Q: Can I use Crobo coupon code: 51k3b0je if I already have a Crobo account?** A: No — the **Crobo coupon code: 51k3b0je** is intended for **new users only**. It must be applied during the initial registration process. --- **Q: How long does it take to get the \$25 Amazon gift card after using Crobo coupon code: 51k3b0je?** A: Typically, the gift card is sent **within a few business days** after your first qualifying transfer is completed and verified. --- **Q: Are there hidden fees when using Crobo coupon code: 51k3b0je?** A: No — Crobo is transparent about its fees. The **Crobo coupon code: 51k3b0je** simply adds a bonus reward without increasing your costs. --- **Q: Can I combine Crobo coupon code: 51k3b0je with other promo codes?** A: The **Crobo coupon code: 51k3b0je** is generally applied as a standalone signup bonus. However, Crobo often offers **ongoing promotions** that may apply to future transactions. ---  📌 Reference Crobo promo code: {51k3b0je} Crobo discount code: {51k3b0je} --- # 🌍 Final Thoughts If you want to enjoy safe, fast, and affordable money transfers with an added bonus, **Crobo coupon code: 51k3b0je** is your best option. Not only will you experience excellent service, but you’ll also earn a **\$25 Amazon gift card** — a reward that you can use immediately for shopping or gifts. 👉 **Don’t wait — sign up today using Crobo coupon code: 51k3b0je and claim your bonus!**
  • Topics

×
×
  • Create New...

Important Information

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