Browse Source

players coutn towards Siege Cap at banes for 3 minutes after leaving bane area

lakebane2
FatBoy-DOTC 3 weeks ago
parent
commit
d1aa581879
  1. 42
      src/engine/objects/City.java

42
src/engine/objects/City.java

@ -39,6 +39,7 @@ import java.sql.SQLException; @@ -39,6 +39,7 @@ import java.sql.SQLException;
import java.time.LocalDateTime;
import java.time.ZoneId;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.concurrent.ConcurrentHashMap;
@ -88,6 +89,8 @@ public class City extends AbstractWorldObject { @@ -88,6 +89,8 @@ public class City extends AbstractWorldObject {
private boolean reverseKOS = false;
private String hash;
public HashMap<Integer, Long> baneAttendees;
/**
* ResultSet Constructor
*/
@ -1017,7 +1020,15 @@ public class City extends AbstractWorldObject { @@ -1017,7 +1020,15 @@ public class City extends AbstractWorldObject {
currentMemory.add(player.getObjectUUID());
// Player is already in our memory
if(this.getBane() != null){
//handle zerg mechanics here
if(this.getBane().getSiegePhase().equals(SiegePhase.WAR)){
//bane is live, start tallying players
if(!this.baneAttendees.containsKey(player.getObjectUUID())){
this.baneAttendees.put(player.getObjectUUID(),System.currentTimeMillis());
}
}
}
if (_playerMemory.contains(player.getObjectUUID()))
continue;
@ -1047,11 +1058,25 @@ public class City extends AbstractWorldObject { @@ -1047,11 +1058,25 @@ public class City extends AbstractWorldObject {
}
private void onExitBane(){
ArrayList<Integer> toRemove = new ArrayList<>();
for(int uuid : this.baneAttendees.keySet()){
if(!_playerMemory.contains(uuid)){
if(System.currentTimeMillis() - this.baneAttendees.get(uuid) > 180000){
toRemove.add(uuid);
}
}
}
for(Integer uuid : toRemove){
this.baneAttendees.remove(uuid);
}
}
private void onExit(HashSet<Integer> currentMemory) {
PlayerCharacter player;
int playerUUID = 0;
HashSet<Integer> toRemove = new HashSet<>();
HashSet<Integer> toRemoveStandard = new HashSet<>();
Iterator<Integer> iter = _playerMemory.iterator();
while (iter.hasNext()) {
@ -1073,21 +1098,28 @@ public class City extends AbstractWorldObject { @@ -1073,21 +1098,28 @@ public class City extends AbstractWorldObject {
this.removeAllCityEffects(player, false);
player.ZergMultiplier = 1.0f;
// We will remove this player after iteration is complete
// so store it in a temporary collection
toRemove.add(playerUUID);
toRemoveStandard.add(playerUUID);
// ***For debugging
// Logger.info("PlayerMemory for ", this.getCityName() + ": " + _playerMemory.size());
}
// Remove players from city memory
_playerMemory.removeAll(toRemove);
for (Integer removalUUID : toRemove) {
_playerMemory.removeAll(toRemoveStandard);
for (Integer removalUUID : toRemoveStandard) {
if (this.cityOutlaws.contains(removalUUID))
this.cityOutlaws.remove(removalUUID);
}
if(this.getBane() != null){
//handle zerg mechanics here
if(this.getBane().getSiegePhase().equals(SiegePhase.WAR)){
this.onExitBane();
}
}
}
public int getWarehouseBuildingID() {

Loading…
Cancel
Save