Jump to content

Detecting an item and performing actions on it in a player's inventory


Recommended Posts

Posted

Like the title says I am trying to detect if the player has a certain item in their inventory, and if they do perform a few actions on it. I have been struggling to find a way to do that, at first I figured I would use the "haveItemStack" method, however while that would tell me they have it doesn't return the itemstack which I would need to perform the actions on. So now I have been thinking about doing a for loop that would look through every item in the inventory using the getStackInSlot method. But I can't seem to figure out what values i can be and how that number would relate to the rest of the inventory. Anyone know? Or better yet does anyone know of another easier way to do what I am trying to?

Creator of the Recipe Expansion Pack mod.

http://www.minecraftforum.net/topic/1983421-172-forge-recipe-expansion-pack-version-012/

Updated to 1.7.2!

Posted

I don't know how you would detect if an item is in the inventory, but I have been detecting when an item is picked up for my mod. For example, when an item is picked up, a specified action takes place.

 

public class PickupHandler implements IPickupNotifier {
@Override
public void notifyPickup(EntityItem item, EntityPlayer player) {

                if (item.getEntityItem().itemID == Items.yourItem.itemID){
                      <perform an action>
                }
        }
}

 

Hope this helps!

Posted

Here is how I do this in my parachute mod.

public static ItemStack inventoryContainsAAD(InventoryPlayer inventory) {
ItemStack itemstack = null;
for (ItemStack s : inventory.mainInventory) {
	if (s != null && s.getItem() instanceof ItemAutoActivateDevice) {
		itemstack = s;
		break;
	}
}
return itemstack;
}

 

you can view the code at https://github.com/m1k3s/parachute

Posted

How about the 'onUpdate' method from Item? It is called automatically for every ItemStack containing your Item each tick, so long as you override this method in your Item class. Maps use it to update while being held, but it's called so long as the item is in your inventory, not necessarily held.

 

These are the parameters:

public void onUpdate(ItemStack itemstack, World world, Entity entity, int par4, boolean isCurrentItem)

Sorry I'm not sure what 'par4' is, I think ticks in use but I may be wrong.

Posted

Just make a commontickhandler that implements ITickHandler and use

if(player.inventory.hasItem(Main.itemwhatever.itemID){
Do Stuff.
}

(Just google how to make a common tick handler if you're unsure)

Also for reference here's how I check if the player has a power beam and an upgrade in their inventory, and if so consumes them and adds a power beam that can switch to the ice beam:

 

if (player.inventory.hasItem(Main.ItemIceUpgrade.itemID) && player.inventory.hasItem(Main.ItemPowerBeam.itemID)) {
		player.inventory.consumeInventoryItem(Main.ItemIceUpgrade.itemID);
		player.inventory.consumeInventoryItem(Main.ItemPowerBeam.itemID);
		player.inventory.addItemStackToInventory(ItemPowerBeamStackI);


	}

 

Hope it helps!

Creator of Metroid Cubed! Power Suits, Beams, Hypermode and more!

width=174 height=100http://i.imgur.com/ghgWmA3.jpg[/img]

Posted

A slightly better, and less resource/time consuming way to do this would be to implement to of the earlier said ways. You would first do a check to see if the player has the item in their inventory, THEN run the for loop to get what slot it is in, and from there, get the itemstack.

If the player doesn't have the item... Just do nothing.

I am Mew. The Legendary Psychic. I behave oddly and am always playing practical jokes.

 

I have also found that I really love making extremely long and extremely but sometimes not so descriptive variables. Sort of like what I just did there xD

Posted
You would first do a check to see if the player has the item in their inventory, THEN run the for loop

 

How can you detect that the item exists in the array without looking at the array?

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



×
×
  • Create New...

Important Information

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