Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 0 additions & 26 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,32 +20,6 @@ If you have any questions, please join our [Discord](https://discord.gg/zaGrfqFE

If you enjoy my open source work and would like to support me, consider buying me a coffee! Your support helps me stay caffeinated and motivated to keep improving and creating awesome projects.

## Quest Helper Integration

The integrated Quest Helper works together with other plugins to give a nice unified experience while questing.

### Not Enough Runes

If you have the [Not Enough Runes](https://runelite.net/plugin-hub/show/not-enough-runes) plugin installed, you can
right-click item requirements and click `Go to NER...` to look that item up in Not Enough Runes.

![Not Enough Runes context menu](./images/not-enough-runes-01.png)

### Shortest Path

If you have the [Shortest Path](https://runelite.net/plugin-hub/show/shortest-path) plugin installed, you can enable the
the "Use 'Shortest Path' plugin" in the Quest Helper config.

![](./images/shortest-path-01.png)

Next time you start a quest, the Shortest Path plugin will help you take the shortest path to the destination.

![Shortest Path path overlay example](./images/shortest-path-02.png)

You can configure what teleportation methods, or the aesthetic of the path in the Shortest Path config.

## Help and discussion

[![Buy Me a Coffee](https://img.shields.io/badge/Buy%20Me%20a%20Coffee-donate-yellow)](https://www.paypal.com/paypalme/MicrobotBE?country.x=BE)


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -74,13 +74,23 @@ public boolean run(AutoCookingConfig config) {
}
}

if (location == null) {
Microbot.showMessage("No suitable cooking location found");
shutdown();
return;
}

getState(config, location);
}

if (Rs2Player.isMoving() || Rs2Player.isAnimating()) return;

switch (state) {
case COOKING:
if (Rs2Bank.isOpen()) {
Rs2Bank.closeBank();
return;
}
if (!cookingItem.hasRequirements()) {
Microbot.showMessage("You do not meet the requirements to cook this item");
shutdown();
Expand Down Expand Up @@ -119,6 +129,8 @@ public boolean run(AutoCookingConfig config) {
state = CookingState.BANKING;
break;
}
state = CookingState.WALKING;
break;
case DROPPING:
Microbot.status = "Dropping " + cookingItem.getBurntItemName();
Rs2Inventory.dropAll(item -> item.getName().equalsIgnoreCase(cookingItem.getBurntItemName()), config.getDropOrder());
Expand All @@ -128,6 +140,7 @@ public boolean run(AutoCookingConfig config) {
case BANKING:
if (location == CookingLocation.ROUGES_DEN) {
NPC npc = Rs2Npc.getBankerNPC();
if (npc == null) return;
boolean isNPCBankOpen = Rs2Bank.openBank(npc);
if (!isNPCBankOpen) return;
} else {
Expand All @@ -138,7 +151,7 @@ public boolean run(AutoCookingConfig config) {
Rs2Bank.depositAll();
Rs2Inventory.waitForInventoryChanges(1800);

if (!hasRawItem(cookingItem)) {
if (!hasRawItemInBank(cookingItem)) {
Microbot.showMessage("No Raw Food Item found in Bank");
shutdown();
return;
Expand Down Expand Up @@ -210,12 +223,13 @@ private boolean isNearCookingLocation(CookingLocation location, int distance) {
}

private boolean hasRawItem(CookingItem cookingItem) {
if (Rs2Bank.isOpen()) {
return Rs2Bank.hasBankItem(cookingItem.getRawItemName(), true);
}
return Rs2Inventory.hasItem(cookingItem.getRawItemName(), true);
}

private boolean hasRawItemInBank(CookingItem cookingItem) {
return Rs2Bank.hasBankItem(cookingItem.getRawItemName(), true);
}

private boolean hasCookedItem(CookingItem cookingItem) {
return Rs2Inventory.hasItem(cookingItem.getCookedItemName(), true);
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,17 @@
import net.runelite.api.GameObject;
import net.runelite.api.Skill;
import net.runelite.api.coords.WorldPoint;
import net.runelite.client.plugins.microbot.util.bank.Rs2Bank;
import net.runelite.api.gameval.ItemID;
import net.runelite.client.plugins.microbot.util.Global;
import net.runelite.client.plugins.microbot.util.bank.Rs2Bank;
import net.runelite.client.plugins.microbot.util.gameobject.Rs2GameObject;
import net.runelite.client.plugins.microbot.util.inventory.Rs2Gembag;
import net.runelite.client.plugins.microbot.util.inventory.Rs2Inventory;
import net.runelite.client.plugins.microbot.util.inventory.Rs2ItemModel;
import net.runelite.client.plugins.microbot.util.player.Rs2Player;
import net.runelite.client.plugins.microbot.util.walker.Rs2Walker;
import net.runelite.client.plugins.microbot.Microbot;
import net.runelite.client.plugins.microbot.util.security.Login;

import javax.inject.Inject;

Expand All @@ -30,24 +36,85 @@ public void thieve() {
}
}

if (Rs2Player.hopIfPlayerDetected(1, 0, 2)) {
return;
}

final GameObject stall = Rs2GameObject.getGameObject(STALL_ID, SAFESPOT, 2);
if (stall == null) {
boolean started = Microbot.hopToWorld(Login.getRandomWorld(Rs2Player.isMember()));
if (started) {
Global.sleepUntil(Microbot::isLoggedIn, 15000);
}
return;
}

if (!Rs2GameObject.hasAction(Rs2GameObject.convertToObjectComposition(stall), "Steal-from")) {
boolean started = Microbot.hopToWorld(Login.getRandomWorld(Rs2Player.isMember()));
if (started) {
Global.sleepUntil(Microbot::isLoggedIn, 15000);
}
return;
}

Rs2GameObject.interact(stall, "Steal-from");
Rs2Player.waitForXpDrop(Skill.THIEVING);

if (Rs2Gembag.hasGemBag()) {
if (Rs2Gembag.isUnknown()) {
Rs2Gembag.checkGemBag();
}
if (!isGemBagCompletelyFull()) {
if (Rs2Inventory.hasItem(ItemID.GEM_BAG)) {
Rs2Inventory.interact(ItemID.GEM_BAG, "Open");
Global.sleepUntil(Rs2Gembag::isGemBagOpen, 2000);
}
if (Rs2Gembag.isGemBagOpen() && hasAnyUncutGemInInventory()) {
Rs2Inventory.interact(ItemID.GEM_BAG_OPEN, "Fill");
}
}
}
}

@Override
public void bank() {
Rs2Bank.walkToBankAndUseBank();
Rs2Bank.depositAll();
if (!Rs2Bank.isOpen()) return;

Rs2Bank.depositAll(ItemID.UNCUT_SAPPHIRE);
Rs2Bank.depositAll(ItemID.UNCUT_EMERALD);
Rs2Bank.depositAll(ItemID.UNCUT_RUBY);
Rs2Bank.depositAll(ItemID.UNCUT_DIAMOND);

Rs2Bank.emptyGemBag();

Rs2Bank.depositAllExcept(ItemID.GEM_BAG, ItemID.GEM_BAG_OPEN);
Rs2Bank.closeBank();
}

@Override
public Integer[] getItemIdsToDrop() {
return new Integer[0];
}

private boolean hasAnyUncutGemInInventory() {
return Rs2Inventory.items(this::isUncutGem).findAny().isPresent();
}

private boolean isUncutGem(Rs2ItemModel item) {
int id = item.getId();
return id == ItemID.UNCUT_SAPPHIRE ||
id == ItemID.UNCUT_EMERALD ||
id == ItemID.UNCUT_RUBY ||
id == ItemID.UNCUT_DIAMOND;
}

private boolean isGemBagCompletelyFull() {
if (Rs2Gembag.isUnknown()) return false;
int sapphire = Rs2Gembag.getGemBagContents().stream().filter(i -> i.getId() == ItemID.UNCUT_SAPPHIRE).findFirst().map(Rs2ItemModel::getQuantity).orElse(0);
int emerald = Rs2Gembag.getGemBagContents().stream().filter(i -> i.getId() == ItemID.UNCUT_EMERALD).findFirst().map(Rs2ItemModel::getQuantity).orElse(0);
int ruby = Rs2Gembag.getGemBagContents().stream().filter(i -> i.getId() == ItemID.UNCUT_RUBY).findFirst().map(Rs2ItemModel::getQuantity).orElse(0);
int diamond = Rs2Gembag.getGemBagContents().stream().filter(i -> i.getId() == ItemID.UNCUT_DIAMOND).findFirst().map(Rs2ItemModel::getQuantity).orElse(0);
return sapphire >= 60 && emerald >= 60 && ruby >= 60 && diamond >= 60;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
import net.runelite.api.events.ItemContainerChanged;
import net.runelite.api.gameval.ItemID;
import net.runelite.api.gameval.VarbitID;
import net.runelite.api.gameval.InterfaceID;
import net.runelite.api.widgets.ComponentID;
import net.runelite.api.widgets.Widget;
import net.runelite.client.config.RuneScapeProfileType;
Expand Down Expand Up @@ -2635,11 +2636,11 @@ public static boolean hasWithdrawAsItem() {
return isWithdrawAs(false);
}

private static final int NOTED_TOGGLE_WIDGET = 786458;

public static boolean setWithdrawAs(boolean noted) {
if (isWithdrawAs(noted)) return true;
Rs2Widget.clickWidget(NOTED_TOGGLE_WIDGET);
int target = noted ? InterfaceID.Bankmain.NOTE : InterfaceID.Bankmain.ITEM;
boolean clicked = Rs2Widget.clickWidget(target);
if (!clicked) return false;
return sleepUntil(() -> isWithdrawAs(noted));
}

Expand Down