aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/main/java/at/hannibal2/skyhanni/config/features/MiscConfig.java4
-rw-r--r--src/main/java/at/hannibal2/skyhanni/data/PatcherCoordinatesClass.kt5
-rw-r--r--src/main/java/at/hannibal2/skyhanni/features/misc/PatcherSendCoordinatesHighlight.kt46
3 files changed, 26 insertions, 29 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/config/features/MiscConfig.java b/src/main/java/at/hannibal2/skyhanni/config/features/MiscConfig.java
index a630f3c7f..b40821da0 100644
--- a/src/main/java/at/hannibal2/skyhanni/config/features/MiscConfig.java
+++ b/src/main/java/at/hannibal2/skyhanni/config/features/MiscConfig.java
@@ -661,9 +661,9 @@ public class MiscConfig {
public boolean restorePieceOfWizardPortalLore = true;
@Expose
- @ConfigOption(name = "Patcher Coords Highlight", desc = "Highlight the the coords sended form patcher.")
+ @ConfigOption(name = "Patcher Coords Waypoint", desc = "Highlight the the coords sended form patcher.")
@ConfigEditorBoolean
- public boolean patcherSendCoordHighlight = false;
+ public boolean patcherSendCoordWaypoint = false;
@Expose
@ConfigOption(name = "Config Button", desc = "Add a button to the pause menu to configure SkyHanni.")
diff --git a/src/main/java/at/hannibal2/skyhanni/data/PatcherCoordinatesClass.kt b/src/main/java/at/hannibal2/skyhanni/data/PatcherCoordinatesClass.kt
new file mode 100644
index 000000000..d90600df8
--- /dev/null
+++ b/src/main/java/at/hannibal2/skyhanni/data/PatcherCoordinatesClass.kt
@@ -0,0 +1,5 @@
+package at.hannibal2.skyhanni.data
+
+import at.hannibal2.skyhanni.utils.LorenzVec
+
+data class PatcherBeacon(val location: LorenzVec, val name: String, val time: Long) \ No newline at end of file
diff --git a/src/main/java/at/hannibal2/skyhanni/features/misc/PatcherSendCoordinatesHighlight.kt b/src/main/java/at/hannibal2/skyhanni/features/misc/PatcherSendCoordinatesHighlight.kt
index b9ac03626..5e82e51f2 100644
--- a/src/main/java/at/hannibal2/skyhanni/features/misc/PatcherSendCoordinatesHighlight.kt
+++ b/src/main/java/at/hannibal2/skyhanni/features/misc/PatcherSendCoordinatesHighlight.kt
@@ -1,8 +1,11 @@
package at.hannibal2.skyhanni.features.misc
import at.hannibal2.skyhanni.SkyHanniMod
+import at.hannibal2.skyhanni.data.PatcherBeacon
import at.hannibal2.skyhanni.events.LorenzChatEvent
+import at.hannibal2.skyhanni.events.LorenzTickEvent
import at.hannibal2.skyhanni.test.GriffinUtils.drawWaypointFilled
+import at.hannibal2.skyhanni.utils.LocationUtils
import at.hannibal2.skyhanni.utils.LorenzColor
import at.hannibal2.skyhanni.utils.LorenzLogger
import at.hannibal2.skyhanni.utils.LorenzVec
@@ -10,23 +13,21 @@ import at.hannibal2.skyhanni.utils.RenderUtils.drawColor
import at.hannibal2.skyhanni.utils.RenderUtils.drawString
import at.hannibal2.skyhanni.utils.StringUtils.matchMatcher
import at.hannibal2.skyhanni.utils.StringUtils.removeColor
-import at.hannibal2.skyhanni.utils.getLorenzVec
import net.minecraftforge.client.event.RenderWorldLastEvent
import net.minecraftforge.event.world.WorldEvent
import net.minecraftforge.fml.common.eventhandler.EventPriority
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent
-import net.minecraftforge.fml.common.gameevent.TickEvent
class PatcherSendCoordinatesHighlight {
- private val patcherBeacon = mutableListOf<LorenzVec>()
- private val patcherName = mutableListOf<String>()
+ private val patcherBeacon = mutableListOf<PatcherBeacon>()
private val logger = LorenzLogger("misc/patchercoords")
private val pattern = "(?<playerName>.*): x: (?<x>.*), y: (?<y>.*), z: (?<z>.*)".toPattern()
+
@SubscribeEvent
fun onPatcherCoordinates(event: LorenzChatEvent) {
- if (!SkyHanniMod.feature.misc.patcherSendCoordHighlight) return
+ if (!SkyHanniMod.feature.misc.patcherSendCoordWaypoint) return
val message = event.message.removeColor()
pattern.matchMatcher(message) {
@@ -34,47 +35,38 @@ class PatcherSendCoordinatesHighlight {
val x = group("x").toInt()
val y = group("y").toInt()
val z = group("z").toInt()
-
- patcherBeacon.add(LorenzVec(x, y, z))
- patcherName.add(playerName)
+ patcherBeacon.add(PatcherBeacon(LorenzVec(x, y, z), playerName, System.currentTimeMillis() / 1000))
logger.log("got patcher coords and username")
}
}
@SubscribeEvent(priority = EventPriority.HIGH)
fun onWorldRender(event: RenderWorldLastEvent) {
- if (!SkyHanniMod.feature.misc.patcherSendCoordHighlight) return
+ if (!SkyHanniMod.feature.misc.patcherSendCoordWaypoint) return
- for (i in 0 until patcherBeacon.size) {
- val location = patcherBeacon[i]
+ for (beacon in patcherBeacon) {
+ val location = beacon.location
event.drawColor(location, LorenzColor.DARK_GREEN, alpha = 1f)
event.drawWaypointFilled(location, LorenzColor.GREEN.toColor(), true, true)
- event.drawString(location.add(0.5, 0.5, 0.5), patcherName[i], true, LorenzColor.DARK_BLUE.toColor())
- logger.log("added patcher beacon!")
+ event.drawString(location.add(0.5, 0.5, 0.5), beacon.name, true, LorenzColor.DARK_BLUE.toColor())
}
}
@SubscribeEvent
- fun onEnterWaypoint(event: TickEvent.PlayerTickEvent) {
- if (!SkyHanniMod.feature.misc.patcherSendCoordHighlight) return
+ fun onEnterWaypoint(event: LorenzTickEvent) {
+ if (!event.isMod(10)) return
- val player = event.player
- if (player.motionX > 0 || player.motionZ > 0) {
- val location = player.getLorenzVec()
- for (i in 0 until patcherBeacon.size) {
- if (location.distanceIgnoreY(patcherBeacon[i]) < 5) {
- patcherBeacon.removeAt(i)
- patcherName.removeAt(i)
- logger.log("removed patcher beacon!")
- }
- }
- }
+ val location = LocationUtils.playerLocation()
+ // removed patcher beacon!
+ patcherBeacon.removeIf { System.currentTimeMillis() / 1000 > it.time + 5 && location.distanceIgnoreY(it.location) < 5 }
+
+ // removed patcher beacon after time!
+ patcherBeacon.removeIf { System.currentTimeMillis() / 1000 > it.time + 60 }
}
@SubscribeEvent
fun onWorldChange(event: WorldEvent.Load) {
patcherBeacon.clear()
- patcherName.clear()
logger.log("Reset everything (world change)")
}
} \ No newline at end of file