Jump to content
Search In
  • More options...
Find results that contain...
Find results in...
Sign in to follow this  
Baal Zebub

Help whit walkback

Recommended Posts

Hello 

 

i am new to scripting and just do it for a hobby, and i made a function that i tought that would work but just usses too much CPU that freezes the client.

basicly i just whanted to make the function walk back a already made path. and if needed check the area of the player.

if some one could tell me why this can't be ussed and what would be a better approach to it, i would appreciate it :)

 

my code:

	public void walkback(RSTile[] path,RSArea area, boolean checkarea){
		if(checkarea== false){
			Walking.invertPath(Walking.randomizePath(path, 2, 2));
			while(Player.isMoving()){
				println("Player is moving");
				sleep(750);}
		}else{
		while(inArea(area)!=true && checkarea == true ){
		println("walkBackTo");
		RSTile[] back = Walking.randomizePath(path, 2, 2);
			Walking.invertPath(back);
			while(Player.isMoving()){
				println("Player is moving");
				sleep(750);
			
			}
		}
		}
	}
	public boolean inArea(RSArea a){
		println("inArea()");
		if(a!= null ){
			if( a.contains(Player.getRSPlayer().getPosition())){
				println("Yes it is in Area"+Player.getRSPlayer().getPosition());
				return true;
			}else {
				println("Nop, it is not in Area"+Player.getRSPlayer().getPosition());
				return false;
			}}else{
		  return false;}
		
	}

Thanks ^^

Baal Zebub:cool:

"The Lord Of The Flies" 

Edited by Baal Zebub

Share this post


Link to post
Share on other sites

You need to invert the path and walk through it.
There are walking methods with a stopping condition. You can use that to check if you've reached the destination area.

https://tribot.org/doc/org/tribot/api2007/Walking.html#walkScreenPath-org.tribot.api.interfaces.Positionable:A-org.tribot.api.types.generic.Condition-long-

https://tribot.org/doc/org/tribot/api2007/Walking.html#walkPath-org.tribot.api.interfaces.Positionable:A-org.tribot.api.types.generic.Condition-long-

You can also use antiban to dynamically decide which one to use:

RSTile[] invertedPath = Walking.invertPath(path);
Condition stopCondition = null;
if (checkarea)
      stopCondition = new Condition() {
          public boolean active() {
               General.sleep(time to sleep in ms);
               return area.contains(Player.getPosition());
          }
      };
WalkingPreference walkPref = AntiBan.generateWalkingPreference(distance);    invertedPath.length should be a decent distance estimative
if (walkPref == WalkingPreference.MINIMAP)
     Walking.walkPath(invertedPath, stopCondition, General.random(min time to check condition in ms, max time to check condition in ms));
else 
     Walking.walkScreenPath(invertedPath, stopCondition, General.random(same as above, same as above));


 

  • Like 1

Share this post


Link to post
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
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  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.

Sign in to follow this  

  • Our picks

    • This release will:

      Fix prayers and world hopper API (Thanks @JoeDezzy1 and @erickho123)


      Improve banking API (Thanks @Encoded)


      Adds methods for returning and using Java Lists, rather than arrays


      Slightly randomizes some hardcoded behaviour


      Removes sleeps from waitConditions; the efficiency saving potential is negligible in these use-cases, therefore cleaner code is preferable


      Other back-end improvements





      Note: If you are using LG, please restart both the RS client and TRiBot.
        • Sad
        • Haha
        • Thanks
        • Like
      • 64 replies
    • This release will:

      Add new internal framework for capturing exceptions


      Fix issue with not selecting the last column in world hopper (Thanks @Todd)


      Add a message about pin usage in Banking#openBank (Thanks @Todd)


      Disable the firewall by default (Thanks @Todd)


      Fix handling of the welcome screen after login (Thanks @Encoded)


      Fix wrong amount bank withdrawal (Thanks @Encoded)


      Fix Screen#isInViewport


      Fix Game#isInViewport (Thanks @Encoded)


      Call onBreakEnd for ListenerManager Breaking Listeners (Thanks @Encoded)


      Fix Prayer#getPrayerPoints NumberFormatException (Thanks @JoeDezzy1)



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

      Fix LG for both OSBuddy and RuneLite


      Fix issue where the resizable client isn't able to be made smaller (Thanks @JoeDezzy1)


      Fix detection of the logout game tab when resizable mode and side panels are enabled (Thanks @JoeDezzy1)


      Add initial support for Sentry to allow us to identify and easily debug exceptions happening with all TRiBot users


      Add methods to determine if the bank is actually loaded, and not just the overarching interface (Thanks @wastedbro)



      Upcoming updates:

      Improved CLI support


      Full Sentry support


      Much more
        • Like
      • 64 replies
    • This release will:

      Fix NPE in Camera API (Thanks @wastedbro)


      Update deposit box interface ids (Thanks @Encoded)


      Add various bank methods (Thanks @wastedbro)


      Banking#getWithdrawXQuantity


      Banking#getDefaultWithdrawQuantity


      Banking#arePlaceholdersOn




      Fix resizeable minimap bug (Thanks @wastedbro)


      Remove Java 8 requirement


      Please note: TRiBot is not yet fully compatible with Java 10+




      Fix the break handler issues by ensuring the break handler thread never gets paused


      Fix broken settings hooks



      Upcoming updates:

      Improved CLI support


      Much more



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

      Add support for using custom F key bindings to switch between game tabs (Thanks @erickho123)


      Fix tab opening for "Skills" and "Kourend Tasks" (Thanks @erickho123)



      Note: If you are using LG, please restart both the RS client and TRiBot
        • Like
      • 34 replies
  • Recently Browsing   0 members

    No registered users viewing this page.

×
×
  • Create New...