Changes the way quest updates are made

Removes the per-trait update-rate
Adds a task timer to update the marker for any NPC moving around
Sets the marker update delay to 5 minutes
Skips all quest marker updates, unless a quest has changed
This commit is contained in:
Kristian Knarvik 2022-11-02 01:51:51 +01:00
parent 4555331988
commit 935a6ce662
8 changed files with 22 additions and 90 deletions

View File

@ -19,7 +19,6 @@ import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.logging.Level; import java.util.logging.Level;
@SuppressWarnings("unused") @SuppressWarnings("unused")
@ -54,24 +53,17 @@ public final class DynmapCitizens extends JavaPlugin {
handlers.add(new MinstrelHandler()); handlers.add(new MinstrelHandler());
for (CitizensTraitHandler handler : handlers) { for (CitizensTraitHandler handler : handlers) {
handler.initialize(); handler.initialize();
handler.updateMarkers();
} }
//Schedule handlers to run periodically //Schedule handlers to run periodically
AtomicInteger elapsedSeconds = new AtomicInteger();
elapsedSeconds.set(240);
Bukkit.getScheduler().runTaskTimer(this, () -> { Bukkit.getScheduler().runTaskTimer(this, () -> {
for (CitizensTraitHandler handler : handlers) { for (CitizensTraitHandler handler : handlers) {
if (handler.isEnabled() && elapsedSeconds.get() % handler.getUpdateRate().getEveryNSeconds() == 0) { if (handler.isEnabled()) {
handler.updateMarkers(); handler.updateMarkers();
} }
} }
elapsedSeconds.addAndGet(5); }, 10 * 20, 300 * 20);
if (elapsedSeconds.get() > 3600) {
elapsedSeconds.set(240);
}
//TODO: It would probably make more sense to have individual timers for each marker based on whether the
// NPC is likely to move about.
}, 5 * 20, 5 * 20);
vaultHandler = new VaultHandler(this.getServer().getServicesManager()); vaultHandler = new VaultHandler(this.getServer().getServicesManager());
} }

View File

@ -3,6 +3,7 @@ package net.knarcraft.dynmapcitizens.handler.trait;
import net.citizensnpcs.api.CitizensAPI; import net.citizensnpcs.api.CitizensAPI;
import net.citizensnpcs.api.npc.NPC; import net.citizensnpcs.api.npc.NPC;
import net.knarcraft.dynmapcitizens.DynmapCitizens; import net.knarcraft.dynmapcitizens.DynmapCitizens;
import org.bukkit.Bukkit;
import org.bukkit.Location; import org.bukkit.Location;
import org.bukkit.World; import org.bukkit.World;
import org.dynmap.DynmapAPI; import org.dynmap.DynmapAPI;
@ -70,11 +71,20 @@ public abstract class AbstractTraitHandler implements CitizensTraitHandler {
return; return;
} }
Marker marker = markerSet.createMarker(null, markerName + npc.getName(), npcLocation.getWorld().getName(), Marker marker = markerSet.createMarker(npcId.toString(), markerName + npc.getName(),
npcLocation.getX(), npcLocation.getY(), npcLocation.getZ(), icon, false); npcLocation.getWorld().getName(), npcLocation.getX(), npcLocation.getY(), npcLocation.getZ(), icon,
false);
if (marker != null) { if (marker != null) {
marker.setDescription(markerDescription); marker.setDescription(markerDescription);
} }
//For NPCs that move around, update their marker's location every n seconds
if (marker != null && isMoving(npc)) {
Bukkit.getScheduler().scheduleSyncRepeatingTask(DynmapCitizens.getInstance(),
() -> marker.setLocation(npcLocation.getWorld().getName(), npc.getStoredLocation().getX(),
npc.getStoredLocation().getY(), npc.getStoredLocation().getZ()), 20, 10 * 20);
//TODO: Make the update rate configurable
}
} }
/** /**

View File

@ -8,7 +8,6 @@ import net.knarcraft.blacksmith.config.NPCSettings;
import net.knarcraft.blacksmith.trait.BlacksmithTrait; import net.knarcraft.blacksmith.trait.BlacksmithTrait;
import net.knarcraft.dynmapcitizens.DynmapCitizens; import net.knarcraft.dynmapcitizens.DynmapCitizens;
import net.knarcraft.dynmapcitizens.property.Icon; import net.knarcraft.dynmapcitizens.property.Icon;
import net.knarcraft.dynmapcitizens.property.UpdateRate;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Material; import org.bukkit.Material;
import org.dynmap.DynmapAPI; import org.dynmap.DynmapAPI;
@ -42,11 +41,6 @@ public class BlacksmithHandler extends AbstractTraitHandler {
isEnabled = false; isEnabled = false;
} }
@Override
public UpdateRate getUpdateRate() {
return UpdateRate.VERY_SLOW;
}
@Override @Override
public void updateMarkers() { public void updateMarkers() {
//Remove existing markers //Remove existing markers

View File

@ -1,7 +1,5 @@
package net.knarcraft.dynmapcitizens.handler.trait; package net.knarcraft.dynmapcitizens.handler.trait;
import net.knarcraft.dynmapcitizens.property.UpdateRate;
/** /**
* A handler which takes care of everything for one citizen trait * A handler which takes care of everything for one citizen trait
*/ */
@ -12,13 +10,6 @@ public interface CitizensTraitHandler {
*/ */
void initialize(); void initialize();
/**
* Gets the update rate used for this handler
*
* @return <p>The update rate for this handler</p>
*/
UpdateRate getUpdateRate();
/** /**
* Gets whether this handler was properly initialized and enabled * Gets whether this handler was properly initialized and enabled
* *

View File

@ -5,7 +5,6 @@ import net.citizensnpcs.api.npc.NPC;
import net.citizensnpcs.api.trait.Trait; import net.citizensnpcs.api.trait.Trait;
import net.knarcraft.dynmapcitizens.DynmapCitizens; import net.knarcraft.dynmapcitizens.DynmapCitizens;
import net.knarcraft.dynmapcitizens.property.Icon; import net.knarcraft.dynmapcitizens.property.Icon;
import net.knarcraft.dynmapcitizens.property.UpdateRate;
import net.knarcraft.minstrel.MinstrelPlugin; import net.knarcraft.minstrel.MinstrelPlugin;
import net.knarcraft.minstrel.music.Song; import net.knarcraft.minstrel.music.Song;
import net.knarcraft.minstrel.trait.MinstrelTrait; import net.knarcraft.minstrel.trait.MinstrelTrait;
@ -39,11 +38,6 @@ public class MinstrelHandler extends AbstractTraitHandler {
isEnabled = false; isEnabled = false;
} }
@Override
public UpdateRate getUpdateRate() {
return UpdateRate.VERY_SLOW;
}
@Override @Override
public void updateMarkers() { public void updateMarkers() {
//Remove existing markers //Remove existing markers

View File

@ -5,7 +5,6 @@ import net.citizensnpcs.api.npc.NPC;
import net.citizensnpcs.api.trait.Trait; import net.citizensnpcs.api.trait.Trait;
import net.knarcraft.dynmapcitizens.DynmapCitizens; import net.knarcraft.dynmapcitizens.DynmapCitizens;
import net.knarcraft.dynmapcitizens.property.Icon; import net.knarcraft.dynmapcitizens.property.Icon;
import net.knarcraft.dynmapcitizens.property.UpdateRate;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.dynmap.DynmapAPI; import org.dynmap.DynmapAPI;
import org.dynmap.markers.GenericMarker; import org.dynmap.markers.GenericMarker;
@ -36,11 +35,6 @@ public class SentinelHandler extends AbstractTraitHandler {
isEnabled = false; isEnabled = false;
} }
@Override
public UpdateRate getUpdateRate() {
return UpdateRate.FAST;
}
@Override @Override
public void updateMarkers() { public void updateMarkers() {
sentinelSet.getMarkers().forEach(GenericMarker::deleteMarker); sentinelSet.getMarkers().forEach(GenericMarker::deleteMarker);

View File

@ -8,7 +8,6 @@ import net.citizensnpcs.api.npc.NPCRegistry;
import net.knarcraft.dynmapcitizens.DynmapCitizens; import net.knarcraft.dynmapcitizens.DynmapCitizens;
import net.knarcraft.dynmapcitizens.handler.trait.AbstractTraitHandler; import net.knarcraft.dynmapcitizens.handler.trait.AbstractTraitHandler;
import net.knarcraft.dynmapcitizens.property.Icon; import net.knarcraft.dynmapcitizens.property.Icon;
import net.knarcraft.dynmapcitizens.property.UpdateRate;
import net.knarcraft.dynmapcitizens.util.QuestsHelper; import net.knarcraft.dynmapcitizens.util.QuestsHelper;
import org.bukkit.Bukkit; import org.bukkit.Bukkit;
import org.bukkit.Location; import org.bukkit.Location;
@ -59,11 +58,6 @@ public class QuestsHandler extends AbstractTraitHandler {
isEnabled = false; isEnabled = false;
} }
@Override
public UpdateRate getUpdateRate() {
return UpdateRate.VERY_SLOW;
}
@Override @Override
public void updateMarkers() { public void updateMarkers() {
if (questsAPI.isLoading()) { if (questsAPI.isLoading()) {
@ -79,14 +73,15 @@ public class QuestsHandler extends AbstractTraitHandler {
//Updates all quest area markers //Updates all quest area markers
if (questsChanged) { if (questsChanged) {
//Update all area markers for quests
updateQuestAreas(); updateQuestAreas();
//Generate information about all NPCs involved in quests
generateQuestNPCInfo();
//Generate markers based on the generated info
generateAllMarkers();
} }
//Generate information about all NPCs involved in quests
generateQuestNPCInfo();
//Generate markers based on the generated info
generateAllMarkers();
} }
/** /**

View File

@ -1,38 +0,0 @@
package net.knarcraft.dynmapcitizens.property;
/**
* An update rate for a group of icons
*/
public enum UpdateRate {
/**
* This is run quite often, to display movement
*/
FAST(5),
/**
* This is run rarely, as change isn't expected
*/
VERY_SLOW(120);
private final int everyNSeconds;
/**
* Instantiates a new update rate
*
* @param everyNSeconds <p>The number of seconds to wait between each run</p>
*/
UpdateRate(int everyNSeconds) {
this.everyNSeconds = everyNSeconds;
}
/**
* Gets the number of seconds between each time an update should be performed
*
* @return <p>The N in every N seconds</p>
*/
public int getEveryNSeconds() {
return everyNSeconds;
}
}