mirror of
https://github.com/BentoBoxWorld/Level.git
synced 2025-01-14 20:31:46 +01:00
Implement sumTeamDeaths, maxDeaths and deathPenalty.
Improved calculating death penalty. Death count now checks if it must include teamDeaths. maxDeaths now is working, as deathHandicap will be set to minimal value from it and current deathCount. Change level and pointsToNextLevel calculation. Now it will remove deathCount * deathPenalty points from rawBlockCount and use new value to calculate current level and points till next one.
This commit is contained in:
parent
4a73534570
commit
e7cc3c7c50
@ -7,6 +7,7 @@ import java.util.HashSet;
|
|||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.ChunkSnapshot;
|
import org.bukkit.ChunkSnapshot;
|
||||||
@ -214,12 +215,38 @@ public class CalcIslandLevel {
|
|||||||
task.cancel();
|
task.cancel();
|
||||||
// Finalize calculations
|
// Finalize calculations
|
||||||
result.rawBlockCount += (long)(result.underWaterBlockCount * addon.getSettings().getUnderWaterMultiplier());
|
result.rawBlockCount += (long)(result.underWaterBlockCount * addon.getSettings().getUnderWaterMultiplier());
|
||||||
|
|
||||||
// Set the death penalty
|
// Set the death penalty
|
||||||
result.deathHandicap = addon.getPlayers().getDeaths(world, island.getOwner());
|
if (this.addon.getSettings().isSumTeamDeaths())
|
||||||
// Set final score
|
{
|
||||||
result.level = (result.rawBlockCount / addon.getSettings().getLevelCost()) - result.deathHandicap - island.getLevelHandicap();
|
for (UUID uuid : this.island.getMemberSet())
|
||||||
|
{
|
||||||
|
this.result.deathHandicap += this.addon.getPlayers().getDeaths(this.world, uuid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.result.deathHandicap =
|
||||||
|
this.addon.getPlayers().getDeaths(this.world, this.island.getOwner());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Just lazy check for min death count.
|
||||||
|
this.result.deathHandicap = Math.min(this.result.deathHandicap, this.addon.getSettings().getMaxDeaths());
|
||||||
|
|
||||||
|
long blockAndDeathPoints = this.result.rawBlockCount;
|
||||||
|
|
||||||
|
if (this.addon.getSettings().getDeathPenalty() > 0)
|
||||||
|
{
|
||||||
|
// Proper death penalty calculation.
|
||||||
|
blockAndDeathPoints -= this.result.deathHandicap * this.addon.getSettings().getDeathPenalty();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.result.level = blockAndDeathPoints / this.addon.getSettings().getLevelCost() - this.island.getLevelHandicap();
|
||||||
|
|
||||||
// Calculate how many points are required to get to the next level
|
// Calculate how many points are required to get to the next level
|
||||||
result.pointsToNextLevel = addon.getSettings().getLevelCost() - (result.rawBlockCount % addon.getSettings().getLevelCost());
|
this.result.pointsToNextLevel = this.addon.getSettings().getLevelCost() -
|
||||||
|
(blockAndDeathPoints % this.addon.getSettings().getLevelCost());
|
||||||
|
|
||||||
// Report
|
// Report
|
||||||
result.report = getReport();
|
result.report = getReport();
|
||||||
// All done.
|
// All done.
|
||||||
|
Loading…
Reference in New Issue
Block a user