map mode
This commit is contained in:
parent
94464aec3d
commit
02fbc22ce4
6 changed files with 81 additions and 7 deletions
1
README.md
Normal file
1
README.md
Normal file
|
@ -0,0 +1 @@
|
|||
[![Open in Gitpod](https://gitpod.io/button/open-in-gitpod.svg)](https://gitpod.io/#https://github.com/Minecon724/RealWeather)
|
2
pom.xml
2
pom.xml
|
@ -2,7 +2,7 @@
|
|||
<modelVersion>4.0.0</modelVersion>
|
||||
<groupId>pl.minecon724</groupId>
|
||||
<artifactId>realweather</artifactId>
|
||||
<version>0.1.1</version>
|
||||
<version>0.2.0</version>
|
||||
|
||||
<properties>
|
||||
<maven.compiler.source>17</maven.compiler.source>
|
||||
|
|
|
@ -29,13 +29,19 @@ public class GetStateTask extends BukkitRunnable {
|
|||
WebServiceClient client;
|
||||
boolean broadcast;
|
||||
boolean debug, debugDox;
|
||||
double scaleLat, scaleLon;
|
||||
int onExceed;
|
||||
|
||||
MapUtils mapUtils = new MapUtils();
|
||||
|
||||
public GetStateTask(
|
||||
Provider provider, String source,
|
||||
double pointLatitude, double pointLongitude,
|
||||
List<String> worlds, Logger logger,
|
||||
WebServiceClient client, boolean broadcast,
|
||||
boolean debug, boolean debugDox
|
||||
boolean debug, boolean debugDox,
|
||||
double scaleLat, double scaleLon,
|
||||
int onExceed
|
||||
) {
|
||||
this.provider = provider;
|
||||
this.source = source;
|
||||
|
@ -47,6 +53,9 @@ public class GetStateTask extends BukkitRunnable {
|
|||
this.broadcast = broadcast;
|
||||
this.debug = debug;
|
||||
this.debugDox = debugDox;
|
||||
this.scaleLat = scaleLat;
|
||||
this.scaleLon = scaleLon;
|
||||
this.onExceed = onExceed;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -76,7 +85,7 @@ public class GetStateTask extends BukkitRunnable {
|
|||
location = city.getLocation();
|
||||
lat = location.getLatitude();
|
||||
lon = location.getLongitude();
|
||||
if (debugDox) logger.info( String.format( "%s's location is %f, %f", p.getName(), lat, lon ));
|
||||
if (debugDox) logger.info( String.format( "%s's real location is %f, %f", p.getName(), lat, lon ));
|
||||
state = provider.request_state(lat, lon);
|
||||
if (debug) logger.info( String.format(
|
||||
"Provider returned state %s %s for %s", state.condition.name(), state.level.name(), p.getName()
|
||||
|
@ -90,6 +99,23 @@ public class GetStateTask extends BukkitRunnable {
|
|||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
} else if (source.equals("map")) {
|
||||
double[] coords;
|
||||
double lat, lon;
|
||||
State state;
|
||||
for (Player p : Bukkit.getOnlinePlayers()) {
|
||||
coords = mapUtils.playerPosAsCoords(p.getLocation(), scaleLat, scaleLon, onExceed);
|
||||
lon = coords[0];
|
||||
lat = coords[1];
|
||||
logger.info( String.format( "%s's location is %f, %f", p.getName(), lat, lon ));
|
||||
state = provider.request_state(lat, lon);
|
||||
if (debug) logger.info( String.format(
|
||||
"Provider returned state %s %s for %f, %f", state.condition.name(), state.level.name(), lat, lon
|
||||
));
|
||||
if (broadcast) p.sendMessage( String.format("%s %s in %f, %f",
|
||||
state.level.name(), state.condition.name(), lat, lon
|
||||
) );
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
23
src/main/java/pl/minecon724/realweather/MapUtils.java
Normal file
23
src/main/java/pl/minecon724/realweather/MapUtils.java
Normal file
|
@ -0,0 +1,23 @@
|
|||
package pl.minecon724.realweather;
|
||||
|
||||
import org.bukkit.Location;
|
||||
|
||||
public class MapUtils {
|
||||
double wrapDouble(double min, double max, double val) {
|
||||
return min + (val - min) % (max - min);
|
||||
}
|
||||
|
||||
public double[] playerPosAsCoords(Location loc, double scaleLat, double scaleLon, int onExceed) {
|
||||
double[] out = new double[2];
|
||||
out[0] = loc.getX() * scaleLon;
|
||||
out[1] = loc.getZ() * scaleLat;
|
||||
if (onExceed == 1) {
|
||||
out[0] = Math.max(-180.0, Math.min(180.0, out[0]));
|
||||
out[1] = Math.max(-90.0, Math.min(90.0, out[1]));
|
||||
} else if (onExceed == 2) {
|
||||
out[0] = wrapDouble(-180.0, 180.0, out[0]);
|
||||
out[1] = wrapDouble(-90.0, 90.0, out[1]);
|
||||
}
|
||||
return out;
|
||||
}
|
||||
}
|
|
@ -13,6 +13,7 @@ import pl.minecon724.realweather.provider.OpenWeatherMapProvider;
|
|||
|
||||
public class RW extends JavaPlugin {
|
||||
FileConfiguration config;
|
||||
|
||||
WebServiceClient client = null;
|
||||
|
||||
@Override
|
||||
|
@ -29,6 +30,7 @@ public class RW extends JavaPlugin {
|
|||
String source = weatherSec.getString("source");
|
||||
ConfigurationSection point = weatherSec.getConfigurationSection("point");
|
||||
ConfigurationSection player = weatherSec.getConfigurationSection("player");
|
||||
ConfigurationSection map = weatherSec.getConfigurationSection("map");
|
||||
|
||||
double pointLatitude = point.getDouble("latitude");
|
||||
double pointLongitude = point.getDouble("longitude");
|
||||
|
@ -57,12 +59,17 @@ public class RW extends JavaPlugin {
|
|||
client = new WebServiceClient.Builder(accId, license).host("geolite.info").build();
|
||||
}
|
||||
|
||||
double scale_lat = map.getDouble("scale_lat");
|
||||
double scale_lon = map.getDouble("scale_lon");
|
||||
int on_exceed = map.getInt("on_exceed");
|
||||
|
||||
boolean broadcast = settingsSec.getBoolean("broadcast");
|
||||
boolean debug = settingsSec.getBoolean("debug");
|
||||
boolean debugDox = settingsSec.getBoolean("debugDox");
|
||||
|
||||
new GetStateTask(
|
||||
provider, source, pointLatitude, pointLongitude, worlds, this.getLogger(), client, broadcast, debug, debugDox
|
||||
provider, source, pointLatitude, pointLongitude, worlds, this.getLogger(),
|
||||
client, broadcast, debug, debugDox, scale_lat, scale_lon, on_exceed
|
||||
).runTaskTimerAsynchronously(this,
|
||||
settingsSec.getLong("timeBeforeInitialRun"),
|
||||
settingsSec.getLong("timeBetweenRecheck")
|
||||
|
|
|
@ -5,8 +5,9 @@ weather:
|
|||
- world
|
||||
- second_world
|
||||
- third_world
|
||||
# "point" for a static location
|
||||
# "player" for using the player's location
|
||||
# "point" - static location
|
||||
# "player" - player's location (fake weather)
|
||||
# "map" - world resembles a real-world globe
|
||||
source: point
|
||||
point:
|
||||
latitude: 41.84201
|
||||
|
@ -14,6 +15,22 @@ weather:
|
|||
player:
|
||||
geolite2_accountId: 710438
|
||||
geolite2_apiKey: 'qLeseHp4QNQcqRGn'
|
||||
map:
|
||||
# Man I've really suffered while working on this one (i hate maths)
|
||||
# Info:
|
||||
# Valid latitude range: -90 to 90
|
||||
# Valid longitude range: -180 to 180
|
||||
# 1 degree of latitude and longitude is about 111 km
|
||||
# The defaults here assume 1 block = ~1 km
|
||||
# Latitude scale, 1 block = <scale> degrees
|
||||
scale_lat: 0.009
|
||||
# Longitude scale, 1 block = <scale> degrees
|
||||
scale_lon: 0.009
|
||||
# What to do if player exceeds the range specified above
|
||||
# 1 - do nothing (clamp to nearest allowed value)
|
||||
# 2 - wrap the number
|
||||
# for example; if the calculated player's latitude is 94 degrees (bad), it'll be converted to -86 degrees (good)
|
||||
on_exceed: 2
|
||||
|
||||
provider:
|
||||
# Your provider choice
|
||||
|
|
Loading…
Reference in a new issue