parent
a2da39c4e2
commit
c78ebe9614
|
@ -10,6 +10,7 @@ import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import pl.tpolgrabia.googleutils.callback.PlacesCallback;
|
import pl.tpolgrabia.googleutils.callback.PlacesCallback;
|
||||||
import pl.tpolgrabia.googleutils.dto.GooglePlacePhoto;
|
import pl.tpolgrabia.googleutils.dto.GooglePlacePhoto;
|
||||||
|
import pl.tpolgrabia.googleutils.dto.GooglePlaceResponse;
|
||||||
import pl.tpolgrabia.googleutils.dto.GooglePlaceResult;
|
import pl.tpolgrabia.googleutils.dto.GooglePlaceResult;
|
||||||
import pl.tpolgrabia.googleutils.utils.PlacesUtils;
|
import pl.tpolgrabia.googleutils.utils.PlacesUtils;
|
||||||
import pl.tpolgrabia.urbanexplorer.AppConstants;
|
import pl.tpolgrabia.urbanexplorer.AppConstants;
|
||||||
|
@ -54,7 +55,7 @@ public class GooglePlacesWorker extends AsyncTask<GooglePlacesRequest, Integer,
|
||||||
lg.debug("Excuting param {}", param);
|
lg.debug("Excuting param {}", param);
|
||||||
Location location = param.getLocation();
|
Location location = param.getLocation();
|
||||||
|
|
||||||
Response<List<GooglePlaceResult>> placesResponse = null;
|
Response<GooglePlaceResponse> placesResponse = null;
|
||||||
try {
|
try {
|
||||||
placesResponse = placesUtils.fetchNearbyPlaces(
|
placesResponse = placesUtils.fetchNearbyPlaces(
|
||||||
location.getLatitude(),
|
location.getLatitude(),
|
||||||
|
@ -63,9 +64,9 @@ public class GooglePlacesWorker extends AsyncTask<GooglePlacesRequest, Integer,
|
||||||
param.getSearchItemType(),
|
param.getSearchItemType(),
|
||||||
param.getPageToken());
|
param.getPageToken());
|
||||||
|
|
||||||
if (placesResponse.code() == HttpStatus.SC_OK) {
|
if (placesResponse != null && placesResponse.code() == HttpStatus.SC_OK) {
|
||||||
GooglePlacesResponse response = new GooglePlacesResponse();
|
GooglePlacesResponse response = new GooglePlacesResponse();
|
||||||
response.setPlaces(placesResponse.body());
|
response.setPlaces(placesResponse.body().getResults());
|
||||||
result.add(response);
|
result.add(response);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,25 +1,23 @@
|
||||||
package pl.tpolgrabia.googleutils;
|
package pl.tpolgrabia.googleutils;
|
||||||
|
|
||||||
import pl.tpolgrabia.googleutils.dto.GooglePlaceResult;
|
import pl.tpolgrabia.googleutils.dto.GooglePlaceResponse;
|
||||||
import retrofit2.Call;
|
import retrofit2.Call;
|
||||||
import retrofit2.http.GET;
|
import retrofit2.http.GET;
|
||||||
import retrofit2.http.Query;
|
import retrofit2.http.Query;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by tpolgrabia on 02.10.16.
|
* Created by tpolgrabia on 02.10.16.
|
||||||
*/
|
*/
|
||||||
public interface GooglePlacesService {
|
public interface GooglePlacesService {
|
||||||
@GET("nearbysearch/json")
|
@GET("nearbysearch/json")
|
||||||
Call<List<GooglePlaceResult>> fetchNearbyPlacesFirst(
|
Call<GooglePlaceResponse> fetchNearbyPlacesFirst(
|
||||||
@Query("key") String apiKey,
|
@Query("key") String apiKey,
|
||||||
@Query("location") String location,
|
@Query("location") String location,
|
||||||
@Query("radius") Double radius,
|
@Query("radius") Double radius,
|
||||||
@Query("type") String type);
|
@Query("type") String type);
|
||||||
|
|
||||||
@GET("nearbysearch/json")
|
@GET("nearbysearch/json")
|
||||||
Call<List<GooglePlaceResult>> fetchNearbyPlacesNext(
|
Call<GooglePlaceResponse> fetchNearbyPlacesNext(
|
||||||
@Query("key") String apiKey,
|
@Query("key") String apiKey,
|
||||||
@Query("location") String location,
|
@Query("location") String location,
|
||||||
@Query("radius") Double radius,
|
@Query("radius") Double radius,
|
||||||
|
|
|
@ -1,141 +0,0 @@
|
||||||
package pl.tpolgrabia.googleutils.converter;
|
|
||||||
|
|
||||||
import org.json.JSONArray;
|
|
||||||
import org.json.JSONObject;
|
|
||||||
import org.slf4j.Logger;
|
|
||||||
import org.slf4j.LoggerFactory;
|
|
||||||
import pl.tpolgrabia.googleutils.dto.*;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Created by tpolgrabia on 28.09.16.
|
|
||||||
*/
|
|
||||||
public class GooglePlaceConverter {
|
|
||||||
|
|
||||||
private static final Logger lg = LoggerFactory.getLogger(GooglePlaceConverter.class);
|
|
||||||
public static GooglePlaceResult convertToPlaceResult(JSONObject object) {
|
|
||||||
|
|
||||||
lg.trace("Place result object: {}", object);
|
|
||||||
|
|
||||||
if (object == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
GooglePlaceResult dto = new GooglePlaceResult();
|
|
||||||
dto.setGeometry(convertToPlaceGeometry(object.optJSONObject("geometry")));
|
|
||||||
dto.setIcon(object.optString("icon"));
|
|
||||||
dto.setId(object.optString("id"));
|
|
||||||
dto.setName(object.optString("name"));
|
|
||||||
dto.setPhotos(convertToPlacePhotos(object.optJSONArray("photos")));
|
|
||||||
dto.setPlaceId(object.optString("place_id"));
|
|
||||||
dto.setRating(object.optDouble("rating"));
|
|
||||||
dto.setReference(object.optString("reference"));
|
|
||||||
dto.setScope(object.optString("scope"));
|
|
||||||
dto.setTypes(convertToStringList(object.optJSONArray("types")));
|
|
||||||
dto.setVicinity(object.optString("vicinity"));
|
|
||||||
return dto;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static List<String> convertToStringList(JSONArray stringArray) {
|
|
||||||
lg.trace("String array: {}", stringArray);
|
|
||||||
|
|
||||||
if (stringArray == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
int n = stringArray.length();
|
|
||||||
List<String> ret = new ArrayList<>(n);
|
|
||||||
for (int i = 0; i < n; i++) {
|
|
||||||
ret.add(stringArray.optString(i));
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static List<GooglePlacePhoto> convertToPlacePhotos(JSONArray jphotos) {
|
|
||||||
lg.trace("Place photos: {}", jphotos);
|
|
||||||
|
|
||||||
if (jphotos == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
int n = jphotos.length();
|
|
||||||
List<GooglePlacePhoto> photos = new ArrayList<>(n);
|
|
||||||
|
|
||||||
for (int i = 0; i < n; i++) {
|
|
||||||
photos.add(convertToPlacePhoto(jphotos.optJSONObject(i)));
|
|
||||||
}
|
|
||||||
|
|
||||||
return photos;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static GooglePlacePhoto convertToPlacePhoto(JSONObject jphoto) {
|
|
||||||
lg.trace("Place photo: {}", jphoto);
|
|
||||||
|
|
||||||
if (jphoto == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
GooglePlacePhoto photo = new GooglePlacePhoto();
|
|
||||||
photo.setHeight(jphoto.optLong("height"));
|
|
||||||
photo.setWidth(jphoto.optLong("width"));
|
|
||||||
photo.setPhotoReference(jphoto.optString("photo_reference"));
|
|
||||||
photo.setHtmlAttributions(convertToStringList(jphoto.optJSONArray("html_attributions")));
|
|
||||||
return photo;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static GooglePlaceGeometry convertToPlaceGeometry(JSONObject jgeometry) {
|
|
||||||
lg.trace("Place geometry: {}", jgeometry);
|
|
||||||
|
|
||||||
if (jgeometry == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
GooglePlaceGeometry geometry = new GooglePlaceGeometry();
|
|
||||||
geometry.setLocation(convertToPlaceLocation(jgeometry.optJSONObject("location")));
|
|
||||||
geometry.setViewport(convertToPlaceViewport(jgeometry.optJSONObject("viewport")));
|
|
||||||
return geometry;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static GooglePlaceViewport convertToPlaceViewport(JSONObject jviewport) {
|
|
||||||
lg.trace("Place viewport: {}", jviewport);
|
|
||||||
|
|
||||||
if (jviewport == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
GooglePlaceViewport viewport = new GooglePlaceViewport();
|
|
||||||
viewport.setNorthEast(convertToPlaceLocation(jviewport.optJSONObject("northeast")));
|
|
||||||
viewport.setSouthWest(convertToPlaceLocation(jviewport.optJSONObject("southwest")));
|
|
||||||
return viewport;
|
|
||||||
}
|
|
||||||
|
|
||||||
private static GooglePlaceLocation convertToPlaceLocation(JSONObject jlocation) {
|
|
||||||
lg.trace("Place location: {}", jlocation);
|
|
||||||
if (jlocation == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
GooglePlaceLocation location = new GooglePlaceLocation();
|
|
||||||
location.setLatitude(jlocation.optDouble("lat"));
|
|
||||||
location.setLongitude(jlocation.optDouble("lng"));
|
|
||||||
return location;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static List<GooglePlaceResult> convertToPlaceResults(JSONArray jresults) {
|
|
||||||
lg.trace("Place results: {}", jresults);
|
|
||||||
|
|
||||||
if (jresults == null) {
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
List<GooglePlaceResult> results = new ArrayList<>();
|
|
||||||
int n = jresults.length();
|
|
||||||
for (int i = 0; i < n; i++) {
|
|
||||||
results.add(convertToPlaceResult(jresults.optJSONObject(i)));
|
|
||||||
}
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,10 +1,14 @@
|
||||||
package pl.tpolgrabia.googleutils.dto;
|
package pl.tpolgrabia.googleutils.dto;
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by tpolgrabia on 28.09.16.
|
* Created by tpolgrabia on 28.09.16.
|
||||||
*/
|
*/
|
||||||
public class GooglePlaceLocation {
|
public class GooglePlaceLocation {
|
||||||
|
@SerializedName("lat")
|
||||||
private Double latitude;
|
private Double latitude;
|
||||||
|
@SerializedName("lng")
|
||||||
private Double longitude;
|
private Double longitude;
|
||||||
|
|
||||||
public Double getLatitude() {
|
public Double getLatitude() {
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
package pl.tpolgrabia.googleutils.dto;
|
package pl.tpolgrabia.googleutils.dto;
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -7,7 +9,9 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public class GooglePlacePhoto {
|
public class GooglePlacePhoto {
|
||||||
private Long height;
|
private Long height;
|
||||||
|
@SerializedName("html_attributions")
|
||||||
private List<String> htmlAttributions;
|
private List<String> htmlAttributions;
|
||||||
|
@SerializedName("photo_reference")
|
||||||
private String photoReference;
|
private String photoReference;
|
||||||
private Long width;
|
private Long width;
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
package pl.tpolgrabia.googleutils.dto;
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by tpolgrabia on 03.10.16.
|
||||||
|
*/
|
||||||
|
public class GooglePlaceResponse {
|
||||||
|
@SerializedName("html_attributions")
|
||||||
|
private List<String> htmlAttributions;
|
||||||
|
@SerializedName("next_page_token")
|
||||||
|
private String nextPageToken;
|
||||||
|
private List<GooglePlaceResult> results;
|
||||||
|
|
||||||
|
public List<String> getHtmlAttributions() {
|
||||||
|
return htmlAttributions;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setHtmlAttributions(List<String> htmlAttributions) {
|
||||||
|
this.htmlAttributions = htmlAttributions;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getNextPageToken() {
|
||||||
|
return nextPageToken;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setNextPageToken(String nextPageToken) {
|
||||||
|
this.nextPageToken = nextPageToken;
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<GooglePlaceResult> getResults() {
|
||||||
|
return results;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setResults(List<GooglePlaceResult> results) {
|
||||||
|
this.results = results;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "GooglePlaceResponse{" +
|
||||||
|
"htmlAttributions=" + htmlAttributions +
|
||||||
|
", nextPageToken='" + nextPageToken + '\'' +
|
||||||
|
", results='" + results + '\'' +
|
||||||
|
'}';
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,5 +1,7 @@
|
||||||
package pl.tpolgrabia.googleutils.dto;
|
package pl.tpolgrabia.googleutils.dto;
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -11,6 +13,7 @@ public class GooglePlaceResult {
|
||||||
private String id;
|
private String id;
|
||||||
private String name;
|
private String name;
|
||||||
private List<GooglePlacePhoto> photos;
|
private List<GooglePlacePhoto> photos;
|
||||||
|
@SerializedName("place_id")
|
||||||
private String placeId;
|
private String placeId;
|
||||||
private Double rating;
|
private Double rating;
|
||||||
private String reference;
|
private String reference;
|
||||||
|
|
|
@ -1,10 +1,14 @@
|
||||||
package pl.tpolgrabia.googleutils.dto;
|
package pl.tpolgrabia.googleutils.dto;
|
||||||
|
|
||||||
|
import com.google.gson.annotations.SerializedName;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by tpolgrabia on 28.09.16.
|
* Created by tpolgrabia on 28.09.16.
|
||||||
*/
|
*/
|
||||||
public class GooglePlaceViewport {
|
public class GooglePlaceViewport {
|
||||||
|
@SerializedName("northeast")
|
||||||
private GooglePlaceLocation northEast;
|
private GooglePlaceLocation northEast;
|
||||||
|
@SerializedName("southwest")
|
||||||
private GooglePlaceLocation southWest;
|
private GooglePlaceLocation southWest;
|
||||||
|
|
||||||
public GooglePlaceLocation getNorthEast() {
|
public GooglePlaceLocation getNorthEast() {
|
||||||
|
|
|
@ -8,13 +8,12 @@ import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
import pl.tpolgrabia.googleutils.GooglePlacesService;
|
import pl.tpolgrabia.googleutils.GooglePlacesService;
|
||||||
import pl.tpolgrabia.googleutils.constants.GooglePlacesConstants;
|
import pl.tpolgrabia.googleutils.constants.GooglePlacesConstants;
|
||||||
import pl.tpolgrabia.googleutils.dto.GooglePlaceResult;
|
import pl.tpolgrabia.googleutils.dto.GooglePlaceResponse;
|
||||||
import retrofit2.Response;
|
import retrofit2.Response;
|
||||||
import retrofit2.Retrofit;
|
import retrofit2.Retrofit;
|
||||||
import retrofit2.converter.gson.GsonConverterFactory;
|
import retrofit2.converter.gson.GsonConverterFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Created by tpolgrabia on 27.09.16.
|
* Created by tpolgrabia on 27.09.16.
|
||||||
|
@ -33,7 +32,7 @@ public class PlacesUtils {
|
||||||
this.aq = new AQuery(ctx);
|
this.aq = new AQuery(ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Response<List<GooglePlaceResult>> fetchNearbyPlaces(Double latitude,
|
public Response<GooglePlaceResponse> fetchNearbyPlaces(Double latitude,
|
||||||
Double longitude,
|
Double longitude,
|
||||||
Double searchRadius,
|
Double searchRadius,
|
||||||
String searchItemType,
|
String searchItemType,
|
||||||
|
|
Loading…
Reference in New Issue