2015-12-28 20:55:59 +01:00
|
|
|
package ru.gelin.android.weather.notification;
|
|
|
|
|
|
|
|
import android.os.Bundle;
|
|
|
|
import android.os.Parcel;
|
|
|
|
import android.os.Parcelable;
|
|
|
|
|
|
|
|
import org.slf4j.Logger;
|
|
|
|
import org.slf4j.LoggerFactory;
|
|
|
|
|
|
|
|
public class ParcelableWeather2 implements Parcelable {
|
|
|
|
private static final Logger LOG = LoggerFactory.getLogger(ParcelableWeather2.class);
|
|
|
|
|
|
|
|
// getters and setters suck ;)
|
|
|
|
|
|
|
|
public long time = 0;
|
|
|
|
public long queryTime = 0;
|
|
|
|
public int version = 0;
|
|
|
|
public String location = "";
|
|
|
|
public int currentTemp = 0;
|
2015-12-29 22:10:38 +01:00
|
|
|
public String currentCondition = "";
|
2015-12-28 20:55:59 +01:00
|
|
|
|
2016-01-03 18:28:32 +01:00
|
|
|
String[] currentConditionType = null;
|
|
|
|
public int currentConditionCode = 3200;
|
|
|
|
String[] forecastConditionType = null;
|
|
|
|
public int forecastConditionCode = 3200;
|
2016-12-30 19:58:56 +01:00
|
|
|
public int todayLowTemp = 0;
|
|
|
|
public int todayHighTemp = 0;
|
|
|
|
public int forecastLowTemp = 0;
|
|
|
|
public int forecastHighTemp = 0;
|
2016-01-03 18:28:32 +01:00
|
|
|
|
|
|
|
|
2015-12-28 20:55:59 +01:00
|
|
|
private ParcelableWeather2(Parcel in) {
|
|
|
|
int version = in.readInt();
|
|
|
|
if (version != 2) {
|
|
|
|
return;
|
|
|
|
}
|
2015-12-29 22:10:38 +01:00
|
|
|
Bundle bundle = in.readBundle();
|
2016-12-30 19:58:56 +01:00
|
|
|
|
2015-12-28 20:55:59 +01:00
|
|
|
location = bundle.getString("weather_location");
|
|
|
|
time = bundle.getLong("weather_time");
|
|
|
|
queryTime = bundle.getLong("weather_query_time");
|
|
|
|
bundle.getString("weather_forecast_url");
|
|
|
|
int conditions = bundle.getInt("weather_conditions");
|
|
|
|
if (conditions > 0) {
|
2015-12-29 22:10:38 +01:00
|
|
|
Bundle conditionBundle = in.readBundle();
|
|
|
|
currentCondition = conditionBundle.getString("weather_condition_text");
|
2015-12-28 20:55:59 +01:00
|
|
|
conditionBundle.getStringArray("weather_condition_types");
|
|
|
|
currentTemp = conditionBundle.getInt("weather_current_temp");
|
2016-01-03 18:28:32 +01:00
|
|
|
|
|
|
|
currentConditionType = conditionBundle.getStringArray("weather_condition_types");
|
|
|
|
currentConditionCode = weatherConditionTypesToOpenWeatherMapIds(currentConditionType[0]);
|
2016-12-30 19:58:56 +01:00
|
|
|
todayLowTemp = conditionBundle.getInt("weather_low_temp");
|
|
|
|
todayHighTemp = conditionBundle.getInt("weather_high_temp");
|
2016-01-03 18:28:32 +01:00
|
|
|
//fetch immediate next forecast
|
|
|
|
if (--conditions > 0) {
|
|
|
|
Bundle forecastBundle = in.readBundle();
|
|
|
|
forecastConditionType = forecastBundle.getStringArray("weather_condition_types");
|
2016-01-05 16:03:59 +01:00
|
|
|
forecastConditionCode = weatherConditionTypesToOpenWeatherMapIds(forecastConditionType[0]);
|
2016-12-30 19:58:56 +01:00
|
|
|
forecastLowTemp = forecastBundle.getInt("weather_low_temp");
|
|
|
|
forecastHighTemp = forecastBundle.getInt("weather_high_temp");
|
2016-01-03 18:28:32 +01:00
|
|
|
}
|
2015-12-29 22:10:38 +01:00
|
|
|
}
|
|
|
|
// get the rest
|
2016-01-03 18:28:32 +01:00
|
|
|
while (--conditions > 0) {
|
2015-12-29 22:10:38 +01:00
|
|
|
Bundle conditionBundle = in.readBundle();
|
|
|
|
conditionBundle.getString("weather_condition_text");
|
|
|
|
conditionBundle.getStringArray("weather_condition_types");
|
|
|
|
conditionBundle.getInt("weather_current_temp");
|
2015-12-28 20:55:59 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static final Creator<ParcelableWeather2> CREATOR = new Creator<ParcelableWeather2>() {
|
|
|
|
@Override
|
|
|
|
public ParcelableWeather2 createFromParcel(Parcel in) {
|
|
|
|
return new ParcelableWeather2(in);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public ParcelableWeather2[] newArray(int size) {
|
|
|
|
return new ParcelableWeather2[size];
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int describeContents() {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void writeToParcel(Parcel dest, int flags) {
|
|
|
|
// we do not really want to use this at all
|
|
|
|
}
|
2016-01-03 18:28:32 +01:00
|
|
|
|
|
|
|
private int weatherConditionTypesToOpenWeatherMapIds(String weather_condition_type) {
|
|
|
|
switch (weather_condition_type) {
|
|
|
|
case "THUNDERSTORM_RAIN_LIGHT":
|
|
|
|
return 200;
|
|
|
|
case "THUNDERSTORM_RAIN":
|
|
|
|
return 201;
|
|
|
|
case "THUNDERSTORM_RAIN_HEAVY":
|
|
|
|
return 202;
|
|
|
|
case "THUNDERSTORM_LIGHT":
|
|
|
|
return 210;
|
|
|
|
case "THUNDERSTORM":
|
|
|
|
return 211;
|
|
|
|
case "THUNDERSTORM_HEAVY":
|
|
|
|
return 212;
|
|
|
|
case "THUNDERSTORM_RAGGED":
|
|
|
|
return 221;
|
|
|
|
case "THUNDERSTORM_DRIZZLE_LIGHT":
|
|
|
|
return 230;
|
|
|
|
case "THUNDERSTORM_DRIZZLE":
|
|
|
|
return 231;
|
|
|
|
case "THUNDERSTORM_DRIZZLE_HEAVY":
|
|
|
|
return 232;
|
|
|
|
|
|
|
|
case "DRIZZLE_LIGHT":
|
|
|
|
return 300;
|
|
|
|
case "DRIZZLE":
|
|
|
|
return 301;
|
|
|
|
case "DRIZZLE_HEAVY":
|
|
|
|
return 302;
|
|
|
|
case "DRIZZLE_RAIN_LIGHT":
|
|
|
|
return 310;
|
|
|
|
case "DRIZZLE_RAIN":
|
|
|
|
return 311;
|
|
|
|
case "DRIZZLE_RAIN_HEAVY":
|
|
|
|
return 312;
|
|
|
|
case "DRIZZLE_SHOWER":
|
|
|
|
return 321;
|
|
|
|
|
|
|
|
case "RAIN_LIGHT":
|
|
|
|
return 500;
|
|
|
|
case "RAIN":
|
|
|
|
return 501;
|
|
|
|
case "RAIN_HEAVY":
|
|
|
|
return 502;
|
|
|
|
case "RAIN_VERY_HEAVY":
|
|
|
|
return 503;
|
|
|
|
case "RAIN_EXTREME":
|
|
|
|
return 504;
|
|
|
|
case "RAIN_FREEZING":
|
|
|
|
return 511;
|
|
|
|
case "RAIN_SHOWER_LIGHT":
|
|
|
|
return 520;
|
|
|
|
case "RAIN_SHOWER":
|
|
|
|
return 521;
|
|
|
|
case "RAIN_SHOWER_HEAVY":
|
|
|
|
return 522;
|
|
|
|
|
|
|
|
case "SNOW_LIGHT":
|
|
|
|
return 600;
|
|
|
|
case "SNOW":
|
|
|
|
return 601;
|
|
|
|
case "SNOW_HEAVY":
|
|
|
|
return 602;
|
|
|
|
case "SLEET":
|
|
|
|
return 611;
|
|
|
|
case "SNOW_SHOWER":
|
|
|
|
return 621;
|
|
|
|
|
|
|
|
case "MIST":
|
|
|
|
return 701;
|
|
|
|
case "SMOKE":
|
|
|
|
return 711;
|
|
|
|
case "HAZE":
|
|
|
|
return 721;
|
|
|
|
case "SAND_WHIRLS":
|
|
|
|
return 731;
|
|
|
|
case "FOG":
|
|
|
|
return 741;
|
|
|
|
|
|
|
|
case "CLOUDS_CLEAR":
|
|
|
|
return 800;
|
|
|
|
case "CLOUDS_FEW":
|
|
|
|
return 801;
|
|
|
|
case "CLOUDS_SCATTERED":
|
|
|
|
return 802;
|
|
|
|
case "CLOUDS_BROKEN":
|
|
|
|
return 803;
|
|
|
|
case "CLOUDS_OVERCAST":
|
|
|
|
return 804;
|
|
|
|
|
|
|
|
case "TORNADO":
|
|
|
|
return 900;
|
|
|
|
case "TROPICAL_STORM":
|
|
|
|
return 901;
|
|
|
|
case "HURRICANE":
|
|
|
|
return 902;
|
|
|
|
case "COLD":
|
|
|
|
return 903;
|
|
|
|
case "HOT":
|
|
|
|
return 904;
|
|
|
|
case "WINDY":
|
|
|
|
return 905;
|
|
|
|
case "HAIL":
|
|
|
|
return 906;
|
|
|
|
}
|
|
|
|
return 3200;
|
|
|
|
}
|
2015-12-28 20:55:59 +01:00
|
|
|
}
|