Google добавляет API в один тип "car_repair"
Я использую API-интерфейсы Google, и он возвращает все места в моем местоположении. Однако я только хочу, чтобы он возвращал тип "авторемонт". Я думаю, что у меня его почти нет, но я что-то упускаю, если кто-то может вести меня в правильном направлении, было бы здорово:)
Мой код до сих пор
PlacPickerActivity
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.Html;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import com.google.android.gms.common.GooglePlayServicesNotAvailableException;
import com.google.android.gms.common.GooglePlayServicesRepairableException;
import com.google.android.gms.location.places.Place;
import com.google.android.gms.location.places.ui.PlacePicker;
import com.google.android.gms.maps.model.LatLng;
import com.google.android.gms.maps.model.LatLngBounds;
public class PlacePickerActivity extends AppCompatActivity {
private static final int PLACE_PICKER_REQUEST = 1;
String url="https://maps.googleapis.com/maps/api/place/textsearch/json?type=car_repair&key=AIzaSyBKsTtLyMBQH8mhvbknJ4MvZwACotmeYO0";
private TextView mName;
private TextView mAddress;
private TextView mAttributions;
private TextView mNumber;
private static final LatLngBounds Sligo = new LatLngBounds(
new LatLng(54.27, -8.47), new LatLng(54.27, -8.47));
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_place_picker);
mName = (TextView) findViewById(R.id.textView);
mAddress = (TextView) findViewById(R.id.textView2);
mAttributions = (TextView) findViewById(R.id.textView3);
mNumber = (TextView) findViewById(R.id.textView4);
Button pickerButton = (Button) findViewById(R.id.pickerButton);
pickerButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
try {
PlacePicker.IntentBuilder intentBuilder =
new PlacePicker.IntentBuilder();
intentBuilder.setLatLngBounds(Sligo);
Intent intent = intentBuilder.build(PlacePickerActivity.this);
startActivityForResult(intent, PLACE_PICKER_REQUEST);
} catch (GooglePlayServicesRepairableException
| GooglePlayServicesNotAvailableException e) {
e.printStackTrace();
}
}
});
}
@Override
protected void onActivityResult(int requestCode,
int resultCode, Intent data) {
if (requestCode == PLACE_PICKER_REQUEST
&& resultCode == Activity.RESULT_OK) {
final Place place = PlacePicker.getPlace(this, data);
final CharSequence name = place.getName();
final CharSequence address = place.getAddress();
final CharSequence formatted_phone_number = place.getPhoneNumber();
String attributions = (String) place.getAttributions();
if (attributions == null) {
attributions = "";
}
mName.setText(name);
mAddress.setText(address);
mAttributions.setText(Html.fromHtml(attributions));
mNumber.setText(formatted_phone_number);
} else {
super.onActivityResult(requestCode, resultCode, data);
}
}
}
Файл манифеста
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.truiton.placepicker">
<uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme">
<meta-data
android:name="com.google.android.gms.version"
android:value="@integer/google_play_services_version"/>
<meta-data
android:name="com.google.android.geo.API_KEY"
android:value="AIzaSyBKsTtLyMBQH8mhvbknJ4MvZwACotmeYO0"/>
<activity
android:name=".PlacePickerActivity"
android:label="@string/app_name">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
Когда я печатаю URL-адрес в своем браузере на своем ПК, он возвращает весь тип "car_repair" в моей области, поэтому мой API-ключ работает
![введите описание изображения здесь]()
Ответы
Ответ 1
Попробуйте с запросом, подобным этому:
Местоположение находится в формате широты, долготы... и будьте осторожны, это "типы", а не тип.
https://maps.googleapis.com/maps/api/place/nearbysearch/json?location=54.27,-8.47&radius=1000&types=car_repair&key=AddYourOwnKeyHere
Ответ 2
Поскольку этот API возвращает тип места внутри области. Существует способ, который может улучшить результат, но все же не оптимальный, который называется setLatLngBounds
. Ссылка https://developers.google.com/android/reference/com/google/android/gms/location/places/ui/PlacePicker.IntentBuilder#public-method-summary
Я уже пробовал этот API и обнаружил, что это в какой-то степени беспорядок.
Например, если вы хотите найти ресторан внутри университета, этот API не только вернет вам ресторан, но и многие другие типы, такие как University
. Возможно, установка привязки может быть хорошей, но все равно получить раздражающий результат, если вы используете только API.
Если вы просто хотите тип car-repair
, я предлагаю вам написать фильтр для фильтрации других типов и сохранить только тип ремонта и соответствующую информацию.
Ответ 3
Я подготовил это для вас, надеюсь, что это поможет
// A class to store your results
public class Place {
private String icon;
private Double latitude;
public void setIcon(String icon) {
this.icon=icon;
}
public void setLatitude(Double latitude) {
this.latitude=latitude;
}
// .....
}
// Utility class to keep things simple
public class Functions {
public static JSONObject convertInputStreamToJSONObject(InputStream inputStream)
throws JSONException, IOException
{
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(inputStream));
String line = "";
String result = "";
while ((line = bufferedReader.readLine()) != null)
result += line;
inputStream.close();
return new JSONObject(result);
}
public static ArrayList<Place> parsePlacesFromJson(JSONObject datos) throws JSONException {
List<Place> placesList = new ArrayList<>();
// in your case this must be "results" I think
final int LIST_LENGTH = datos.getJSONArray("results").length();
//final int LIST_LENGTH = datos.getJSONArray("nameOfTheJsonMainArray").length();
Log.d("Length", String.valueOf(LIST_LENGTH));
// For every element in the list
for(int i = 0; i < LIST_LENGTH; i++) {
// Instance of a new Place
Place place = new Place();
// Get data as needed, this represents one place
JSONObject obj = datos.getJSONArray("results").getJSONObject(i);
Double latitude = obj.getJSONObject("geometry").getJSONObject("location").getDouble("lat");
String icon = obj.getString("icon");
place.setLatitude(latitude);
place.setIcon(icon);
//....
placesList.add(place)
}
return placesList;
}
}
// The google places reader class
public class ApiReader {
private static final String TAG = "API_READER";
Context context;
View v;
public ApiReader(Context context, View v) {
this.context = context;
this.v = v;
}
private static final String APIKEY = "yourkeyhere";
private static String ENDPOINT =
"https://maps.googleapis.com/maps/api/place/nearbysearch/json?location=54.27,-8.47&radius=1000&types=car_repair&key=%s";
// Method to be called
public void getCarRepairs() throws IOException {
URL url = new URL(String.format(ENDPOINT, APIKEY));
new GetPlaces().execute(url);
}
// Inner asyctask class
private class GetPlaces extends AsyncTask<URL, Integer, List<Place>> {
List<Place> lista;
@Override
protected List<Place> doInBackground(URL... params) {
JSONObject datos;
URL url = params[0];
HttpURLConnection urlConnection = null;
try {
urlConnection = (HttpURLConnection) url.openConnection();
InputStream in = new BufferedInputStream(urlConnection.getInputStream());
datos = Functions.convertInputStreamToJSONObject(in);
Log.i(TAG, datos.toString());
// De los datos obtenemos un objeto Place
lista = Functions.parsePlacesFromJson(datos);
Log.i(TAG, "" + lista.toString());
Log.i(TAG, "Went into try was OK.");
} catch (Exception e) {
Log.e(TAG, e.toString());
Log.i(TAG, "Went into catch");
} finally {
urlConnection.disconnect();
Log.i(TAG, "Went into finally, urlConnection disconnected.");
}
return lista;
}
// This method it gets what the "doInBackGround" returns
protected void onPostExecute(List<Place> placesList) {
if(placesList != null) {
// Do whatever with the list of places
//Functions.updateView(v, placesList);
}
}
}
}
// And to make things work in yout activity just do like this
ApiReader api = new ApiReader(this, findViewById(R.id.mainLayout));
try {
api.getCarRepairs();
} catch (IOException e) {
e.printStackTrace();
}
Наслаждайтесь!