Jump to content

[1.8.9] Cant resolve Error on an easy blockstates Ore Block..


Mattizin

Recommended Posts

Hey Guys,

 

I'm just learning modding for 1.8.9

I want to create a simple BlockOre with an EnumOreType with 3 Types of Ores.

Everything works, except the in Inventory/Hand rendering.

I get the following error:

[23:23:45] [Client thread/ERROR] [FML]: Model definition for location mattech:ore#inventory not found

i googled and tried it for days now but all i found was "Your json files have to be in the wrong place", but i think they are right...

Please help me. Thanks.

Full github repository:

https://github.com/M4tt1z1n/Mattech

Like i said the Block is BlockOre with EnumOreType

 

Mattizin

Link to comment
Share on other sites

Mhh. In my opinion when i Register the Blocks(subblocks) like this with the name  + "Ore" i should be able to reach the json file with name+Ore or im wrong?

for(int i = 0; i < EnumOreType.values().length; i++) 
	{
		registerRender(ModBlocks.ore, i, EnumOreType.values()[i].getName() + "Ore");
	}

Link to comment
Share on other sites

Yeah, thought github link was enough, but here it is:

public static void registerRender(Block block, int meta, String fileName) 
{
	Item item = Item.getItemFromBlock(block);
	Minecraft.getMinecraft().getRenderItem().getItemModelMesher().register(item, meta,
			new ModelResourceLocation(modid + ":" + fileName, "inventory"));
	System.out.println(modid + ":" + fileName);
}

Link to comment
Share on other sites

By default, the only model loaded for an

Item

(including an

ItemBlock

) is the one with its registry name (

Item#getRegistryName

).

 

You're telling Minecraft to use different models for each metadata value of the

Item

form of

ModBlocks.ore

, but you never tell it to load any of these models.

 

To tell Minecraft to load a model other than the default one, call

ModelBakery.registerItemVariants

in preInit. Each argument is either the location of an item model or the location and variant of a blockstates file to load the model from.

 

Don't use

ItemModelMesher#register

, use

ModelLoader.setCustomModelResourceLocation

(for metadata-based models, will call

ModelBakery.registerItemVariants

for you) or

ModelLoader.setCustomMeshDefinition

(for arbitrary

ItemStack

to

ModelResourceLocation

mapping) in preInit.

 

Never use

getUnlocalizedName().substring(5)

anywhere in your code. Unlocalised names can change at any time, registry names are IDs and must not change. As I said before, the default model loaded for an

Item

is the one with its registry name, unlocalised names have nothing to do with models.

 

I suggest using the registry name system to register your

Block

s and

Item

s: Call

setRegistryName

to set the registry name, then call the single argument overload of

GameRegistry.registerBlock

/

registerItem

to register the

Block

/

Item

. Do not use unlocalised names as registry names, but you can use registry names as unlocalised names (this will include your mod ID in the unlocalised name, which will avoid conflicts with other mods).

 

Using registry names now will make it much easier to update to the new registry system in 1.9.

Please don't PM me to ask for help. Asking your question in a public thread preserves it for people who are having the same problem in the future.

Link to comment
Share on other sites

See here for an example of what I'm talking about.

registerBlockItemModelForMeta

(which you can see in the same class) is essentially just a wrapper around

ModelLoader.setCustomModelResourceLocation

.

 

This uses a variant of the block's blockstates file (uses Forge's blockstates format) rather than an item model. To use an item model, use a

ModelResourceLocation

with the model's location and the

"inventory"

variant.

 

Use the

getRegistryName

method to get the registry name of an

Item

or

Block

.

 

Most of my mod's items use this method to set their registry and unlocalised names, but some (e.g. Records) have completely separate unlocalised and registry names that they set manually. I use a similar method for blocks.

Please don't PM me to ask for help. Asking your question in a public thread preserves it for people who are having the same problem in the future.

Link to comment
Share on other sites

Thank you, that works now. I just have to rewrite my method to register the blockrenderer for the normal blocks(not meta) because mc crashes when i use my method at the moment when it is loaded in pre init. I commented it out to test only the meta Block and that worked :)

Link to comment
Share on other sites

The

RenderItem

instance is created between preInit and init, so you can't access it in preInit. The solution is to use the

ModelLoader

methods instead of the

ItemModelMesher

methods.

Please don't PM me to ask for help. Asking your question in a public thread preserves it for people who are having the same problem in the future.

Link to comment
Share on other sites

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



×
×
  • Create New...

Important Information

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