Android Place Picker在发布后立即关闭
作为一个项目的一部分,我正在开发一个android应用程序,并使用GooglePlacesAPI根据位置显示感兴趣的地点。我正在使用PlacePicker构建器来完成此任务 但是,当应用程序运行时,位置选择器会启动,然后立即关闭(约1-2秒) 我已经实施了以下建议(我从其他答案中得到): 我已经为android应用程序生成了公共API密钥,并将其包含在应用程序清单的元数据标记中 我已经在开发者控制台上启用了“Google Places API for android”API 我已经在build.gradle的dependencies中包含了最新的play services版本 我已经在下面包括了我的代码和日志。如果我需要包括任何其他内容,请务必告诉我 Manifest.xml: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.
<?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_key和com.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"
}
]