mirror of
https://github.com/Zrips/Jobs.git
synced 2024-11-29 22:13:25 +01:00
84 lines
2.1 KiB
Java
84 lines
2.1 KiB
Java
|
package com.gamingmesh.jobs.stuff;
|
||
|
|
||
|
import java.util.HashMap;
|
||
|
import org.bukkit.Chunk;
|
||
|
import org.bukkit.entity.Player;
|
||
|
|
||
|
import com.gamingmesh.jobs.Jobs;
|
||
|
import com.gamingmesh.jobs.container.ExploreChunk;
|
||
|
import com.gamingmesh.jobs.container.ExploreRegion;
|
||
|
import com.gamingmesh.jobs.container.ExploreRespond;
|
||
|
|
||
|
public class Explore {
|
||
|
|
||
|
private HashMap<String, ExploreRegion> worlds = new HashMap<String, ExploreRegion>();
|
||
|
private boolean exploreEnabled = false;
|
||
|
private int playerAmount = 1;
|
||
|
|
||
|
public Explore() {
|
||
|
}
|
||
|
|
||
|
public int getPlayerAmount() {
|
||
|
return this.playerAmount;
|
||
|
}
|
||
|
|
||
|
public void setPlayerAmount(int amount) {
|
||
|
if (this.playerAmount < amount)
|
||
|
this.playerAmount = amount;
|
||
|
}
|
||
|
|
||
|
public boolean isExploreEnabled() {
|
||
|
return this.exploreEnabled;
|
||
|
}
|
||
|
|
||
|
public void setExploreEnabled() {
|
||
|
this.exploreEnabled = true;
|
||
|
Jobs.getJobsDAO().loadExplore();
|
||
|
}
|
||
|
|
||
|
public HashMap<String, ExploreRegion> getWorlds() {
|
||
|
return worlds;
|
||
|
}
|
||
|
|
||
|
public ExploreRespond ChunkRespond(Player player, Chunk chunk) {
|
||
|
return ChunkRespond(player.getName(), chunk.getWorld().getName(), chunk.getX(), chunk.getZ());
|
||
|
}
|
||
|
|
||
|
public ExploreRespond ChunkRespond(String player, String worldName, int x, int z) {
|
||
|
|
||
|
int ChunkX = x;
|
||
|
int ChunkZ = z;
|
||
|
|
||
|
int RegionX = (int) Math.floor(ChunkX / 32D);
|
||
|
int RegionZ = (int) Math.floor(ChunkZ / 32D);
|
||
|
|
||
|
if (!worlds.containsKey(worldName)) {
|
||
|
ExploreChunk eChunk = new ExploreChunk(player, ChunkX, ChunkZ);
|
||
|
ExploreRegion eRegion = new ExploreRegion(RegionX, RegionZ);
|
||
|
eRegion.addChunk(eChunk);
|
||
|
worlds.put(worldName, eRegion);
|
||
|
return new ExploreRespond(eChunk.getCount(), true);
|
||
|
} else {
|
||
|
ExploreRegion eRegion = worlds.get(worldName);
|
||
|
ExploreChunk eChunk = null;
|
||
|
for (ExploreChunk one : eRegion.getChunks()) {
|
||
|
if (one.getX() != ChunkX)
|
||
|
continue;
|
||
|
if (one.getZ() != ChunkZ)
|
||
|
continue;
|
||
|
eChunk = one;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
if (eChunk == null) {
|
||
|
eChunk = new ExploreChunk(player, ChunkX, ChunkZ);
|
||
|
eRegion.addChunk(eChunk);
|
||
|
return new ExploreRespond(eChunk.getCount(), true);
|
||
|
} else {
|
||
|
return eChunk.addPlayer(player);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|