diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2018-12-18 09:39:06 -0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-12-18 09:39:06 -0800 |
commit | d0798cd3699c7ce5cc25daf65335d0670256eda0 (patch) | |
tree | 0593a646a7f6651be02139779ee1cdfefd2add20 /src/org | |
parent | 85cd0f9e023b7c664373ea19418c2ed5675c5025 (diff) | |
parent | 0e39aad22c5679f37e5a2ab892c15cf196cd0873 (diff) | |
download | traccar-server-d0798cd3699c7ce5cc25daf65335d0670256eda0.tar.gz traccar-server-d0798cd3699c7ce5cc25daf65335d0670256eda0.tar.bz2 traccar-server-d0798cd3699c7ce5cc25daf65335d0670256eda0.zip |
Merge pull request #4166 from mujeerhashmi/mapmyindia
Implement MapmyIndia Reverse geocoder
Diffstat (limited to 'src/org')
-rw-r--r-- | src/org/traccar/Context.java | 3 | ||||
-rw-r--r-- | src/org/traccar/geocoder/MapmyIndiaGeocoder.java | 67 |
2 files changed, 70 insertions, 0 deletions
diff --git a/src/org/traccar/Context.java b/src/org/traccar/Context.java index 07fab2bd1..95d433795 100644 --- a/src/org/traccar/Context.java +++ b/src/org/traccar/Context.java @@ -60,6 +60,7 @@ import org.traccar.geocoder.HereGeocoder; import org.traccar.geocoder.MapQuestGeocoder; import org.traccar.geocoder.NominatimGeocoder; import org.traccar.geocoder.OpenCageGeocoder; +import org.traccar.geocoder.MapmyIndiaGeocoder; import org.traccar.geocoder.Geocoder; import org.traccar.geolocation.UnwiredGeolocationProvider; import org.traccar.helper.Log; @@ -351,6 +352,8 @@ public final class Context { return new BanGeocoder(cacheSize, addressFormat); case "here": return new HereGeocoder(id, key, language, cacheSize, addressFormat); + case "mapmyindia": + return new MapmyIndiaGeocoder(url, key, cacheSize, addressFormat); default: return new GoogleGeocoder(key, language, cacheSize, addressFormat); } diff --git a/src/org/traccar/geocoder/MapmyIndiaGeocoder.java b/src/org/traccar/geocoder/MapmyIndiaGeocoder.java new file mode 100644 index 000000000..d42ad8eb3 --- /dev/null +++ b/src/org/traccar/geocoder/MapmyIndiaGeocoder.java @@ -0,0 +1,67 @@ +package org.traccar.geocoder; + +import javax.json.JsonArray; +import javax.json.JsonObject; + +public class MapmyIndiaGeocoder extends JsonGeocoder { + + public MapmyIndiaGeocoder(String url, String key, int cacheSize, AddressFormat addressFormat) { + super(url + "/" + key + "/rev_geocode?lat=%f&lng=%f", cacheSize, addressFormat); + } + + @Override + public Address parseAddress(JsonObject json) { + JsonArray results = json.getJsonArray("results"); + + if (!results.isEmpty()) { + Address address = new Address(); + + JsonObject result = (JsonObject) results.get(0); + + if (result.containsKey("formatted_address")) { + address.setFormattedAddress(result.getString("formatted_address")); + } + + if (result.containsKey("house_number") && (result.getString("house_number") != "")) { + address.setHouse(result.getString("house_number")); + } else if (result.containsKey("house_name") && (result.getString("house_name") != "")) { + address.setHouse(result.getString("house_name")); + } + + if (result.containsKey("street")) { + address.setStreet(result.getString("street")); + } + + if (result.containsKey("locality") && (result.getString("locality") != "")) { + address.setSuburb(result.getString("locality")); + } else if (result.containsKey("sublocality") && (result.getString("sublocality") != "")) { + address.setSuburb(result.getString("sublocality")); + } else if (result.containsKey("subsublocality") && (result.getString("subsublocality") != "")) { + address.setSuburb(result.getString("subsublocality")); + } + + if (result.containsKey("city") && (result.getString("city") != "")) { + address.setSettlement(result.getString("city")); + } else if (result.containsKey("village") && (result.getString("village") != "")) { + address.setSettlement(result.getString("village")); + } + + if (result.containsKey("district")) { + address.setDistrict(result.getString("district")); + } else if (result.containsKey("subDistrict")) { + address.setDistrict(result.getString("subDistrict")); + } + + if (result.containsKey("state")) { + address.setState(result.getString("state")); + } + + if (result.containsKey("pincode")) { + address.setPostcode(result.getString("pincode")); + } + + return address; + } + return null; + } +} |