Anti Drag: Hold on Key (#1629)

Added an option for key hold instead of toggle.
Fixed cursor not changing to normal and instead using RS3 Gold as default when toggling off.
This commit is contained in:
LoneVV
2019-09-28 18:46:50 +03:00
committed by Kyle
parent 9258c8eff8
commit 18438626c4
3 changed files with 83 additions and 24 deletions

View File

@@ -42,8 +42,8 @@ public interface AntiDragConfig extends Config
keyName = "alwaysOn",
name = "Always On",
description = "Makes the anti-drag always active and disables the hotkey toggle",
disabledBy = "keybind",
hide = "keybind"
disabledBy = "keybind || holdkeybind",
hide = "keybind || holdkeybind"
)
default boolean alwaysOn()
{
@@ -55,21 +55,34 @@ public interface AntiDragConfig extends Config
keyName = "keybind",
name = "Toggle with Keybind",
description = "Toggle anti drag on and off, rather than always on.",
disabledBy = "alwaysOn",
hide = "alwaysOn"
disabledBy = "alwaysOn || holdkeybind",
hide = "alwaysOn || holdkeybind"
)
default boolean keybind()
{
return false;
}
@ConfigItem(
position = 2,
keyName = "holdkeybind",
name = "Hold with Keybind",
description = "Hold anti drag key to turn it on, rather than toggle it on or off.",
disabledBy = "alwaysOn || keybind",
hide = "alwaysOn || keybind"
)
default boolean holdkeybind()
{
return false;
}
@ConfigItem(
keyName = "key",
name = "Keybind",
description = "The keybind you want to use for antidrag",
position = 2,
position = 3,
hidden = true,
unhide = "keybind"
unhide = "keybind || holdkeybind"
)
default Keybind key()
{
@@ -80,7 +93,7 @@ public interface AntiDragConfig extends Config
keyName = "dragDelay",
name = "Drag Delay",
description = "Configures the inventory drag delay in client ticks (20ms)",
position = 3
position = 4
)
default int dragDelay()
{
@@ -91,9 +104,9 @@ public interface AntiDragConfig extends Config
keyName = "reqfocus",
name = "Reset on focus loss",
description = "Disable antidrag when losing focus (like alt tabbing)",
position = 4,
position = 5,
hidden = true,
unhide = "keybind"
unhide = "keybind || holdkeybind"
)
default boolean reqfocus()
{
@@ -104,9 +117,9 @@ public interface AntiDragConfig extends Config
keyName = "overlay",
name = "Enable overlay",
description = "Do you really need a description?",
position = 5,
position = 6,
hidden = true,
unhide = "keybind"
unhide = "keybind || holdkeybind"
)
default boolean overlay()
{
@@ -119,8 +132,8 @@ public interface AntiDragConfig extends Config
name = "Overlay color",
description = "Change the overlay color, duh",
hidden = true,
unhide = "keybind",
position = 6
unhide = "keybind || holdkeybind",
position = 7
)
default Color color()
{
@@ -131,9 +144,9 @@ public interface AntiDragConfig extends Config
keyName = "changeCursor",
name = "Change Cursor",
description = "Change cursor when you have anti-drag enabled.",
position = 7,
position = 8,
hidden = true,
unhide = "keybind"
unhide = "keybind || holdkeybind"
)
default boolean changeCursor()
{
@@ -145,11 +158,11 @@ public interface AntiDragConfig extends Config
name = "Cursor",
description = "Select which cursor you wish to use",
hidden = true,
unhide = "keybind",
position = 8
unhide = "changeCursor",
position = 9
)
default CustomCursor selectedCursor()
{
return CustomCursor.DRAGON_SCIMITAR;
return CustomCursor.RS3_GOLD;
}
}

View File

@@ -42,7 +42,6 @@ import net.runelite.client.input.KeyManager;
import net.runelite.client.plugins.Plugin;
import net.runelite.client.plugins.PluginDescriptor;
import net.runelite.client.plugins.PluginType;
import net.runelite.client.plugins.customcursor.CustomCursorConfig;
import net.runelite.client.ui.ClientUI;
import net.runelite.client.ui.overlay.OverlayManager;
import net.runelite.client.util.HotkeyListener;
@@ -93,6 +92,7 @@ public class AntiDragPlugin extends Plugin
private boolean alwaysOn;
private boolean keybind;
private boolean holdkeybind;
private Keybind key;
private int dragDelay;
private boolean reqfocus;
@@ -109,7 +109,7 @@ public class AntiDragPlugin extends Plugin
addSubscriptions();
updateConfig();
if (this.keybind)
if (this.keybind || this.holdkeybind)
{
keyManager.registerKeyListener(hotkeyListener);
}
@@ -125,6 +125,7 @@ public class AntiDragPlugin extends Plugin
keyManager.unregisterKeyListener(hotkeyListener);
toggleDrag = false;
overlayManager.remove(overlay);
clientUI.resetCursor();
}
private void addSubscriptions()
@@ -151,6 +152,18 @@ public class AntiDragPlugin extends Plugin
keyManager.unregisterKeyListener(hotkeyListener);
}
}
if
(event.getKey().equals(("holdkeybind")))
{
if (this.holdkeybind)
{
keyManager.registerKeyListener(hotkeyListener);
}
else
{
keyManager.unregisterKeyListener(hotkeyListener);
}
}
if (event.getKey().equals("alwaysOn"))
{
client.setInventoryDragDelay(this.alwaysOn ? this.dragDelay : DEFAULT_DELAY);
@@ -159,6 +172,10 @@ public class AntiDragPlugin extends Plugin
{
client.setInventoryDragDelay(this.dragDelay);
}
if (event.getKey().equals(("changeCursor")))
{
clientUI.resetCursor();
}
}
}
@@ -167,7 +184,7 @@ public class AntiDragPlugin extends Plugin
switch (event.getGameState())
{
case LOGGED_IN:
if (keybind)
if (keybind || holdkeybind)
{
keyManager.registerKeyListener(hotkeyListener);
}
@@ -181,6 +198,7 @@ public class AntiDragPlugin extends Plugin
{
this.alwaysOn = config.alwaysOn();
this.keybind = config.keybind();
this.holdkeybind = config.holdkeybind();
this.key = config.key();
this.dragDelay = config.dragDelay();
this.reqfocus = config.reqfocus();
@@ -227,12 +245,38 @@ public class AntiDragPlugin extends Plugin
{
overlayManager.remove(overlay);
client.setInventoryDragDelay(DEFAULT_DELAY);
clientUI.resetCursor();
}
}
@Override
public void hotkeyReleased()
{
if (alwaysOn)
{
return;
}
toggleDrag = !toggleDrag;
if (toggleDrag)
{
if (configOverlay)
{
overlayManager.add(overlay);
}
if (changeCursor)
{
net.runelite.client.plugins.customcursor.CustomCursor selectedCursor = configManager.getConfig(CustomCursorConfig.class).selectedCursor();
clientUI.setCursor(selectedCursor.getCursorImage(), selectedCursor.toString());
}
client.setInventoryDragDelay(dragDelay);
}
else
{
overlayManager.remove(overlay);
client.setInventoryDragDelay(DEFAULT_DELAY);
clientUI.resetCursor();
}
}
};
}
}

View File

@@ -35,13 +35,15 @@ public enum CustomCursor
RS3_GOLD("RS3 Gold", "cursor-rs3-gold.png"),
RS3_SILVER("RS3 Silver", "cursor-rs3-silver.png"),
DRAGON_DAGGER("Dragon Dagger", "cursor-dragon-dagger.png"),
DRAGON_DAGGER_POISON("Dragon Dagger (p)", "cursor-dragon-dagger-p.png"),
TROUT("Trout", "cursor-trout.png"),
DRAGON_SCIMITAR("Dragon Scimitar", "cursor-dragon-scimitar.png"),
ARMADYL_GODSWORD("Armadyl Godsword", "cursor-armadyl-godsword.png"),
BANDOS_GODSWORD("Bandos Godsword", "cursor-bandos-godsword.png"),
MOUSE("Mouse", "cursor-mouse.png"),
SARADOMIN_GODSWORD("Saradomin Godsword", "cursor-saradomin-godsword.png"),
ZAMORAK_GODSWORD("Zamorak Godsword", "cursor-zamorak-godsword.png");
ZAMORAK_GODSWORD("Zamorak Godsword", "cursor-zamorak-godsword.png"),
SKILL_SPECS("Skill Specs", "cursor-skill-specs.png");
private final String name;