Jump to content

Trouble Burying Bones


Empires

Recommended Posts

I'm trying to make a basic chicken killer that collects feathers and buries bones. I had it attacking and collecting feathers fine but as soon as I added the bury option/case it breaks completely as it just stands there doing nothing. On top of this the client is also unresponsive forcing me to use task manager to close down the bot. 

 

Any ideas? 

 

Thanks

import org.osbot.rs07.api.Inventory;
import org.osbot.rs07.api.model.Character;
import org.osbot.rs07.api.model.GroundItem;
import org.osbot.rs07.api.model.NPC;
import org.osbot.rs07.api.model.Player;
import org.osbot.rs07.script.Script;
import org.osbot.rs07.script.ScriptManifest;
import java.awt.*;

@ScriptManifest(name = "EmpiresChickenKiller", author = "Empires", version = 1.0, info = "", logo = "") 
public class EmpiresChickenKiller extends Script {


    @Override
    public void onStart() {
        log("Welcome to EmpiresChickenKiller.");
        log("Lets get started...");
    }
    
    private enum State {
     ATTACK, WAIT, BURY
    };
    
    private Inventory playerInventory;
    
    private State getState(){
     if(myPlayer().isMoving() || combat.isFighting() || myPlayer().isUnderAttack())
      return State.WAIT; 
     else if(playerInventory.getEmptySlotCount() > 0)
      return State.ATTACK;
     else
      return State.BURY;
    }


    @Override
    public int onLoop() throws InterruptedException {
     
     switch(getState()) {
     
     case ATTACK:
     GroundItem featherCollect = groundItems.closest("Feather");
     if(featherCollect != null)
      featherCollect.interact("Take");
      sleep(random(500,700));
     
     GroundItem bonesCollect = groundItems.closest("Bones");
     if(bonesCollect != null)
      bonesCollect.interact("Take");
      sleep(random(400,600));
     
     NPC targetChicken = npcs.closest("Chicken");
     if(!targetChicken.isOnScreen())
      camera.toEntity(targetChicken);
     
     if(targetChicken != null && !targetChicken.isUnderAttack() && (targetChicken.getHealth() != 0))
      targetChicken.interact("Attack"); 
      sleep(random(500,800)); 
     break;


     case WAIT:
      sleep(random(300,500));
      break;
     
     case BURY:
     playerInventory.dropAllExcept("Feathers", "Bones");

     while(playerInventory.contains("Bones"))
      playerInventory.interact("Bury", "Bones");
      sleep(random(200,310)); 


     break;


     }
     
     return 100;

    }
    
    @Override
    public void onExit() {
        log("Thanks for using my script!");
    }

    @Override
    public void onPaint(Graphics2D g) {
        //This is where you will put your code for paint(s)
    }


}
Link to comment
Share on other sites

Thanks for reply,

 

would you be able to hint me on how to do that? I tried using playerInventory.initializeModule() at the start of my onLoop() and it compiled but still crashed. Am I doing that right?

 

sorry for basic bitch question, first time scripting ://

 

What a nice guy :)

playerInventoy = getInventoy();
Link to comment
Share on other sites

It really is not horrible. No need for elitist remarks.

Yes, it is horrible. The script will fail to run properly and/or crash so frequently that it wouldn't even be worth running. I could waste my time listing out everything that's wrong with this script if I wanted to. My comment has nothing to do with myself, it's about letting him know that he needs to improve if he wants to write a script that won't crash or spam click random rs entities.

Edited by Flamo
Link to comment
Share on other sites

Yes, it is horrible. The script will fail to run properly and/or crash so frequently that it wouldn't even be worth running. I could list out everything that's wrong with this script, it's not about being an Elitist, it's about letting him know that he needs to improve if he wants to write a fully functional script.

chill. well it is my first time writing one so its obviously gonna be a bit meh, but I did just ask you why it sucks so if you can list stuff can you let me know what about it that makes it bad?

Link to comment
Share on other sites

Yes, it is horrible. The script will fail to run properly and/or crash so frequently that it wouldn't even be worth running. I could waste my time listing out everything that's wrong with this script if I wanted to. My comment has nothing to do with myself, it's about letting him know that he needs to improve if he wants to write a script that won't crash or spam click random rs entities.

 

XxMLGxX scripter tell us what he should add to his chicken killer.

Link to comment
Share on other sites

chill. well it is my first time writing one so its obviously gonna be a bit meh, but I did just ask you why it sucks so if you can list stuff can you let me know what about it that makes it bad?

Yeah, I'd love to give you a explanation as to why your code is bad.

https://www.teamspeak.com/downloads

Install teamspeak, join "elitescripts.org" and poke me "Danny" in the java channel. I'm not going to waste my time writing a longwinded post that you won't understand when I could speak to you and clear things up in a fraction of the time.

Edited by Flamo
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
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.

  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...