Jump to content

[1.10.2] Custom Crop Planting Crash


THEGamingninja

Recommended Posts

I'm having a bit of an Issue with Crops, whenever I try to place the seed It crashes the game

Here's my code.

 

Seed Item Class

package thegamingninja.moreutils.init;

import net.minecraft.block.Block;
import net.minecraft.init.Blocks;
import net.minecraft.item.ItemSeeds;
import thegamingninja.moreutils.Load;
import thegamingninja.moreutils.Reference;

public class ItemRegenSeed extends ItemSeeds {

public ItemRegenSeed(){
	super(ModCrops.regencrop, Blocks.FARMLAND);
	setUnlocalizedName("regen_seed");
	setRegistryName(Reference.MoreUtilItems.REGEN_SEED.getRegistryName());
	setCreativeTab(Load.CREATIVE_TAB);
 }
}

 

package thegamingninja.moreutils.init;

import net.minecraft.block.Block;
import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.block.model.ModelResourceLocation;
import net.minecraft.item.Item;
import net.minecraft.item.ItemBlock;
import net.minecraftforge.fml.common.registry.GameRegistry;
import thegamingninja.moreutils.Reference;
import thegamingninja.moreutils.block.CropRegen;

public class ModCrops {

public static Block regencrop;

public static void init() {

	regencrop = new CropRegen();
}

public static void register() {
	registerBlock(regencrop);
}

public static void registerRenders() {
	registerRender(regencrop);

}

private static void registerBlock(Block block) {
	GameRegistry.register(block);
	ItemBlock item = new ItemBlock(block);
	item.setRegistryName(block.getRegistryName());
	GameRegistry.register(item);
}
private static void registerRender(Block block) {

	Item item = Item.getItemFromBlock(block);

	Minecraft.getMinecraft().getRenderItem().getItemModelMesher()
	.register(item, 0, new ModelResourceLocation(Reference.MOD_ID + ":" + item.getUnlocalizedName() .substring(5), "inventory"));
}



}

 

Client Proxy Class

package thegamingninja.moreutils.proxy;

import thegamingninja.moreutils.init.ModBlocks;
import thegamingninja.moreutils.init.ModCrops;
import thegamingninja.moreutils.init.ModItems;

public class ClientProxy implements CommonProxy {

@Override
public void init() {
	ModItems.registerRenders();
	ModBlocks.registerRenders();
	ModCrops.registerRenders();
}

}

Link to comment
Share on other sites

You register your items before your blocks, so you pass null to your item's constructor.

 

There's literally 4000 posts on this forum about this issue.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

I changed It to this

package thegamingninja.moreutils.proxy;

import thegamingninja.moreutils.init.ModBlocks;
import thegamingninja.moreutils.init.ModCrops;
import thegamingninja.moreutils.init.ModItems;

public class ClientProxy implements CommonProxy {

@Override
public void init() {
	ModBlocks.registerRenders();
	ModItems.registerRenders();
	ModCrops.registerRenders();
}

}

 

Still have the same Issue.

Link to comment
Share on other sites

Gosh.

What ever could the problem be?

 

This is one of the reasons one should use the new

RegistryEvent

s, to avoid problems like these.

 

Given that I've seen people (try to) pass the item to their block, and the block to their item...I'm not so sure.

 

You can't do that.

Your crop class must reference ModItems.seed directly, it cannot take it as a parameter to its constructor.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

Link to comment
Share on other sites

I haven't messed with them yet myself.  Here's how Lex does it:

https://github.com/LexManos/VoidUtils/blob/master/src/main/java/net/minecraftforge/lex/voidutils/VoidUtils.java#L96-L120

 

But the point remains:

 

Your crop class must reference ModItems.seed directly, it cannot take it as a parameter to its constructor.

Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable.  If you think this is the case, JUST REPORT ME.  Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice.

 

Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked.

 

DO NOT PM ME WITH PROBLEMS. No help will be given.

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.