Android Place Picker在发布后立即关闭

Android Place Picker在发布后立即关闭,android,google-places-api,Android,Google Places Api,作为一个项目的一部分,我正在开发一个android应用程序,并使用GooglePlacesAPI根据位置显示感兴趣的地点。我正在使用PlacePicker构建器来完成此任务 但是,当应用程序运行时,位置选择器会启动,然后立即关闭(约1-2秒) 我已经实施了以下建议(我从其他答案中得到): 我已经为android应用程序生成了公共API密钥,并将其包含在应用程序清单的元数据标记中 我已经在开发者控制台上启用了“Google Places API for android”API 我已经在build.

作为一个项目的一部分,我正在开发一个android应用程序,并使用GooglePlacesAPI根据位置显示感兴趣的地点。我正在使用PlacePicker构建器来完成此任务

但是,当应用程序运行时,位置选择器会启动,然后立即关闭(约1-2秒)

我已经实施了以下建议(我从其他答案中得到):

我已经为android应用程序生成了公共API密钥,并将其包含在应用程序清单的元数据标记中

我已经在开发者控制台上启用了“Google Places API for android”API

我已经在build.gradle的dependencies中包含了最新的play services版本

我已经在下面包括了我的代码和日志。如果我需要包括任何其他内容,请务必告诉我

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>
PlacesSample-使用google places API的活动:

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

05-05 23:38:30.593  21408-21408/com.sampath.project.project_v2 I/Timeline﹕ Timeline: Activity_idle id: android.os.BinderProxy@17e945c6 time:628772943
05-05 23:38:30.598  21408-21408/com.sampath.project.project_v2 I/Timeline﹕ Timeline: Activity_idle id: android.os.BinderProxy@17e945c6 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: android.os.BinderProxy@2daadb0a 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: android.os.BinderProxy@2daadb0a time:628776586
您是否仔细检查了API密钥是否与中的应用程序(包名和应用程序证书的SHA-1指纹)关联

您可以在上找到说明。确保为调试证书和发布证书设置它


我希望这有帮助

弗朗索瓦·沃茨的解决方案帮助回答了这个问题。谢谢你,弗朗索瓦

我用关键字“Places”搜索日志,发现Places API确实抛出了一个异常。它希望Manifest.xml中的
标记中包含
com.google.android.geo.API_键

我在
标签中改为
com.google.android.geo.API\u KEY,而不是
标签中的那个

现在改为
com.google.android.geo.API_KEY
,并从
标签中删除了相同的行,使其正常工作。我觉得自己是个白痴没有自己解决这个问题

元数据标签应为
android:name=“com.google.android.geo.API\u KEY”

它应该位于清单中的
标记内


清单文件中的com.google.android.geo.api_keycom.google.android.maps.v2.api_key不应相同

登录并按照以下步骤获取placepicker places的密钥

创建或选择现有>使用google API>google Places API for Android>在左侧菜单中启用>凭据>添加凭据>API密钥>Android密钥>创建>复制密钥

将密钥粘贴到manifest“com.google.android.geo.api_key


注意:google places api每天的请求限制为1000次。之后你必须付钱。最好避免PlacePicker。

在gradle中添加compile
'com.google.android.gms:play services location:8.1.0'
,我也遇到了同样的问题。确保为Android启用Google Places API,而不仅仅是Places API。“PlacesAPI for Android”将不会显示在API&Auth/API下,因为它还不是一个流行的API。您必须使用API搜索框来搜索它。

这个问题也让我发疯,关于这个问题有很多问题,但没有人帮我。最后,我发现有不同的GooglePlacesAPI,特别是针对Android的。因此,我使用的API密钥只是针对非Android版本

使用此链接生成密钥

可能是您忘记将机器SHA密钥添加到谷歌地图控制台。面对同样的问题,将我的SHA密钥添加到控制台后,它开始正常工作。

我在控制台的API&Auth中填写了同意屏幕及其正常工作。检查屏幕截图。
奇怪的是,这对我来说是一个凭证问题。在调试模式下,它甚至可以在没有警告的情况下工作,但是当我使用我的应用程序的发布版本时,它就不能工作了(我已经注册了我的发布和调试sha1密钥),所以我取消了所有限制,现在它可以工作了。

在我的例子中,存在API冲突。我添加了google-service.json文件,该文件也有API密钥,我为地图生成了新密钥。所以那个地方拾荒者马上就要关门了。 解决方案:

  • 使用google-service.json文件中的单个API密钥

  • 为您的Google云平台项目启用“Places SDK for Android”功能(使用与Firebase项目相同的名称,不要使用不同的项目。您将发现与Firebase项目相同的名称)

  • android应用程序的Put SHA1应用程序限制(推荐)
  • 检查是否仅在应用程序标记中放置了以下代码

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

  • 我把这个放在这里,也许它对将来的人有帮助

    对我来说,使用错误的Api键导致了崩溃,尽管它在过去工作得很好


    我不得不使用第二个键(Google services for Android自动创建的键),而不是我创建的第一个键。

    在我的例子中,当我用
    Google service.json
    中的键更改当前API键时,解决了问题

    在google-services.json中:

     "api_key": [
            {
              "current_key": "PASTE THIS API KEY TO THE MANIFEST"
            }
          ]
    

    PlacePicker
    现在已被正式弃用

    我试图完成Udacity高级Android应用程序开发课程,但遇到了同样的问题。 说

    地点选择器在2019年1月29日被弃用。它被关掉了 2019年7月29日,不再提供。继续使用将 导致错误消息。新SDK不支持该位置 选择器


    交叉发布到

    现在正式不推荐PlacePicker

    试试这个图书馆。重量轻,类似于placepicker,具有一些附加功能


    我做了双重检查,以确保API密钥关联与我的应用程序正确无误。我现在添加了发布证书,但没有任何区别。我也在你的mani中看到了
     "api_key": [
            {
              "current_key": "PASTE THIS API KEY TO THE MANIFEST"
            }
          ]