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



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • The game crashed whilst unexpected error Error: net.minecraftforge.fml.ModLoadingException: Advanced Mining Dimension (mining_dimension) encountered an error during the done event phase
    • Here is the end of the log. it was way too big to put in pastebin, but I started from when I was online and everything was fine. Error should be in here: https://pastebin.com/Sdhdq593
    • Update: I stand corrected as I was able to dig up a relevant log from my earlier testing which highlights the overall issue but does not explain how to solve it. See, Diagnostic Logs for pack.mcmeta not found: https://pastebin.com/LXS8Rtna
    • Which mod was this? What are all the mods that were in use? It will help if enough information to replicate the problem is available.
    • I have been attempting to create a supplementary resource pack with Patchouli in order to add back the guidebook for Better End but unfortunately in every prototype I have made pack.mcmeta and my resource pack are not recognized. I have tested both zipped and unzipped and either way curseforge does not recognize my resource pack as existing. For testing I stripped my pack down to just the pack.mcmeta file and two empty folders labelled data and assets and I know the data folder is not the problem as firstly my first attempts just had an assets folder following Patchouli instructions and data came later in my flailing attempts to make anything in my pack work. The mcmeta file is not recognized whether or not I use this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } "language": { "en_US": { "name": "English", "region": "United States" } } } ,or this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } } I have made sure to only use lowercase and the pack folder is named better-end-guide. Is this some magic nonsense from me doing this manually instead of using an IDE or similar tool? Could it be because my files are by default in UTF-8 even though ANSI gives the same results? Is there a specific community secret tool I am supposed to use for zipping or specific settings? I am pulling my hair in distress. Unfortunately as there are no errors involved I lack logs to offer, if that disqualifies this thread please do not be harsh and instead if you can then please direct me to a forum with different rules and sufficiently respectful but knowledgeable as to be of assistance. Most of my experience with the programming community has been poor and so naturally I find myself wary.
  • Topics

  • Who's Online (See full list)

    • There are no registered users currently online
×
×
  • Create New...

Important Information

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