Подтвердить что ты не робот

Android Place Picker закрывается сразу после запуска

Я разрабатываю приложение для Android как часть проекта, и я использую API Google places для отображения интересующих мест на основе местоположения. Я использую PlacePicker Inentbuilder для выполнения этого.

Однако, когда приложение запускается, программа выбора места запускается, а затем немедленно закрывается (около 1-2 секунд).

Я уже реализовал следующие предложения (которые я получил из других ответов):

Я создал открытый ключ API для приложений для Android, и включил его в тег метаданных в манифесте приложения.

Я включил API-интерфейс API Google Places для Android для консоли разработчиков.

Я включил последнюю версию игровых сервисов в зависимости от build.gradle.

Я включил свой код и логарифм ниже. Дайте мне знать, если мне нужно включить что-нибудь еще.

Manifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.sampath.project.project_v2" >

<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" >
    <activity
        android:name=".MainActivity"
        android:label="@string/app_name" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <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="@string/google_api_key" />
    <meta-data
        android:name="com.google.android.maps.v2.API_KEY"
        android:value="@string/google_api_key" />"

    <activity
        android:name=".LoginActivity"
        android:label="@string/title_activity_login" >
    </activity>
    <activity
        android:name=".PlacesSample"
        android:label="@string/title_activity_places_sample" >
        <meta-data
            android:name="com.google.android.geo.api_key"
            android:value="@string/google_api_key" />
    </activity>
</application>

</manifest>

Build.gradle(модуль приложения - это единственный модуль)

apply plugin: 'com.android.application'

android {
    compileSdkVersion 22
    buildToolsVersion "22.0.1"

    defaultConfig {
        applicationId "com.sampath.project.project_v2"
        minSdkVersion 16
        targetSdkVersion 21
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

dependencies {
    //compile fileTree(include: ['*.jar'], dir: 'libs')
    //compile 'com.android.support:appcompat-v7:22.1.1'
    compile 'com.android.support:appcompat-v7:22.1.1'
    compile 'com.android.support:cardview-v7:22.1.1'
    compile 'com.android.support:recyclerview-v7:22.1.1'
    compile 'com.google.android.gms:play-services:7.3.0'
}

PlacesSample - активность, использующая API google places:

package com.sampath.project.project_v2;


import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.TextView;
import android.widget.Toast;

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;


public class PlacesSample extends AppCompatActivity {
    TextView getLocation;
    int PLACE_PICKER_REQUEST = 1;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_places_sample);
        getLocation = (TextView)findViewById(R.id.getLocTV);
        getLocation.setClickable(true);
        getLocation.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                PlacePicker.IntentBuilder builder = new PlacePicker.IntentBuilder();
                Intent intent;
                try {
                    intent = builder.build(getApplicationContext());
                    startActivityForResult(intent, PLACE_PICKER_REQUEST);
                    System.out.println("start activity for result");
                } catch (GooglePlayServicesRepairableException e) {
                    e.printStackTrace();
                } catch (GooglePlayServicesNotAvailableException e) {
                    e.printStackTrace();
                }

            }
        });
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.menu_places_sample, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();

        //noinspection SimplifiableIfStatement
        if (id == R.id.action_settings) {
            return true;
        }

        return super.onOptionsItemSelected(item);
    }

    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        System.out.println("onActivityResult");
        if (requestCode == PLACE_PICKER_REQUEST) {
            if (resultCode == RESULT_OK) {
                Place place = PlacePicker.getPlace(data, this);
                String toastMsg = String.format("Place: %s", place.getName());
                Toast.makeText(this, toastMsg, Toast.LENGTH_LONG).show();
            }
        }
    }
}

Logcat:

05-05 23:38:30.593  21408-21408/com.sampath.project.project_v2 I/Timeline﹕ Timeline: Activity_idle id: [email protected] time:628772943
05-05 23:38:30.598  21408-21408/com.sampath.project.project_v2 I/Timeline﹕ Timeline: Activity_idle id: [email protected] time:628772948
05-05 23:38:31.517  21408-21408/com.sampath.project.project_v2 I/Timeline﹕ Timeline: Activity_launch_request id:com.sampath.project.project_v2 time:628773867
05-05 23:38:31.527  21408-21408/com.sampath.project.project_v2 W/ResourceType﹕ For resource 0x01030224, entry index(548) is beyond type entryCount(9)
05-05 23:38:31.527  21408-21408/com.sampath.project.project_v2 W/ResourceType﹕ For resource 0x01030224, entry index(548) is beyond type entryCount(9)
05-05 23:38:31.636  21408-21408/com.sampath.project.project_v2 I/Timeline﹕ Timeline: Activity_idle id: [email protected] time:628773986
05-05 23:38:33.869  21408-21408/com.sampath.project.project_v2 I/System.out﹕ start activity for result
05-05 23:38:34.227  21408-21408/com.sampath.project.project_v2 I/System.out﹕ onActivityResult
05-05 23:38:34.235  21408-21408/com.sampath.project.project_v2 I/Timeline﹕ Timeline: Activity_idle id: [email protected] time:628776586
4b9b3361

Ответ 1

Решения Франсуа Уотса помогли ответить на это. Спасибо, Франсуа...

Я искал журналы с ключевым словом "Места" и обнаружил, что API "Места" действительно бросает исключение. Он ожидал com.google.android.geo.API_KEY в тегах <application> в Manifest.xml.

Я изменился на com.google.android.geo.API_KEY в теге <activity>, а не на теге <application>.

Теперь изменилось на com.google.android.geo.API_KEY и удалили те же строки из тега <activity> и получили его работу. Почувствуйте себя идиотом за то, что я не справился с этим сам.

Тег метаданных должен читать android:name="com.google.android.geo.API_KEY"
Он должен находиться в теге <application> в манифесте.

Ответ 2

enter image description here Проверяли ли вы дважды, что ваш ключ API связан с вашим приложением (имя пакета и отпечаток SHA-1 сертификата приложения) в консоли разработчика?

Инструкции можно найти в разделе "Регистрация" и "Ключи API". Обязательно настройте его как для отладки, так и для сертификатов выпуска.

Надеюсь, это поможет!

Ответ 3

У меня была такая же проблема. Убедитесь, что вы включили Google Places API для Android, а не только Places API в консоли разработчика. "API мест для Android" не будет отображаться в разделе " API-интерфейсы и аутентификация /API-интерфейсы", поскольку он пока не является популярным API-интерфейсом. Вам придется искать его с помощью окна поиска API.

Ответ 4

В файле манифеста com.google.android.geo.api_key и com.google.android.maps.v2.API_KEY не должно быть одинаковым.

перейти к https://console.developers.google.com/project

и выполните следующие действия, чтобы получить ключ для мест размещения.

создать или выбрать существующий > использовать google apis > API Google Адресов для Android > включить > учетные данные в меню слевa > добавить учетные данные > api key > android key > create > copy key.

вставьте свой ключ в манифест " com.google.android.geo.api_key"

Примечание: существует ограничение на 1000 запросов в день для google places api. после того, как вы должны заплатить деньги. Лучше избегать PlacePicker.

Ответ 5

Добавить компиляцию 'com.google.android.gms:play-services-location:8.1.0' в Gradle

Ответ 6

Эта проблема также сошла с ума, так много проблем, связанных с этой проблемой, но никто не помог мне. В конце концов, я понял, что существуют различные API Google Адресов, особенно для Android. Следовательно, API-ключ, который я использовал, был просто для версии, отличной от Android.

Создайте свой ключ, используя эту ссылку. https://developers.google.com/places/android-api/signup

Ответ 7

Может быть, вы забыли добавить ключ SHA вашего компьютера в консоль Google Maps. Столкнулся с той же проблемой, добавил мой ключ SHA в консоль, он начал работать нормально.

Ответ 8

Я заполнил экран "Согласие" в API-интерфейсах и аутентификации консоли, и он работает нормально. Проверьте снимок экрана. enter image description here

Ответ 9

Было странно, что это была проблема с полномочиями для меня. Он работает даже без предупреждения в режиме отладки, но когда я использую выпущенную версию моего приложения, он просто не работает (я зарегистрировал свой релиз и отладку ключей sha1), поэтому я снял все ограничения и теперь он работает.

Ответ 10

В моем случае произошел конфликт API. Я добавил файл google-service.json, в котором также был ключ API, и сгенерировал новый ключ для Карт. Так что место сборщика закрывалось сразу. Решение:

  1. Используйте один ключ API, который находится в файле google-service.json

  2. Включите функцию "Places SDK для Android" для своего проекта Google Cloud Platform (с тем же именем, что и в проекте Firebase, не используйте другой проект. Вы найдете проект с тем же именем, что и в Firebase)

  3. Положите ограничение приложения SHA1 для приложения Android (рекомендуется)
  4. Проверьте, поместили ли вы следующий код только в тег приложения

        <meta-data
            android:name="com.google.android.geo.API_KEY"
            android:value="API_KEY" />
    

Ответ 11

Я просто оставлю это здесь, может быть, это поможет кому-то в будущем.

Для меня использование неправильного ключа Api вызвало сбой, хотя в прошлом он работал нормально.

Places SDK for Android - Credentials

Мне пришлось использовать второй ключ (тот, который автоматически создается службами Google для Android) вместо первого, который я создал.

Ответ 12

Если вы все еще сталкиваетесь с этой проблемой, перенесите средство выбора с помощью следующей ссылки: Миграция в SDK-клиент New Places