Add npc menu options to MenuManager
This commit is contained in:
@@ -0,0 +1,35 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
package net.runelite.api.events;
|
||||||
|
|
||||||
|
import lombok.Data;
|
||||||
|
import net.runelite.api.NPCComposition;
|
||||||
|
|
||||||
|
@Data
|
||||||
|
public class NpcActionChanged
|
||||||
|
{
|
||||||
|
private NPCComposition npcComposition;
|
||||||
|
private int idx;
|
||||||
|
}
|
||||||
@@ -32,7 +32,9 @@ import com.google.common.eventbus.Subscribe;
|
|||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import javax.inject.Provider;
|
import javax.inject.Provider;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
@@ -40,8 +42,11 @@ import lombok.extern.slf4j.Slf4j;
|
|||||||
import net.runelite.api.Client;
|
import net.runelite.api.Client;
|
||||||
import net.runelite.api.MenuAction;
|
import net.runelite.api.MenuAction;
|
||||||
import net.runelite.api.MenuEntry;
|
import net.runelite.api.MenuEntry;
|
||||||
|
import net.runelite.api.NPC;
|
||||||
|
import net.runelite.api.NPCComposition;
|
||||||
import net.runelite.api.events.MenuEntryAdded;
|
import net.runelite.api.events.MenuEntryAdded;
|
||||||
import net.runelite.api.events.MenuOptionClicked;
|
import net.runelite.api.events.MenuOptionClicked;
|
||||||
|
import net.runelite.api.events.NpcActionChanged;
|
||||||
import net.runelite.api.events.PlayerMenuOptionClicked;
|
import net.runelite.api.events.PlayerMenuOptionClicked;
|
||||||
import net.runelite.api.events.PlayerMenuOptionsChanged;
|
import net.runelite.api.events.PlayerMenuOptionsChanged;
|
||||||
import net.runelite.api.events.WidgetMenuOptionClicked;
|
import net.runelite.api.events.WidgetMenuOptionClicked;
|
||||||
@@ -64,6 +69,7 @@ public class MenuManager
|
|||||||
private final Map<Integer, String> playerMenuIndexMap = new HashMap<>();
|
private final Map<Integer, String> playerMenuIndexMap = new HashMap<>();
|
||||||
//Used to manage custom non-player menu options
|
//Used to manage custom non-player menu options
|
||||||
private final Multimap<Integer, WidgetMenuOption> managedMenuOptions = HashMultimap.create();
|
private final Multimap<Integer, WidgetMenuOption> managedMenuOptions = HashMultimap.create();
|
||||||
|
private final Set<String> npcMenuOptions = new HashSet<>();
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
public MenuManager(Provider<Client> clientProvider, EventBus eventBus)
|
public MenuManager(Provider<Client> clientProvider, EventBus eventBus)
|
||||||
@@ -72,6 +78,32 @@ public class MenuManager
|
|||||||
this.eventBus = eventBus;
|
this.eventBus = eventBus;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void addNpcMenuOption(String option)
|
||||||
|
{
|
||||||
|
npcMenuOptions.add(option);
|
||||||
|
|
||||||
|
// add to surrounding npcs
|
||||||
|
Client client = clientProvider.get();
|
||||||
|
for (NPC npc : client.getNpcs())
|
||||||
|
{
|
||||||
|
NPCComposition composition = npc.getComposition();
|
||||||
|
addNpcOption(composition, option);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void removeNpcMenuOption(String option)
|
||||||
|
{
|
||||||
|
npcMenuOptions.remove(npcMenuOptions);
|
||||||
|
|
||||||
|
// remove this option from all npc compositions
|
||||||
|
Client client = clientProvider.get();
|
||||||
|
for (NPC npc : client.getNpcs())
|
||||||
|
{
|
||||||
|
NPCComposition composition = npc.getComposition();
|
||||||
|
removeNpcOption(composition, option);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds a CustomMenuOption to the list of managed menu options.
|
* Adds a CustomMenuOption to the list of managed menu options.
|
||||||
*
|
*
|
||||||
@@ -186,6 +218,56 @@ public class MenuManager
|
|||||||
addPlayerMenuItem(newIdx, menuText);
|
addPlayerMenuItem(newIdx, menuText);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Subscribe
|
||||||
|
public void onNpcActionChanged(NpcActionChanged event)
|
||||||
|
{
|
||||||
|
NPCComposition composition = event.getNpcComposition();
|
||||||
|
for (String npcOption : npcMenuOptions)
|
||||||
|
{
|
||||||
|
addNpcOption(composition, npcOption);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void addNpcOption(NPCComposition composition, String npcOption)
|
||||||
|
{
|
||||||
|
String[] actions = composition.getActions();
|
||||||
|
int unused = -1;
|
||||||
|
for (int i = 0; i < actions.length; ++i)
|
||||||
|
{
|
||||||
|
if (actions[i] == null && unused == -1)
|
||||||
|
{
|
||||||
|
unused = i;
|
||||||
|
}
|
||||||
|
else if (actions[i] != null && actions[i].equals(npcOption))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (unused == -1)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
actions[unused] = npcOption;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void removeNpcOption(NPCComposition composition, String npcOption)
|
||||||
|
{
|
||||||
|
String[] actions = composition.getActions();
|
||||||
|
|
||||||
|
if (composition.getActions() == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (int i = 0; i < actions.length; ++i)
|
||||||
|
{
|
||||||
|
if (actions[i] != null && actions[i].equals(npcOption))
|
||||||
|
{
|
||||||
|
actions[i] = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Subscribe
|
@Subscribe
|
||||||
public void onMenuOptionClicked(MenuOptionClicked event)
|
public void onMenuOptionClicked(MenuOptionClicked event)
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -0,0 +1,46 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2018, Adam <Adam@sigterm.info>
|
||||||
|
* All rights reserved.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions are met:
|
||||||
|
*
|
||||||
|
* 1. Redistributions of source code must retain the above copyright notice, this
|
||||||
|
* list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
* this list of conditions and the following disclaimer in the documentation
|
||||||
|
* and/or other materials provided with the distribution.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||||
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||||
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||||
|
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||||
|
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||||
|
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||||
|
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||||
|
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
|
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||||
|
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
package net.runelite.mixins;
|
||||||
|
|
||||||
|
import net.runelite.api.events.NpcActionChanged;
|
||||||
|
import net.runelite.api.mixins.FieldHook;
|
||||||
|
import net.runelite.api.mixins.Inject;
|
||||||
|
import net.runelite.api.mixins.Mixin;
|
||||||
|
import static net.runelite.client.callback.Hooks.eventBus;
|
||||||
|
import net.runelite.rs.api.RSNPCComposition;
|
||||||
|
|
||||||
|
@Mixin(RSNPCComposition.class)
|
||||||
|
public abstract class RSNpcCompositionMixin implements RSNPCComposition
|
||||||
|
{
|
||||||
|
@FieldHook("actions")
|
||||||
|
@Inject
|
||||||
|
public void actionsHook(int idx)
|
||||||
|
{
|
||||||
|
NpcActionChanged npcActionChanged = new NpcActionChanged();
|
||||||
|
npcActionChanged.setNpcComposition(this);
|
||||||
|
npcActionChanged.setIdx(idx);
|
||||||
|
eventBus.post(npcActionChanged);
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user