Add flick helper to player bar (#3882)

Allows the player to toggle the prayer flick location between the Quick Prayer Orb, Prayer Bar or Both.
This commit is contained in:
forsco
2018-07-31 18:52:52 +10:00
committed by Tomas Slusny
parent 6d99d3abcb
commit 0c3380c500
5 changed files with 113 additions and 56 deletions

View File

@@ -34,7 +34,6 @@ import net.runelite.api.Client;
import net.runelite.api.Perspective; import net.runelite.api.Perspective;
import net.runelite.api.Player; import net.runelite.api.Player;
import net.runelite.api.Point; import net.runelite.api.Point;
import net.runelite.api.Prayer;
import net.runelite.api.Skill; import net.runelite.api.Skill;
import net.runelite.api.coords.LocalPoint; import net.runelite.api.coords.LocalPoint;
import net.runelite.client.ui.overlay.Overlay; import net.runelite.client.ui.overlay.Overlay;
@@ -51,13 +50,16 @@ class PrayerBarOverlay extends Overlay
private final Client client; private final Client client;
private final PrayerConfig config; private final PrayerConfig config;
private final PrayerPlugin plugin;
private boolean showingPrayerBar; private boolean showingPrayerBar;
@Inject @Inject
private PrayerBarOverlay(final Client client, final PrayerConfig config) private PrayerBarOverlay(final Client client, final PrayerConfig config, final PrayerPlugin plugin)
{ {
this.client = client; this.client = client;
this.config = config; this.config = config;
this.plugin = plugin;
setPosition(OverlayPosition.DYNAMIC); setPosition(OverlayPosition.DYNAMIC);
setPriority(OverlayPriority.HIGH); setPriority(OverlayPriority.HIGH);
@@ -90,12 +92,22 @@ class PrayerBarOverlay extends Overlay
graphics.fillRect(barX, barY, barWidth, barHeight); graphics.fillRect(barX, barY, barWidth, barHeight);
graphics.setColor(BAR_FILL_COLOR); graphics.setColor(BAR_FILL_COLOR);
graphics.fillRect(barX, barY, progressFill, barHeight); graphics.fillRect(barX, barY, progressFill, barHeight);
if (plugin.isPrayersActive() && (config.prayerFlickLocation().equals(PrayerFlickLocation.PRAYER_BAR) || config.prayerFlickLocation().equals(PrayerFlickLocation.BOTH)))
{
double t = plugin.getTickProgress();
int xOffset = (int) (-Math.cos(t) * barWidth / 2) + barWidth / 2;
graphics.setColor(Color.black);
graphics.fillRect(barX + xOffset, barY, 1, barHeight);
}
return new Dimension(barWidth, barHeight); return new Dimension(barWidth, barHeight);
} }
void onTick() void onTick()
{ {
final boolean anyPrayerActive = checkIfAnyPrayerIsActive();
final Player localPlayer = client.getLocalPlayer(); final Player localPlayer = client.getLocalPlayer();
showingPrayerBar = true; showingPrayerBar = true;
@@ -105,7 +117,7 @@ class PrayerBarOverlay extends Overlay
return; return;
} }
if (config.hideIfNotPraying() && !anyPrayerActive) if (config.hideIfNotPraying() && !plugin.isPrayersActive())
{ {
showingPrayerBar = false; showingPrayerBar = false;
return; return;
@@ -116,17 +128,4 @@ class PrayerBarOverlay extends Overlay
showingPrayerBar = false; showingPrayerBar = false;
} }
} }
private boolean checkIfAnyPrayerIsActive()
{
for (Prayer pray : Prayer.values())
{
if (client.isPrayerActive(pray))
{
return true;
}
}
return false;
}
} }

View File

@@ -33,13 +33,13 @@ public interface PrayerConfig extends Config
{ {
@ConfigItem( @ConfigItem(
position = 0, position = 0,
keyName = "prayerflick", keyName = "prayerFlickLocation",
name = "Prayer flick helper", name = "Pray flick location",
description = "Enable the prayer flick helper" description = "Choose where to display the prayer flick helper"
) )
default boolean prayerFlickHelper() default PrayerFlickLocation prayerFlickLocation()
{ {
return true; return PrayerFlickLocation.NONE;
} }
@ConfigItem( @ConfigItem(

View File

@@ -0,0 +1,48 @@
/*
* Copyright (c) 2018, Forsco <https://github.com/forsco>
* 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.client.plugins.prayer;
import lombok.Getter;
import lombok.RequiredArgsConstructor;
@Getter
@RequiredArgsConstructor
public enum PrayerFlickLocation
{
NONE("Off"),
PRAYER_ORB("Prayer Orb"),
PRAYER_BAR("Prayer Bar"),
BOTH("Both");
private final String name;
@Override
public String toString()
{
return name;
}
}

View File

@@ -28,11 +28,8 @@ import java.awt.Color;
import java.awt.Dimension; import java.awt.Dimension;
import java.awt.Graphics2D; import java.awt.Graphics2D;
import java.awt.geom.Rectangle2D; import java.awt.geom.Rectangle2D;
import java.time.Duration;
import java.time.Instant;
import javax.inject.Inject; import javax.inject.Inject;
import net.runelite.api.Client; import net.runelite.api.Client;
import net.runelite.api.Prayer;
import net.runelite.api.widgets.Widget; import net.runelite.api.widgets.Widget;
import net.runelite.api.widgets.WidgetInfo; import net.runelite.api.widgets.WidgetInfo;
import net.runelite.client.ui.overlay.Overlay; import net.runelite.client.ui.overlay.Overlay;
@@ -42,27 +39,26 @@ import net.runelite.client.ui.overlay.OverlayPosition;
class PrayerFlickOverlay extends Overlay class PrayerFlickOverlay extends Overlay
{ {
private final Client client; private final Client client;
private boolean prayersActive = false; private final PrayerConfig config;
private Instant startOfLastTick = Instant.now(); private final PrayerPlugin plugin;
@Inject @Inject
private PrayerFlickOverlay(Client client) private PrayerFlickOverlay(Client client, PrayerConfig config, PrayerPlugin plugin)
{ {
setPosition(OverlayPosition.DYNAMIC); setPosition(OverlayPosition.DYNAMIC);
setLayer(OverlayLayer.ABOVE_WIDGETS); setLayer(OverlayLayer.ABOVE_WIDGETS);
this.client = client; this.client = client;
} this.config = config;
this.plugin = plugin;
void onTick()
{
startOfLastTick = Instant.now(); //Reset the tick timer
prayersActive = isAnyPrayerActive(); //Check if prayers are active
} }
@Override @Override
public Dimension render(Graphics2D graphics) public Dimension render(Graphics2D graphics)
{ {
if (!prayersActive) //If there are no prayers active we don't need to be flicking // If there are no prayers active or flick location is set to the prayer bar we don't require the flick helper
if (!plugin.isPrayersActive()
|| config.prayerFlickLocation().equals(PrayerFlickLocation.NONE)
|| config.prayerFlickLocation().equals(PrayerFlickLocation.PRAYER_BAR))
{ {
return null; return null;
} }
@@ -86,12 +82,7 @@ class PrayerFlickOverlay extends Overlay
int orbInnerX = (int) (bounds.getX() + 24);//x pos of the inside of the prayer orb int orbInnerX = (int) (bounds.getX() + 24);//x pos of the inside of the prayer orb
int orbInnerY = (int) (bounds.getY() - 1);//y pos of the inside of the prayer orb int orbInnerY = (int) (bounds.getY() - 1);//y pos of the inside of the prayer orb
long timeSinceLastTick = Duration.between(startOfLastTick, Instant.now()).toMillis(); double t = plugin.getTickProgress();
float tickProgress = timeSinceLastTick / 600f;
tickProgress = Math.min(tickProgress, 1);//Cap to 1, so if a tick continues past the expected 600 we don't move the indicator off the orb
double t = tickProgress * Math.PI;//t on interval [0,pi]
int xOffset = (int) (-Math.cos(t) * orbInnerWidth / 2) + orbInnerWidth / 2; int xOffset = (int) (-Math.cos(t) * orbInnerWidth / 2) + orbInnerWidth / 2;
int indicatorHeight = (int) (Math.sin(t) * orbInnerHeight); int indicatorHeight = (int) (Math.sin(t) * orbInnerHeight);
@@ -103,17 +94,4 @@ class PrayerFlickOverlay extends Overlay
return new Dimension((int) bounds.getWidth(), (int) bounds.getHeight()); return new Dimension((int) bounds.getWidth(), (int) bounds.getHeight());
} }
boolean isAnyPrayerActive()
{
for (Prayer pray : Prayer.values())//Check if any prayers are active
{
if (client.isPrayerActive(pray))
{
return true;
}
}
return false;
}
} }

View File

@@ -27,7 +27,11 @@ package net.runelite.client.plugins.prayer;
import com.google.common.eventbus.Subscribe; import com.google.common.eventbus.Subscribe;
import com.google.inject.Provides; import com.google.inject.Provides;
import java.time.Duration;
import java.time.Instant;
import javax.inject.Inject; import javax.inject.Inject;
import lombok.AccessLevel;
import lombok.Getter;
import net.runelite.api.Client; import net.runelite.api.Client;
import net.runelite.api.InventoryID; import net.runelite.api.InventoryID;
import net.runelite.api.Item; import net.runelite.api.Item;
@@ -52,6 +56,11 @@ public class PrayerPlugin extends Plugin
{ {
private final PrayerCounter[] prayerCounter = new PrayerCounter[PrayerType.values().length]; private final PrayerCounter[] prayerCounter = new PrayerCounter[PrayerType.values().length];
private Instant startOfLastTick = Instant.now();
@Getter(AccessLevel.PACKAGE)
private boolean prayersActive = false;
@Inject @Inject
private Client client; private Client client;
@@ -144,9 +153,11 @@ public class PrayerPlugin extends Plugin
@Subscribe @Subscribe
public void onGameTick(GameTick tick) public void onGameTick(GameTick tick)
{ {
if (config.prayerFlickHelper()) prayersActive = isAnyPrayerActive();
if (!config.prayerFlickLocation().equals(PrayerFlickLocation.NONE))
{ {
flickOverlay.onTick(); startOfLastTick = Instant.now();
} }
if (config.showPrayerDoseIndicator()) if (config.showPrayerDoseIndicator())
@@ -233,6 +244,27 @@ public class PrayerPlugin extends Plugin
return total; return total;
} }
double getTickProgress()
{
long timeSinceLastTick = Duration.between(startOfLastTick, Instant.now()).toMillis();
float tickProgress = (timeSinceLastTick % 600) / 600f;
return tickProgress * Math.PI;
}
private boolean isAnyPrayerActive()
{
for (Prayer pray : Prayer.values())//Check if any prayers are active
{
if (client.isPrayerActive(pray))
{
return true;
}
}
return false;
}
private void removeIndicators() private void removeIndicators()
{ {
infoBoxManager.removeIf(entry -> entry instanceof PrayerCounter); infoBoxManager.removeIf(entry -> entry instanceof PrayerCounter);