Jump to content

Recommended Posts

Posted

Im having an issue were I set the item id for a it in the game, however changes to a different number when I run the client.

 

package hydroblocks;

import net.minecraft.block.Block;
import net.minecraft.block.material.Material;
import net.minecraft.item.Item;
import cpw.mods.fml.common.Mod;
import cpw.mods.fml.common.Mod.EventHandler;
import cpw.mods.fml.common.event.FMLPreInitializationEvent;
import cpw.mods.fml.common.network.NetworkMod;
import cpw.mods.fml.common.registry.GameRegistry;
import cpw.mods.fml.common.registry.LanguageRegistry;

@Mod(modid = HydroBlocks.modid, name = "HydroBlocks Mod", version ="1.0" )
@NetworkMod(clientSideRequired = true, serverSideRequired = false)
public class HydroBlocks 
{
public static final String modid = "pandateam_HydroBlocks";

public static Block hydromixerBlock;

public static Item hydronutrientsItem;

@EventHandler
public void load(FMLPreInitializationEvent event)
{	//2620 is working
	hydromixerBlock = new BlockHydroMixerBlock(2620, Material.rock).setUnlocalizedName("hydromixerBlock");

	GameRegistry.registerBlock(hydromixerBlock, modid + hydromixerBlock.getUnlocalizedName().substring(5));

	LanguageRegistry.addName(hydromixerBlock, "Hydro Mixer");

	//26201 is meant to be the block ID however it seems to be randomly set
	hydronutrientsItem = new Itemhydronutrients(26201).setUnlocalizedName("hydroponicnutrientsItem");

	LanguageRegistry.addName(hydronutrientsItem, "Hydroponic Nutrients");
}
}

 

The item in question that I am having an issue with is the hydronutrientsItem the block id I want to set it to is 26201, however this wont work. When I run the client it sets the item id as 26457

 

Posted
  On 11/30/2013 at 3:56 PM, crystalhero05 said:

Why don't you just put id 2621?

 

That would be a block ID, not an item ID.

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
  On 11/30/2013 at 4:00 PM, Draco18s said:

  Quote

Why don't you just put id 2621?

 

That would be a block ID, not an item ID.

 

I have block id of 2009 and an item id of 2008 I really don't understand the difference.

 

Anyway try putting a lower id for it jibbity

Posted

Because IDs lower than 4096 will conflict with blocks.  Highly not recommended.

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
  On 11/30/2013 at 3:56 PM, crystalhero05 said:

Why don't you just put id 2621?

 

I have tried changing the itemID like you suggested, however it just generated another random number.

Posted
  On 11/30/2013 at 4:45 PM, jibbity said:

  Quote

Why don't you just put id 2621?

 

I have tried changing the itemID like you suggested, however it just generated another random number.

 

Do you have the class of the item? If you do put it up please.

Posted
package hydroblocks;

import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import net.minecraft.client.renderer.texture.IconRegister;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.item.Item;

public class Itemhydronutrients extends Item
{

public Itemhydronutrients(int id) {
	super(id);
	this.setCreativeTab(CreativeTabs.tabMaterials);
}

@SideOnly(Side.CLIENT)
public void registerIcons(IconRegister par1IconRegister)
{
	this.itemIcon = par1IconRegister.registerIcon(HydroBlocks.modid + ":" + (this.getUnlocalizedName().substring(5)));
}
}

Posted

I think you don't have ramdom number into the game. You only have youID + 256, try:

	//26201 is meant to be the block ID however it seems to be randomly set
	hydronutrientsItem = new Itemhydronutrients(26201 - 256).setUnlocalizedName("hydroponicnutrientsItem");

 

It happens because minecraft adds 256 to the ID you set to items, so if you want an item with ID 3000, you will have to write 3000 - 256 or 2744

Posted
  On 11/30/2013 at 4:56 PM, SackCastellon said:

I think you don't have ramdom number into the game. You only have youID + 256, try:

	//26201 is meant to be the block ID however it seems to be randomly set
	hydronutrientsItem = new Itemhydronutrients(26201 - 256).setUnlocalizedName("hydroponicnutrientsItem");

 

It happens because minecraft adds 256 to the ID you set to items, so if you want an item with ID 3000, you will have to write 3000 - 256 or 2744

 

Thank you very much, and to everyone who replied.

Posted
  On 11/30/2013 at 4:52 PM, jibbity said:

package hydroblocks;

import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;
import net.minecraft.client.renderer.texture.IconRegister;
import net.minecraft.creativetab.CreativeTabs;
import net.minecraft.item.Item;

public class Itemhydronutrients extends Item
{

public Itemhydronutrients(int id) {
	super(id);
	this.setCreativeTab(CreativeTabs.tabMaterials);
}

@SideOnly(Side.CLIENT)
public void registerIcons(IconRegister par1IconRegister)
{
	this.itemIcon = par1IconRegister.registerIcon(HydroBlocks.modid + ":" + (this.getUnlocalizedName().substring(5)));
}
}

 

I just noticed: you defined the block and the item inside public void load. try defining it outside of it like this:

 

public static Item Redpick = new ItemRedpick(2000, toolRed).setUnlocalizedName("Redpick");
public static Block RedOre = new RedOre(2009, Material.rock).setUnlocalizedName("RedOre");

Posted
  On 11/30/2013 at 5:00 PM, jibbity said:

  Quote

I think you don't have ramdom number into the game. You only have youID + 256, try:

	//26201 is meant to be the block ID however it seems to be randomly set
	hydronutrientsItem = new Itemhydronutrients(26201 - 256).setUnlocalizedName("hydroponicnutrientsItem");

 

It happens because minecraft adds 256 to the ID you set to items, so if you want an item with ID 3000, you will have to write 3000 - 256 or 2744

 

Thank you very much, and to everyone who replied.

 

The +/- 256 is from the Olden Days when items started at 256 (because blocks were 0-255) but had their own IDs.  So the +256 was to offset them to avoid conflicts with blocks.  It's not needed any more, but the offset is still there as part of some legacy code.  You don't need to worry about it being exact.  In fact, de-offseting it will make your mod slightly less compatible with other mods, as when the user goes to try and solve an ID conflict he'll see this:

 

I:SomeOtherModItemID=4744

I:YourModItemID=5000

 

And be like "why the fuck are these two items conflicting?  They don't have the same ID!"  But surprise, surprise, both IDs get shifted up by 256 (5000, 5256) then you downshift yours again (5000,  5000) and there's a conflict.

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

And don't modify what the config tells you is there.  Don't subtract 256, don't pass go, and don't collect $200.

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.

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

    • I'm developing a Forge mod for Minecraft 1.16.5 to run on CatServer (version 1.16.5-1d8d6313, Forge 36.2.39). My mod needs to get the player's UUID from a ServerPlayerEntity object within a Forge ServerChatEvent handler. When I use serverPlayerEntity.getUUID(), my mod compiles fine, but I get a java.lang.NoSuchMethodError: net.minecraft.entity.player.ServerPlayerEntity.getUUID()Ljava/util/UUID; at runtime. I cannot use serverPlayerEntity.getUniqueID() as it causes a compile error (cannot find symbol). Is there a known issue with this on CatServer, or a recommended way for a Forge mod to reliably get a player's UUID from ServerPlayerEntity in this environment? My goal is to pass this UUID to the LuckPerms API (which is running as a Bukkit plugin and successfully connected via ServicesManager). erorr ChatMod: FMLServerStartedEvent received. Attempting to initialize LuckPerms connection... [22:45:20] [Server thread/INFO]: ⚙️ Початок ініціалізації LuckPerms API через Bukkit Services Manager... [22:45:20] [Server thread/INFO]: ✅ Bukkit ServicesManager успішно отримано. [22:45:20] [Server thread/INFO]: ✅ Реєстрацію сервісу LuckPerms знайдено. [22:45:20] [Server thread/INFO]: ✅ API LuckPerms успішно отримано від Bukkit plugin! [22:45:20] [Server thread/INFO]: Використовується реалізація: me.lucko.luckperms.common.api.LuckPermsApiProvider [22:45:20] [Server thread/INFO]: ✅ LuckPerms API схоже що успішно ініціалізовано через Bukkit Services Manager. [22:45:24] [User Authenticator #1/INFO]: UUID of player Hiklee is 92cd7721-2652-3867-896b-2ceba5b99306 [22:45:25] [Server thread/INFO]: Using new advancement loading for net.minecraft.advancements.PlayerAdvancements@24cb7a68 [22:45:26] [Server thread/INFO]: Hiklee[/127.0.0.1:41122] logged in with entity id 210 at (92.23203876864889, 95.6183020148442, 68.24087802017877) [22:45:28] [Async Chat Thread - #0/INFO]: ✅ Скасовано стандартне відправлення чату! [22:45:28] [Async Chat Thread - #0/ERROR]: Exception caught during firing event: net.minecraft.entity.player.ServerPlayerEntity.getUUID()Ljava/util/UUID; Index: 1 Listeners: 0: NORMAL 1: ASM: class com.example.chatmod.ChatEventHandler onPlayerChat(Lnet/minecraftforge/event/ServerChatEvent;)V java.lang.NoSuchMethodError: net.minecraft.entity.player.ServerPlayerEntity.getUUID()Ljava/util/UUID; at com.example.chatmod.ChatPacketHandler.getPlayerPrefix(ChatPacketHandler.java:46) at com.example.chatmod.ChatEventHandler.onPlayerChat(ChatEventHandler.java:32) at net.minecraftforge.eventbus.ASMEventHandler_1_ChatEventHandler_onPlayerChat_ServerChatEvent.invoke(.dynamic) at net.minecraftforge.eventbus.ASMEventHandler.invoke(ASMEventHandler.java:85) at net.minecraftforge.eventbus.EventBus.post(EventBus.java:303) at net.minecraftforge.eventbus.EventBus.post(EventBus.java:283) at net.minecraftforge.common.ForgeHooks.onServerChatEvent(ForgeHooks.java:493) at net.minecraft.network.play.ServerPlayNetHandler.chat(ServerPlayNetHandler.java:1717) at net.minecraft.network.play.ServerPlayNetHandler.func_244548_c(ServerPlayNetHandler.java:1666) at net.minecraft.network.play.ServerPlayNetHandler.func_147354_a(ServerPlayNetHandler.java:1605) at net.minecraft.network.play.client.CChatMessagePacket.lambda$handle$0(CChatMessagePacket.java:34) at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) at java.util.concurrent.FutureTask.run(FutureTask.java:266) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) at java.lang.Thread.run(Thread.java:750
    • Thank you so much for your help, I'll try it as soon as I can. I have a genuine question because I'm not familiar with the matter: Can a recipe error cause something as serious as the AMD error?
    • When i try to launch my modpack, the instance crashes and this is sent to the logs: Time: 2025-05-27 23:07:18 Description: Rendering overlay Below is the full log: https://mclo.gs/jP5G2EH
    • Make a test without delightful
  • Topics

×
×
  • Create New...

Important Information

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