Как решить "API мест для Android, похоже, не включен для вашего приложения" - PullRequest
0 голосов
/ 22 февраля 2019

Эта ошибка беспокоит меня уже более суток.Я уже тщательно искал, но ни один из ответов не дал мне решения.Я правильно настроил ключ API с ограничениями App, указав имя пакета и ключ SHA1.Вот код manifest.xml

    <?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.myapplication">
    <!--
         The ACCESS_COARSE/FINE_LOCATION permissions are not required to use
         Google Maps Android API v2, but you must specify either coarse or fine
         location permissions for the 'MyLocation' functionality.
    -->
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:roundIcon="@mipmap/ic_launcher_round"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <meta-data
            android:name="com.google.android.geo.API_KEY"
            android:value="@string/google_maps_key" />

        <activity android:name=".PlacePickerActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <!--
             The API key for Google Maps-based APIs is defined as a string resource.
             (See the file "res/values/google_maps_api.xml").
             Note that the API key is linked to the encryption key used to sign the APK.
             You need a different API key for each encryption key, including the release key that is used to
             sign the APK for publishing.
             You can define the keys for the debug and release targets in src/debug/ and src/release/.
        -->


        <activity
            android:name=".MapsActivity"
            android:label="@string/title_activity_maps">

        </activity>

    </application>

</manifest>

MapsActivity

public class MapsActivity extends FragmentActivity implements OnMapReadyCallback {

private GoogleMap mMap;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_maps);
    // Obtain the SupportMapFragment and get notified when the map is ready to be used.
    SupportMapFragment mapFragment = (SupportMapFragment) getSupportFragmentManager()
            .findFragmentById(R.id.map);
    mapFragment.getMapAsync(this);
}


/**
 * Manipulates the map once available.
 * This callback is triggered when the map is ready to be used.
 * This is where we can add markers or lines, add listeners or move the camera. In this case,
 * we just add a marker near Sydney, Australia.
 * If Google Play services is not installed on the device, the user will be prompted to install
 * it inside the SupportMapFragment. This method will only be triggered once the user has
 * installed Google Play services and returned to the app.
 */
@Override
public void onMapReady(GoogleMap googleMap) {
    mMap = googleMap;

    // Add a marker in Sydney and move the camera
    LatLng sydney = new LatLng(-34, 151);
    mMap.addMarker(new MarkerOptions().position(sydney).title("Marker in Sydney"));
    mMap.moveCamera(CameraUpdateFactory.newLatLng(sydney));
}

}

PlacePickerActivity

public class PlacePickerActivity extends AppCompatActivity {

    int PLACE_PICKER_REQUEST=1;
    TextView tvPlace;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_place_picker);
        tvPlace=findViewById(R.id.tv_Place);
    }

    public void goPlacePicker(View view) {
        PlacePicker.IntentBuilder builder=new PlacePicker.IntentBuilder();
        try{
            Log.e("error","1");
            startActivityForResult(builder.build(PlacePickerActivity.this),PLACE_PICKER_REQUEST);

        }catch(GooglePlayServicesRepairableException e)
        {
            Log.e("Repairable",e.toString());

            e.printStackTrace();
        }
        catch(GooglePlayServicesNotAvailableException e){
            Log.e("Not Available",e.toString());
            e.printStackTrace();
        }

    }
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data){
        if(requestCode == PLACE_PICKER_REQUEST){
            if(resultCode == RESULT_OK){
                Log.e("Activity","2");
                Place place=PlacePicker.getPlace(PlacePickerActivity.this,data);
                Log.e("PlacePicker","3");
                tvPlace.setText(place.getAddress());
            }
        }

    }
}

Заранее благодарим за любую возможную помощь..

1 Ответ

0 голосов
/ 22 февраля 2019

Примечание: Версия Google Play Services для Places SDK для Android (в Google Play Services 16.0.0) устарела с 29 января 2019 года и будет отключена в июле29, 2019. Доступна новая версия Places SDK для Android. Мы рекомендуем обновить ее до новой версии как можно скорее.Для получения дополнительной информации см. Руководство по миграции .

. Вы можете проверить указанное выше сообщение в по этой ссылке в разделе Уведомление об амортизации.

Разместить APIперемещены в отдельную библиотеку вместо Google Play Services.Поэтому вам нужно перейти на API-интерфейс New Place.


Вы можете следовать приведенному ниже руководству по миграции или под кодом, чтобы интегрировать Places SDK для Android.

1.Добавьте эту зависимость в файл уровня приложения build.gradle:
implementation 'com.google.android.libraries.places:places:1.0.0'

Примечание: minSdkVersion вашего проекта приложения должно быть 14 или выше

2.Инициализируйте места в своей деятельности.
Places.initialize(getApplicationContext(), YOUR_API_KEY);

3.Вызовите функцию ниже, если вы хотите открыть PlaceAutocomplete Activity

private void startAutocompleteActivity() {
        List<com.google.android.libraries.places.api.model.Place.Field> placeFields = new ArrayList<>(Arrays.asList(com.google.android.libraries.places.api.model.Place.Field.values()));
        List<TypeFilter> typeFilters = new ArrayList<>(Arrays.asList(TypeFilter.values()));
// Create a RectangularBounds object.
  RectangularBounds bounds = RectangularBounds.newInstance(
    new LatLng(-33.880490, 151.184363),
    new LatLng(-33.858754, 151.229596));
        Intent autocompleteIntent =
                new Autocomplete.IntentBuilder(AutocompleteActivityMode.FULLSCREEN, placeFields)
                        .setLocationBias(bounds)
                        .setTypeFilter(typeFilters.get(0))
                        .build(this);
        startActivityForResult(autocompleteIntent, 1001);
    }  

4.Напишите ниже код onActivityResult

/**
     * Override the activity's onActivityResult(), check the request code, and
     * do something with the returned place data (in this example it's place name and place ID).
     */
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        if (requestCode == 1001) {
            if (resultCode == RESULT_OK) {
                Place place = Autocomplete.getPlaceFromIntent(data);
                Log.i(TAG, "Place: " + place.getName() + ", " + place.getId());
            } else if (resultCode == AutocompleteActivity.RESULT_ERROR) {
                // TODO: Handle the error.
                Status status = Autocomplete.getStatusFromIntent(data);
                Log.i(TAG, status.getStatusMessage());
            } else if (resultCode == RESULT_CANCELED) {
                // The user canceled the operation.
            }
        }
    }


Вы можете проверить это демо-приложение для более подробной информации


Теперь самое важное, чтоВы должны включить биллинг для использования New Place API для Android.

Чтобы использовать Places SDK для Android, вы должны включить ключ API во все запросы API, и вы должны включить биллинг для каждого из ваших проектов.

Проверьте эту ссылку для получения дополнительной информации и цен.

SKU: базовые данные

Поля в базовой категории включены в базовую стоимость запроса мест и не приводят к дополнительным сборам.Артикул базовых данных запускается, когда запрашивается любое из следующих полей: АДРЕС, ИД, LAT_LNG, ИМЯ, OPENING_HOURS, PHOTO_METADATAS, PLUS_CODE, TYPES, USER_RATINGS_TOTAL, VIEWPORT.

Вы можете проверить цены и другиев той же ссылке , приведенной выше.

...