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();
        }

Наслаждайтесь!