Jump to content

check if held item has the right id (1.16.5)


Chigoma333

Recommended Posts

I'm trying to make a kill counter on a weapon (actually for Curio Ring but I didn't know how to read the ring slot). So now I want to see if the ID of the item matches the ID of the item the player is holding. I know that you can't compare an ItemStack with an Item, is there another way to get the Item the player is holding or a way to see what id an Item has in an ItemStack? Of course System.out.println("Hello World!") is only for testing if it worked.

package de.chigoma333.ringofblood.core.init;

import de.chigoma333.ringofblood.core.init.customitem.Ring_of_Blood;
import net.minecraft.block.material.Material;
import net.minecraft.entity.Entity;
import net.minecraft.entity.player.PlayerEntity;
import net.minecraft.inventory.ItemStackHelper;
import net.minecraft.item.Item;
import net.minecraft.item.ItemStack;
import net.minecraft.item.Items;
import net.minecraft.potion.EffectInstance;
import net.minecraft.potion.Effects;
import net.minecraftforge.event.entity.living.LivingDeathEvent;
import net.minecraftforge.items.ItemHandlerHelper;
import top.theillusivec4.curios.api.type.ISlotType;

import static de.chigoma333.ringofblood.core.init.ItemInit.RING_OF_BLOOD;

public class Event {



    public void onLivingDeathEvent(LivingDeathEvent event) {

    if(!event.getEntity().getEntityWorld().isRemote) {
        Entity killer = event.getSource().getTrueSource();
        if(killer != null && killer instanceof PlayerEntity) {
            Iterable<ItemStack> b = killer.getHeldEquipment(); //MUSS ZUM SLOT GEÄNDERT WERDEN
            ItemStack heldItem = b.iterator().next();
            if(heldItem == RING_OF_BLOOD){
                System.out.println("Hello World!");
        }
    }
}


    }
}

 

Link to comment
Share on other sites

Now I have the feeling that I am too stupid

import net.minecraftforge.event.entity.living.LivingDeathEvent;
import static de.chigoma333.ringofblood.core.init.ItemInit.RING_OF_BLOOD;

public class Event {



    public void onLivingDeathEvent(LivingDeathEvent event) {

    if(!event.getEntity().getEntityWorld().isRemote) {
        Entity killer = event.getSource().getTrueSource();
        if(killer != null && killer instanceof PlayerEntity) {
            Iterable<ItemStack> b = killer.getHeldEquipment(); //MUSS ZUM SLOT GEÄNDERT WERDEN
            ItemStack heldItem = b.iterator().next();
            if(heldItem instanceof RING_OF_BLOOD) {
                System.out.println("Hello World!");
        }
    }
}

 

Link to comment
Share on other sites

I have written this now it does not throw me an error but it does not work. (Sorry I know that I'm annoying)

public class Event {



    public void onLivingDeathEvent(LivingDeathEvent event) {
    if(!event.getEntity().getEntityWorld().isRemote) {
        Entity killer = event.getSource().getTrueSource();
        if(killer != null && killer instanceof PlayerEntity) {
            Iterable<ItemStack> b = Collections.singleton(((PlayerEntity) killer).getHeldItem(Hand.MAIN_HAND)); //MUSS ZUM SLOT GEÄNDERT WERDEN
            Item heldItem = b.iterator().next().getItem();
            if(heldItem.equals(RING_OF_BLOOD)) {
                PlayerEntity player = (PlayerEntity) killer;
                player.addPotionEffect(new EffectInstance(Effects.FIRE_RESISTANCE, 200));
            }
        }
    }
}
}

 

Link to comment
Share on other sites

RING_OF_BLOOD is an item I have added.

public class ItemInit {
    public static final DeferredRegister<Item> ITEMS = DeferredRegister.create(ForgeRegistries.ITEMS, Ringofblood.MOD_ID);

    public static final RegistryObject<Item> test = ITEMS.register("test",
            () -> new Item(new Item.Properties().group(ItemGroup.COMBAT)));

    public static final RegistryObject<Item> RING_OF_BLOOD = ITEMS.register("ring_of_blood",
            () -> new Ring_of_Blood(new Item.Properties().group(ItemGroup.COMBAT)));
}

My code is executed until if(heldItem.equals(RING_OF_BLOOD)) then it is not executed any further

public class EventKillCounterHandler  {

    @SubscribeEvent
    public void onLivingDeathEvent(LivingDeathEvent event) {
        if(!event.getEntity().getEntityWorld().isRemote) {
            Entity killer = event.getSource().getTrueSource();
            if(killer != null && killer instanceof PlayerEntity) {
                Iterable<ItemStack> b = Collections.singleton(((PlayerEntity) killer).getHeldItem(Hand.MAIN_HAND)); //MUSS ZUM SLOT GEÄNDERT WERDEN
                Item heldItem = b.iterator().next().getItem();
                if(heldItem.equals(RING_OF_BLOOD)) {
                    PlayerEntity player = (PlayerEntity) killer;
                    player.addPotionEffect(new EffectInstance(Effects.FIRE_RESISTANCE, 200));
                }
            }
        }
    }
}

 

Link to comment
Share on other sites

I think I have managed that there is now an id.

public class EventKillCounterHandler  {
    @SubscribeEvent
    public void onLivingDeathEvent(LivingDeathEvent event) {
        if(!event.getEntity().getEntityWorld().isRemote) {
            Entity killer = event.getSource().getTrueSource();
            if(killer != null && killer instanceof PlayerEntity) {
                Iterable<ItemStack> b = Collections.singleton(((PlayerEntity) killer).getHeldItem(Hand.MAIN_HAND)); //MUSS ZUM SLOT GEÄNDERT WERDEN
                Item heldItem = b.iterator().next().getItem();
                if(heldItem.equals(RING_OF_BLOOD.getId())) {
                    PlayerEntity player = (PlayerEntity) killer;
                    player.addPotionEffect(new EffectInstance(Effects.FIRE_RESISTANCE, 200));
                }
            }
        }
    }
}

 But unfortunately I still have the problem that

Item heldItem = b.iterator().next().getItem();

still only throws out the number 1.

Link to comment
Share on other sites

I use iterator because without me it throws the error Cannot resolve method getItem in Iterable.
Example:

Iterable<ItemStack> b = Collections.singleton(((PlayerEntity) killer).getHeldItem(Hand.MAIN_HAND));
                Item heldItem = b.getItem();

throws out the error "Cannot resolve method getItem in Iterable".

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



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • So the default PlayerModel contains this code here to set the players arms to slim   if (pSlim) { $$3.addOrReplaceChild("left_arm", CubeListBuilder.create().texOffs(32, 48).addBox(-1.0F, -2.0F, -2.0F, 3.0F, 12.0F, 4.0F, pCubeDeformation), PartPose.offset(5.0F, 2.5F, 0.0F)); $$3.addOrReplaceChild("right_arm", CubeListBuilder.create().texOffs(40, 16).addBox(-2.0F, -2.0F, -2.0F, 3.0F, 12.0F, 4.0F, pCubeDeformation), PartPose.offset(-5.0F, 2.5F, 0.0F)); $$3.addOrReplaceChild("left_sleeve", CubeListBuilder.create().texOffs(48, 48).addBox(-1.0F, -2.0F, -2.0F, 3.0F, 12.0F, 4.0F, pCubeDeformation.extend(0.25F)), PartPose.offset(5.0F, 2.5F, 0.0F)); $$3.addOrReplaceChild("right_sleeve", CubeListBuilder.create().texOffs(40, 32).addBox(-2.0F, -2.0F, -2.0F, 3.0F, 12.0F, 4.0F, pCubeDeformation.extend(0.25F)), PartPose.offset(-5.0F, 2.5F, 0.0F)); } else { $$3.addOrReplaceChild("left_arm", CubeListBuilder.create().texOffs(32, 48).addBox(-1.0F, -2.0F, -2.0F, 4.0F, 12.0F, 4.0F, pCubeDeformation), PartPose.offset(5.0F, 2.0F, 0.0F)); $$3.addOrReplaceChild("left_sleeve", CubeListBuilder.create().texOffs(48, 48).addBox(-1.0F, -2.0F, -2.0F, 4.0F, 12.0F, 4.0F, pCubeDeformation.extend(0.25F)), PartPose.offset(5.0F, 2.0F, 0.0F)); $$3.addOrReplaceChild("right_sleeve", CubeListBuilder.create().texOffs(40, 32).addBox(-3.0F, -2.0F, -2.0F, 4.0F, 12.0F, 4.0F, pCubeDeformation.extend(0.25F)), PartPose.offset(-5.0F, 2.0F, 0.0F)); } And that's got me thinking. If I can't replace the whole model in one fell swoop, what if I replaced each individual limb with my models mesh definitions? Note: It was crazy. The createMesh method in PlayerModel could not be @Overriden and addOrReplaceChild just makes changes to a new model that uses the original as a base.     However, I did render my model using this   final toatestentity idk = entities.toatest.get().create(p.level()); Minecraft.getInstance().getEntityRenderDispatcher().getRenderer(idk).render(idk, 0f, pTicks, stack, buffer, paLights); However that just uses the render from the entity I used to test getting the model to render in the first place. I don't want to do that. I want to fully replace the player model which this doesn't actually do (I don't think?).  Maybe it'd just be best to render my model as a new layer and make the base player model invisible? Maybe I'll take a look at how armor is rendered to move with the player so I won't have to make my own animations? Idk, I'm really set on figuring this out though.
    • AT Launcher works just fine
    • Make a test with another Launcher like MultiMC or AT Launcher  
    • https://mclo.gs/EZ0jeA2
  • Topics

×
×
  • Create New...

Important Information

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