Jump to content

Recommended Posts

Posted

Hey guys. This is a question that has come up before I know, but I have scoured the forums and applied every tip I can find, but my custom mob is still rendering with no texture.

 

Using the current 1.6.4 recommended Forge version.

 

I'm getting the dreaded error:

 

14:41:14 - 2014-02-28 14:41:14 [WARNING] [Minecraft-Client] Failed to load texture: ellitopiabears:textures/mobs/pig_bear.png
14:41:14 - java.io.FileNotFoundException: ellitopiabears:textures/mobs/pig_bear.png

 

My mod is a modified PigZombie that looks like a bear. Here's the code:

 

package net.ellitopia.ellitopiabears.renderer.entity;

import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import net.ellitopia.ellitopiabears.EllitopiaBears;
import net.ellitopia.ellitopiabears.client.model.ModelPigBear;
import net.minecraft.client.renderer.entity.RenderBiped;
import net.minecraft.entity.Entity;
import net.minecraft.entity.EntityLiving;
import net.minecraft.entity.monster.EntityPigZombie;
import net.minecraft.util.ResourceLocation;

@SideOnly(Side.CLIENT)
public class RenderPigBear extends RenderBiped {
    
    private static final ResourceLocation zombiePigmanTextures = new ResourceLocation(EllitopiaBears.MODID, "textures/mobs/pig_bear.png");
    
    public RenderPigBear()
    {
        super(new ModelPigBear(), 0.5F, 1.0F);
    }
    
    @Override
     protected void func_82421_b()
    {
        this.field_82423_g = new ModelPigBear(1.0F, true);
        this.field_82425_h = new ModelPigBear(0.5F, true);
    }
    
    protected ResourceLocation func_110863_a(EntityPigZombie par1EntityZombie)
    {
        return zombiePigmanTextures;
    }
     
    @Override
    protected ResourceLocation func_110856_a(EntityLiving par1EntityLiving)
    {
        return this.func_110863_a((EntityPigZombie)par1EntityLiving);
    }
     
    @Override
    protected ResourceLocation getEntityTexture(Entity par1Entity)
    {
        return this.func_110863_a((EntityPigZombie)par1Entity);
    }

}

 

Texture image is stored at mcp\src\minecraft\assets\ellitopiabears\textures\mobs\pig_bear.png

 

What am I missing?

Posted

I did think that was possible, but back-slash is an illegal escape character in this context. :(

 

I tried it with a double back-slash to get around this, but still no joy.

 

I'm glad this isn't as obvious as I thought it might be! :)

Posted

I did see that thread, but I couldn't see how to apply it to my code (above). I have no File to parse, only a ResourceLocation which doesn't point to a resource, or a string with no context.

 

How would I use the code in that thread in the context of my code above?

Posted

Hi

 

When you use a ResourceLocation, Forge converts it to a full path using this code

 

FolderResourcePack::
    protected boolean makeFullPath(String par1Str)
    {
        return (new File(this.basePath, par1Str)).isFile();
    }

 

If you find the vanilla FolderResourcePack and put a breakpoint in there, then look at the value of this.basePath, it will show you what the base path is.

You might need to "continue" a couple of times until the right ResourcePath comes up because there are several different ones and only one of them is yours (you will know it when you see it).

 

Alternatively add the following line and then look in the console output after running

 

FolderResourcePack::
    protected boolean makeFullPath(String par1Str)
    {
        System.out.println("FolderResourcePack::makeFullPath basePath = " + this.basePath); // ToDo: debugging, remove
        return (new File(this.basePath, par1Str)).isFile();
    }

 

-TGG

Posted

That would be a great suggestion, if this was calling a file from the Resource Pack, and if my FolderResourcePack class had a method called makeFullPath... in fact I searched the source and didn't find ANY file with makeFullPath in.

 

So now I'm more confused. :( I swear this is easier in 1.7.2

Posted

Ah, I see.  I just had a look and they've obviously changed the handling of Resources yet again.

 

Try a breakpoint in SimpleReloadableResourceManager::getResource  and look in this.domainResourceManagers

 

- see screenshot  https://www.dropbox.com/s/7v3xouub45cxk4e/ScreenShot.png

 

alternatively

 

FolderResourcePack::

    protected InputStream getInputStreamByName(String par1Str) throws IOException
    {
        return new BufferedInputStream(new FileInputStream(new File(this.resourcePackFile, par1Str)));   // breakpoint here
    }

--> look in this.resourcePackFile

(may need to continue several times until you find the right one).

 

or alternatively

    protected InputStream getInputStreamByName(String par1Str) throws IOException
    {
        System.out.println("this.resourcePackFile:" + this.resourcePackFile.toString());           // todo: debugging only, remove
        return new BufferedInputStream(new FileInputStream(new File(this.resourcePackFile, par1Str)));
    }

 

-TGG

 

 

 

 

Posted

BINGO!

 

I output the absolute path from the simple reloaded and found it was looking in mcp/bin/minecraft. I put the assets in there and everything sparked into life!

 

When I deobfuscated I had to manually transfer the assets and the mod info file, but I now have a working mod!

 

Thanks for the help people, especially TGG.

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

    • Hi, i'm really having problems trying to set the texture to my custom item. I thought i'm doing everything correctly, but all i see is the missing texture block for my item. I am trying this for over a week now and getting really frustrated. The only time i could make the texture work, was when i used an older Forge version (52.0.1) for Minecraft (1.21.4). Was there a fundamental change for textures and models somewhere between versions that i'm missing? I started with Forge 54.1.0 and had this problem, so in my frustration i tried many things: Upgrading to Forge 54.1.1, created multiple new projects, workspaces, redownloaded everything and setting things up multiple times, as it was suggested in an older thread. Therea are no errors in the console logs, but maybe i'm blind, so i pasted the console logs to pastebin anyway: https://pastebin.com/zAM8RiUN The only time i see an error is when i change the models JSON file to an incorrect JSON which makes sense and that suggests to me it is actually reading the JSON file.   I set the github repository to public, i would be so thankful if anyone could take a look and tell me what i did wrong: https://github.com/xLorkin/teleport_pug_forge   As a note: i'm pretty new to modding, this is my first mod ever. But i'm used to programming. I had some up and downs, but through reading the documentation, using google and experimenting, i could solve all other problems. I only started modding for Minecraft because my son is such a big fan and wanted this mod.
    • Please read the FAQ (link in orange bar at top of page), and post logs as described there.
    • Hello fellow Minecrafters! I recently returned to Minecraft and realized I needed a wiki that displays basic information easily and had great user navigation. That’s why I decided to build: MinecraftSearch — a site by a Minecraft fan, for Minecraft fans. Key Features So Far Straight-to-the-Point Info: No extra fluff; just the essentials on items, mobs, recipes, loot and more. Clean & Intuitive Layout: Easy navigation so you spend less time scrolling and more time playing. Optimized Search: Search for anything—items, mobs, blocks—and get results instantly. What I’m Thinking of Adding More data/information: Catch chances for fishing rod, traveling villager trades, biomes info and a lot more. The website is still under development and need a lot more data added. Community Contributions: Potential for user-uploaded tips for items/mobs/blocks in the future. Feature Requests Welcome: Your ideas could shape how the wiki evolves! You can see my roadmap at the About page https://minecraftsearch.com/about I’d love for you to check out MinecraftSearch and see if it helps you find the info you need faster. Feedback is crucial—I want to develop this further based on what the community needs most, so please let me know what you think. Thanks, and happy crafting!
    • Instructions on how to install newer Java can be found in the FAQ
    • That's just plain wrong... newer versions are much better optimised and start a lot faster than 1.8.9, both Forge and Minecraft itself. Comparing Fabric 1.21 with Forge 1.8 is like comparing apples and oranges... one's brand new and the other's over a decade old.
  • Topics

×
×
  • Create New...

Important Information

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