vin0m Posted July 10, 2018 Share Posted July 10, 2018 I am trying to give an item to a player and for some reason this code that was working in 1.10.2 will not work in 1.12.2. I can't figure out what I need to do differently. Code: ItemStack stack = new ItemStack(ModItems.goldSatchel); Item item = stack.getItem(); int newItemValue = maxItemDamage - value; item.setDamage(stack, newItemValue); player.inventory.addItemStackToInventory(stack); The new item is not placed in the players inventory. Did something change in 1.12? Quote Link to comment Share on other sites More sharing options...
cubicoder Posted July 10, 2018 Share Posted July 10, 2018 Where are you running this code? Quote Check out my tutorials at https://cubicoder.github.io/. Link to comment Share on other sites More sharing options...
aw_wolfe Posted July 10, 2018 Share Posted July 10, 2018 you can set the damage directly to the stack stack.setItemDamage(); Are you getting an item in inventory, or just not a damaged item? Quote Link to comment Share on other sites More sharing options...
vin0m Posted July 10, 2018 Author Share Posted July 10, 2018 4 minutes ago, cubicoder said: Where are you running this code? I am running it in my class "CommandGoldCoins implements ICommand {" in the section "public void execute(MinecraftServer server, ICommandSender sender, String[] input) throws CommandException". 5 minutes ago, aw_wolfe said: you can set the damage directly to the stack stack.setItemDamage(); Are you getting an item in inventory, or just not a damaged item? A part of this command modifies the current item damage. That works fine. It is also supposed to make a new item (code above) with a set damage amount. The new item does not appear in the inventory. It worked fine in 1.10.2 so I'm confused on what has changed. Quote Link to comment Share on other sites More sharing options...
cubicoder Posted July 10, 2018 Share Posted July 10, 2018 (edited) Looking at the code for the /give command, it looks like you have to have the player drop the item stack using player.dropItem(itemstack, false). Then make the resulting EntityItem have no pickup delay and set the owner to the player (entityitem.setNoPickupDelay() and entityitem.setOwner(entityplayer.getName()), respectively). I've never messed with commands before, though, so I may be wrong. Edited July 10, 2018 by cubicoder Quote Check out my tutorials at https://cubicoder.github.io/. Link to comment Share on other sites More sharing options...
vin0m Posted July 10, 2018 Author Share Posted July 10, 2018 Apparently you can only set the item damage up to 4 digits. Anything over that and it fails to create the item. That was the issue. Quote Link to comment Share on other sites More sharing options...
Animefan8888 Posted July 10, 2018 Share Posted July 10, 2018 (edited) 22 hours ago, vin0m said: Apparently you can only set the item damage up to 4 digits. Anything over that and it fails to create the item. That was the issue. ItemStack#itemDamage is truncated to a short value aka the max is 32767(thank you Draco18s). ItemStacks are considered empty if their itemDamage is greater than 65535 or less than -32767. Edited July 11, 2018 by Animefan8888 Error Quote VANILLA MINECRAFT CLASSES ARE THE BEST RESOURCES WHEN MODDING I will be posting 1.15.2 modding tutorials on this channel. If you want to be notified of it do the normal YouTube stuff like subscribing, ect. Forge and vanilla BlockState generator. Link to comment Share on other sites More sharing options...
Draco18s Posted July 10, 2018 Share Posted July 10, 2018 12 hours ago, Animefan8888 said: ItemStack#itemDamage is truncated to a short value aka the max is 65535. *cough* 32766. 32767 is the Wildcard Value ("match any"). Quote 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 More sharing options...
Recommended Posts
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.