Jump to content
Sign in to follow this  
Shady1

short api question

Recommended Posts

hi,

I made another thread asking how to detect the equipment that another person is wearing and someone was very nice and provided this information on the API to use for me, below.  I'm having trouble figuring out how to implement it, if anyone could use this with a small example for me on creating the method.  Also, unclear what the filters would be and how I would go about making them, thank you very much.

 

//===================================================================

Players.getAll(filter) / Players.findNearest(filter)   (Filter used to exclude yourself)
getDefinition()
getEquipment()

Make sure to length/null check when necessary.

//===================================================================

Share this post


Link to post
Share on other sites
    private RSItem[] getPlayerEquipment(String player_name) {
        final RSPlayer[] player = Players.find(Filters.Players.nameEquals(player_name));
        if (player.length <= 0)
            return null;

        final RSPlayerDefinition player_definition = player[0].getDefinition();
        if (player_definition == null)
            return null;

        return player_definition.getEquipment();
    }

Null check

Share this post


Link to post
Share on other sites
1 hour ago, Sphiinx said:
    private RSItem[] getPlayerEquipment(String player_name) {
        final RSPlayer[] player = Players.find(Filters.Players.nameEquals(player_name));
        if (player.length <= 0)
            return null;

        final RSPlayerDefinition player_definition = player[0].getDefinition();
        if (player_definition == null)
            return null;

        return player_definition.getEquipment();
    }

Null check

should return an empty array.

Share this post


Link to post
Share on other sites
On 11/1/2016 at 11:44 AM, Sphiinx said:
    private RSItem[] getPlayerEquipment(String player_name) {
        final RSPlayer[] player = Players.find(Filters.Players.nameEquals(player_name));
        if (player.length <= 0)
            return null;

        final RSPlayerDefinition player_definition = player[0].getDefinition();
        if (player_definition == null)
            return null;

        return player_definition.getEquipment();
    }

Null check

sorry i am confused still.  see im trying to see the enemies gear, so that i can say, if the enemy has the gear that matches what i write down for example if they have a blue wizard hat on, i want to teleport out.  so i don't understand how to implement this.  also how it just says "private rsitem" i thought a method needed to be boolean or void sorry if i sound noob cuz i am.

Share this post


Link to post
Share on other sites
41 minutes ago, Shady1 said:

sorry i am confused still.  see im trying to see the enemies gear, so that i can say, if the enemy has the gear that matches what i write down for example if they have a blue wizard hat on, i want to teleport out.  so i don't understand how to implement this.  also how it just says "private rsitem" i thought a method needed to be boolean or void sorry if i sound noob cuz i am.

You should look into learning more java.

  • Like 1

Share this post


Link to post
Share on other sites
3 hours ago, Shady1 said:

is it possible to do this though? detect what they are wearing and do something if they are wearing a certain item?

I've answered a few days ago on your previous post

Now that I know what you really want to do with the method i can rewrite it:
 

// a list of item names
private List<String> itemNames = Arrays.asList("blue wizard hat");   

// a filter to find other players
private Filter<RSPlayer> enemies = new Filter<RSPlayer>() {
	private RSPlayer myself = Player.getRSPlayer();
	@Override
	public boolean accept(RSPlayer p) {
		return p != null && !p.equals(myself);
	}
};

private boolean enemyFound() {	
	List<String> enemyItemNames = new ArrayList<String>();

	// get every enemy item around you
	for (RSPlayer p : Players.find(enemies)) {
		RSPlayerDefinition player = p.getDefinition();
		if (player != null) {
			for (RSItem i : player.getEquipment()) {
				RSItemDefinition item = i.getDefinition();
				if (item != null) {
					enemyItemNames.add(item.getName());
				}
			}	
		}
	}
	
	// if disjoint returns false, we have found an item that matches the ones you specified
	return !Collections.disjoint(itemNames, enemyItemNames);
}

@Override
public void run() {

	if (enemyFound()) {
		// enemy found, do your logic here
	}
}

An example with "Quest point cape" on items list:
32JlNfT.png

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

  • Our picks

    • This update will:

      Allow for clicking through the chat box when possible (Thanks @Todd)


      Fix Combat#selectIndex (Thanks @Encoded)


      Ensure worlds stay sorted and added a check to avoid misclicks in the in-game world hopper (Thanks @erickho123)


      Fix out-dated Options API interface indices (Thanks @Todd)



      Upcoming updates:

      Break handler bug fix


      Improved CLI support


      Much more



      Note: If you are using LG, please restart both the RS client and TRiBot
      • 7 replies
    • This release will:

      Fix login bot after today's game update (Thanks @JoeDezzy1)


      Fix latest in-game world hopping issues (Thanks @erickho123)


      Compact Settings UI and set location relative to TRiBot (Thanks @JoeDezzy1)


      Fix an older implementation of GrandExchange#getWindowState (Thanks @JoeDezzy1)


      Improve the preformance of NPCChat by only searching in certain interface parents (Thanks @JoeDezzy1)



      Upcoming updates:

      Break handler bug fix


      Improved CLI support


      LG support for RuneLite


      Much more



      Note: If you are using LG, please restart both the RS client and TRiBot
      • 16 replies
    • This release will:

      Fix bytecode manipulation in order to prevent the modification of parameters within the Filter and Condition classes themselves (thanks @wastedbro)


      Fix NPE caused by non-null value in GE API (thanks @erickho123)


      Add and fix equals methods for api2007.types (thanks @JoeDezzy1)


      Modify Mouse#leaveGame to make the mouse leave the game from top, left, right, or bottom (thanks @erickho123)


      Add Entrana area to Ships API (thanks @erickho123)


      Fix raid prayers index/settings in Prayer API (thanks @erickho123)



      Upcoming updates:

      Break handler bug fix


      Improved CLI support


      Much more



      Note: If you are using LG, please restart both the RS client and TRiBot
      • 29 replies
    • This update will:

      Implement better canvas locking/synchronization mechanism


      Fix small Login API bug


      Remove the requirement for xbooting Java classes


      Use ExecutorService to perform canvas work in parallel


      Add "Account Management" game tab to GameTab API (thanks @Encoded)


      Fix NPCChat#getMessage (thanks @Encoded )


      Fix NPCChat#selectOption (thanks @Encoded )


      Fix Banking API after today's update (thanks @Encoded )


      Fix in-game world hopper after today's update (thanks @Encoded )



      Upcoming updates:

      Break handler bug fix


      Improved CLI support


      Much more



      Note: If you are using LG, please restart both the RS client and TRiBot
      • 38 replies
    • This release includes:

      Fix updater bug which was causing a bunch of issues


      TRiBot will no longer require manual hook fixes every time the RS client updates - the updater has been fully patched for objects


      Hooked login fields


      Improved the login bot


      Ability to recognize the banned/locked messages again


      Ability to read the current input for username and password fields


      If the username or password is already entered correctly, it won't be erased


      If only part of the username or password is already entered correctly, it won't be erased. The login bot will fill in what's missing.


      If there are a few invalid characters after a valid substring of your username/password, only (approximately) those invalid characters will be erased. The login bot will then proceed to fill in the missing characters.





      Coming soon:

      Skull icon fix


      Improve screen rate and responsiveness of the RS client (both regular client and LG)


      Much more
      • 33 replies
  • Recently Browsing   0 members

    No registered users viewing this page.

×