Jump to content
View in the app

A better way to browse. Learn more.

Forge Forums

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Featured Replies

Posted

So in this method, specifically at itemStack.isEmpty(), when I am in creative mode and right click on water with a bottle, the bottle quickly fills with water then instantly gets removed from the inventory. itemStack#isEmpty is called when there is only 1 bottle left in the stack. In survival this does not happen and it fills up as it should. Everything else is working fine. Also if I change it to PlayerInteractEvent.RightClickBlock, this problem does not occur. This is everything in the class.

Spoiler

@SubscribeEvent
public ActionResult<ItemStack> onItemRightClick(PlayerInteractEvent.RightClickItem event) {
    EntityPlayer player = event.getEntityPlayer();
    EnumHand hand = EnumHand.MAIN_HAND;
    ItemStack itemStack = player.getHeldItem(hand);
    World world = event.getWorld();

    RayTraceResult rayTraceResult = this.rayTrace(world, player, true);

    if (rayTraceResult == null) {
        return new ActionResult(EnumActionResult.PASS, itemStack);
    } else {

        BlockPos blockpos = rayTraceResult.getBlockPos();

        if (world.getBlockState(blockpos).getMaterial() == Material.WATER && itemStack.getItem() == ItemInit.BOTTLE) {
            if (event.getHand() == player.getActiveHand()) {

                player.playSound(SoundEvents.ITEM_BOTTLE_FILL, 1.0f, 1.0f);
                itemStack.shrink(1);

                if (itemStack.isEmpty()) {

                    player.setHeldItem(hand, new ItemStack(ItemInit.WATER));
                } else if (!player.inventory.addItemStackToInventory(new ItemStack(ItemInit.WATER))) {

                    player.dropItem(new ItemStack(ItemInit.WATER), false);
                }
            }

        }
    }

    return new ActionResult(EnumActionResult.PASS, itemStack);
}

 

  • Author

Thanks! I got it working. Just a quick question while I'm on this topic, does my class have to extend Item to use RayTraceResult?

14 minutes ago, Siqhter said:

Just a quick question while I'm on this topic, does my class have to extend Item to use RayTraceResult?

No

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.

  • Author

Ok, I might have been misunderstanding, but since RayTraceResult is protected, I can access it with the this keyword if my class extends Item.

34 minutes ago, Siqhter said:

Ok, I might have been misunderstanding, but since RayTraceResult is protected, I can access it with the this keyword if my class extends Item.

Oh, well then no you cant use it. I didnt know if it was protected or not.

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.

  • Author

Ok, thanks. I could just copy over the RayTraceResult method, but that's extra code.

Edited by Siqhter

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...

Important Information

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

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.