diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/data/MayorElectionData.kt | 13 | ||||
-rw-r--r-- | src/main/java/at/hannibal2/skyhanni/features/garden/GardenCropMilestoneDisplay.kt | 34 |
2 files changed, 33 insertions, 14 deletions
diff --git a/src/main/java/at/hannibal2/skyhanni/data/MayorElectionData.kt b/src/main/java/at/hannibal2/skyhanni/data/MayorElectionData.kt index 634958217..70f30a021 100644 --- a/src/main/java/at/hannibal2/skyhanni/data/MayorElectionData.kt +++ b/src/main/java/at/hannibal2/skyhanni/data/MayorElectionData.kt @@ -53,9 +53,14 @@ class MayorElectionData { SkyHanniMod.coroutineScope.launch { val url = "https://api.hypixel.net/resources/skyblock/election" val jsonObject = withContext(Dispatchers.IO) { APIUtil.getJSONResponse(url) } - rawMayorData = gson.fromJson(jsonObject, MayorData::class.java).also { - candidates = mapOf(it.mayor.election.getPairs(), it.current.getPairs()) + rawMayorData = gson.fromJson(jsonObject, MayorData::class.java) + val data = rawMayorData ?: return@launch + val map = mutableMapOf<Int, Candidate>() + map put data.mayor.election.getPairs() + data.current?.let { + map put data.current.getPairs() } + candidates = map } } @@ -79,4 +84,8 @@ class MayorElectionData { private fun MayorData.Election.getPairs() = year + 1 to candidates.bestCandidate() private fun List<MayorData.Candidate>.bestCandidate() = maxBy { it.votes } + + private infix fun <K, V> MutableMap<K, V>.put(pairs: Pair<K, V>) { + this[pairs.first] = pairs.second + } }
\ No newline at end of file diff --git a/src/main/java/at/hannibal2/skyhanni/features/garden/GardenCropMilestoneDisplay.kt b/src/main/java/at/hannibal2/skyhanni/features/garden/GardenCropMilestoneDisplay.kt index b53627699..4be321a0f 100644 --- a/src/main/java/at/hannibal2/skyhanni/features/garden/GardenCropMilestoneDisplay.kt +++ b/src/main/java/at/hannibal2/skyhanni/features/garden/GardenCropMilestoneDisplay.kt @@ -128,14 +128,7 @@ class GardenCropMilestoneDisplay { val crop = item.getCropType() ?: return if (cultivatingData.containsKey(crop)) { val old = cultivatingData[crop]!! -// val finneganPerkFactor = if (finneganPerkActive() && Random.nextDouble() <= 0.25) 0.5 else 1.0 -// val finneganPerkFactor = if (finneganPerkActive()) 0.8 else 1.0 - - // 1/(1 + 0.25*2) - val multiplier = 0.6666 - val finneganPerkFactor = if (finneganPerkActive()) multiplier else 1.0 - val addedCounter = ((counter - old) * finneganPerkFactor).toInt() - println("addedCounter: $addedCounter") + val addedCounter = counter - old if (GardenCropMilestones.cropCounter.isEmpty()) { for (innerCrop in CropType.values()) { @@ -147,8 +140,9 @@ class GardenCropMilestoneDisplay { cropType.setSpeed(-1) } } - - crop.setCounter(crop.getCounter() + addedCounter) + if (!finneganPerkActive()) { + crop.setCounter(crop.getCounter() + addedCounter) + } EliteFarmingWeight.addCrop(crop, addedCounter) if (currentCrop == crop) { calculateSpeed(addedCounter) @@ -162,8 +156,14 @@ class GardenCropMilestoneDisplay { } } - private fun finneganPerkActive() = - config.forcefullyEnabledAlwaysFinnegan || MayorElectionData.isPerkActive("Finnegan", "Farming Simulator") + private fun finneganPerkActive(): Boolean { + val forcefullyEnabledAlwaysFinnegan = config.forcefullyEnabledAlwaysFinnegan + val perkActive = MayorElectionData.isPerkActive("Finnegan", "Farming Simulator") + MayorElectionData.currentCandidate?.let { + + } + return forcefullyEnabledAlwaysFinnegan || perkActive + } @SubscribeEvent fun onBlockClick(event: BlockClickEvent) { @@ -209,6 +209,10 @@ class GardenCropMilestoneDisplay { } private fun checkSpeed() { + if (finneganPerkActive()) { + currentSpeed = (currentSpeed.toDouble() * 0.8).toInt() + } + if (countInLastSecond > 8) { allCounters.add(currentSpeed) while (allCounters.size > 30) { @@ -217,6 +221,12 @@ class GardenCropMilestoneDisplay { averageSpeedPerSecond = allCounters.average().toInt() } countInLastSecond = 0 + + if (finneganPerkActive()) { + currentCrop?.let { + it.setCounter(it.getCounter() + currentSpeed) + } + } currentSpeed = 0 lastBlocksPerSecond = blocksBroken |