entityhider: add blacklist for hiding dead npcs. (#2231)
This commit is contained in:
@@ -1596,6 +1596,14 @@ public interface Client extends GameShell
|
|||||||
*/
|
*/
|
||||||
void setDeadNPCsHidden(boolean state);
|
void setDeadNPCsHidden(boolean state);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The provided ids will not be hidden when the
|
||||||
|
* entity-hider attempts to hide dead {@link NPC}'s.
|
||||||
|
*
|
||||||
|
* @param blacklist set of npc ids.
|
||||||
|
*/
|
||||||
|
void setBlacklistDeadNpcs(Set<Integer> blacklist);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets an array of tile collision data.
|
* Gets an array of tile collision data.
|
||||||
* <p>
|
* <p>
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ public class Text
|
|||||||
{
|
{
|
||||||
private static final StringBuilder SB = new StringBuilder(64);
|
private static final StringBuilder SB = new StringBuilder(64);
|
||||||
|
|
||||||
private static final Splitter COMMA_SPLITTER = Splitter
|
public static final Splitter COMMA_SPLITTER = Splitter
|
||||||
.on(",")
|
.on(",")
|
||||||
.omitEmptyStrings()
|
.omitEmptyStrings()
|
||||||
.trimResults();
|
.trimResults();
|
||||||
|
|||||||
@@ -235,10 +235,24 @@ public interface EntityHiderConfig extends Config
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ConfigItem(
|
@ConfigItem(
|
||||||
position = 18,
|
position = 18,
|
||||||
keyName = "hidePets",
|
keyName = "blacklistDeadNpcs",
|
||||||
name = "Hide Pets",
|
name = "Hide on Death Blacklist",
|
||||||
description = "Configures whether or not other player pets are hidden"
|
description = "Configures which NPCs NOT to hide when they die",
|
||||||
|
titleSection = "npcsTitle",
|
||||||
|
hidden = true,
|
||||||
|
unhide = "hideDeadNPCs"
|
||||||
|
)
|
||||||
|
default String blacklistDeadNpcs()
|
||||||
|
{
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
@ConfigItem(
|
||||||
|
position = 19,
|
||||||
|
keyName = "hidePets",
|
||||||
|
name = "Hide Pets",
|
||||||
|
description = "Configures whether or not other player pets are hidden"
|
||||||
)
|
)
|
||||||
default boolean hidePets()
|
default boolean hidePets()
|
||||||
{
|
{
|
||||||
@@ -249,7 +263,7 @@ public interface EntityHiderConfig extends Config
|
|||||||
keyName = "miscTitle",
|
keyName = "miscTitle",
|
||||||
name = "Miscellaneous",
|
name = "Miscellaneous",
|
||||||
description = "",
|
description = "",
|
||||||
position = 19
|
position = 20
|
||||||
)
|
)
|
||||||
default Title miscTitle()
|
default Title miscTitle()
|
||||||
{
|
{
|
||||||
@@ -257,7 +271,7 @@ public interface EntityHiderConfig extends Config
|
|||||||
}
|
}
|
||||||
|
|
||||||
@ConfigItem(
|
@ConfigItem(
|
||||||
position = 20,
|
position = 21,
|
||||||
keyName = "hideProjectiles",
|
keyName = "hideProjectiles",
|
||||||
name = "Hide Projectiles",
|
name = "Hide Projectiles",
|
||||||
description = "Configures whether or not projectiles are hidden",
|
description = "Configures whether or not projectiles are hidden",
|
||||||
|
|||||||
@@ -28,7 +28,9 @@ package net.runelite.client.plugins.entityhider;
|
|||||||
|
|
||||||
import com.google.inject.Provides;
|
import com.google.inject.Provides;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.stream.Collectors;
|
import java.util.stream.Collectors;
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
@@ -83,6 +85,22 @@ public class EntityHiderPlugin extends Plugin
|
|||||||
{
|
{
|
||||||
updateConfig();
|
updateConfig();
|
||||||
|
|
||||||
|
final Set<Integer> blacklist = new HashSet<>();
|
||||||
|
|
||||||
|
for (String s : Text.COMMA_SPLITTER.split(config.blacklistDeadNpcs()))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
blacklist.add(Integer.parseInt(s));
|
||||||
|
}
|
||||||
|
catch (NumberFormatException ignored)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
client.setBlacklistDeadNpcs(blacklist);
|
||||||
|
|
||||||
if (event.getOldValue() == null || event.getNewValue() == null)
|
if (event.getOldValue() == null || event.getNewValue() == null)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
|
|||||||
@@ -27,7 +27,9 @@ package net.runelite.mixins;
|
|||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import net.runelite.api.mixins.Inject;
|
import net.runelite.api.mixins.Inject;
|
||||||
import net.runelite.api.mixins.Mixin;
|
import net.runelite.api.mixins.Mixin;
|
||||||
import net.runelite.rs.api.RSClient;
|
import net.runelite.rs.api.RSClient;
|
||||||
@@ -83,6 +85,9 @@ public abstract class EntityHiderBridgeMixin implements RSClient
|
|||||||
@Inject
|
@Inject
|
||||||
public static List<String> hideSpecificPlayers = new ArrayList<>();
|
public static List<String> hideSpecificPlayers = new ArrayList<>();
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
public static Set<Integer> blacklistDeadNpcs = new HashSet<>();
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
@Override
|
@Override
|
||||||
public void setIsHidingEntities(boolean state)
|
public void setIsHidingEntities(boolean state)
|
||||||
@@ -225,6 +230,13 @@ public abstract class EntityHiderBridgeMixin implements RSClient
|
|||||||
hideSpecificPlayers = players;
|
hideSpecificPlayers = players;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
@Override
|
||||||
|
public void setBlacklistDeadNpcs(Set<Integer> blacklist)
|
||||||
|
{
|
||||||
|
blacklistDeadNpcs = blacklist;
|
||||||
|
}
|
||||||
|
|
||||||
@Inject
|
@Inject
|
||||||
@Override
|
@Override
|
||||||
public void setPetsHidden(boolean state)
|
public void setPetsHidden(boolean state)
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ package net.runelite.mixins;
|
|||||||
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Set;
|
||||||
import net.runelite.api.mixins.Copy;
|
import net.runelite.api.mixins.Copy;
|
||||||
import net.runelite.api.mixins.Inject;
|
import net.runelite.api.mixins.Inject;
|
||||||
import net.runelite.api.mixins.Mixin;
|
import net.runelite.api.mixins.Mixin;
|
||||||
@@ -80,6 +81,9 @@ public abstract class EntityHiderMixin implements RSScene
|
|||||||
@Shadow("hideSpecificPlayers")
|
@Shadow("hideSpecificPlayers")
|
||||||
private static List<String> hideSpecificPlayers;
|
private static List<String> hideSpecificPlayers;
|
||||||
|
|
||||||
|
@Shadow("blacklistDeadNpcs")
|
||||||
|
private static Set<Integer> blacklistDeadNpcs;
|
||||||
|
|
||||||
@Shadow("hideNPCs2D")
|
@Shadow("hideNPCs2D")
|
||||||
private static boolean hideNPCs2D;
|
private static boolean hideNPCs2D;
|
||||||
|
|
||||||
@@ -199,7 +203,7 @@ public abstract class EntityHiderMixin implements RSScene
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hideDeadNPCs && npc.getHealthRatio() == 0)
|
if (hideDeadNPCs && npc.getHealthRatio() == 0 && !blacklistDeadNpcs.contains(npc.getId()))
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user