Jump to content

Recommended Posts

Posted

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();
}

}

Posted

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.

Posted

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.

Posted

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.

Posted

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.

Posted

If you want help with a (another) crash, make sure that you post the crash report.

The debugger is a powerful and necessary tool in any IDE, so learn how to use it. You'll be able to tell us more and get better help here if you investigate your runtime problems in the debugger before posting.

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.