【发布时间】:2017-04-06 21:07:48
【问题描述】:
我正在尝试制作一个位置感知的商业搜索应用。为此,我使用 Google Places Api,特别是 Places.GEO_DATA_API 和 LocationServices.API。这个想法是用户可以使用他们当前的位置或使用自动完成搜索来输入地址。我的问题是我认为调用onConnected() 时这两个api 混淆了,因为我不断收到此错误:
E/AndroidRuntime: FATAL EXCEPTION: main
Process: edu.depaul.csc472.coffeeshoplocator, PID: 9420
java.lang.IllegalStateException: GoogleApiClient is not connected yet.
at com.google.android.gms.internal.zzrb.zzb(Unknown Source)
at com.google.android.gms.internal.zzrf.zzb(Unknown Source)
at com.google.android.gms.internal.zzrd.zzb(Unknown Source)
at com.google.android.gms.location.internal.zzd.requestLocationUpdates(Unknown Source)
at edu.depaul.csc472.coffeeshoplocator.MainActivity.startLocationUpdates(MainActivity.java:233)
at edu.depaul.csc472.coffeeshoplocator.MainActivity.getLocation(MainActivity.java:241)
at edu.depaul.csc472.coffeeshoplocator.MainActivity.onConnected(MainActivity.java:263)
at com.google.android.gms.common.internal.zzk.zzp(Unknown Source)
at com.google.android.gms.internal.zzrd.zzn(Unknown Source)
at com.google.android.gms.internal.zzrb.zzass(Unknown Source)
at com.google.android.gms.internal.zzrb.onConnected(Unknown Source)
at com.google.android.gms.internal.zzrf.onConnected(Unknown Source)
at com.google.android.gms.internal.zzqr.onConnected(Unknown Source)
at com.google.android.gms.common.internal.zzj$1.onConnected(Unknown Source)
at com.google.android.gms.common.internal.zze$zzj.zzavj(Unknown Source)
at com.google.android.gms.common.internal.zze$zza.zzc(Unknown Source)
at com.google.android.gms.common.internal.zze$zza.zzv(Unknown Source)
at com.google.android.gms.common.internal.zze$zze.zzavl(Unknown Source)
at com.google.android.gms.common.internal.zze$zzd.handleMessage(Unknown Source)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6077)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:865)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)
它只是偶尔发生。除了这次崩溃之外,我已经成功运行了该程序,没有任何意外行为。
构建api的代码如下:
protected synchronized void buildGoogleApiClient(){
mGoogleApiLocation = new GoogleApiClient.Builder(this)
.addConnectionCallbacks(this)
.addOnConnectionFailedListener(this)
.addApi(LocationServices.API)
.build();
mGoogleApiAutoComplete = new GoogleApiClient.Builder(this)
.addApi(Places.GEO_DATA_API)
.enableAutoManage(this,GOOGLE_API_CLIENT_ID,this)
.addConnectionCallbacks(this)
.build();
}
这是我的onConnected() 方法,它向用户请求访问精细位置的权限,然后尝试获取用户的位置:
@Override
public void onConnected(Bundle bundle) {
requestForSpecificPermission();
getLocation();
placeArrayAdapter.setGoogleApiClient(mGoogleApiAutoComplete);
}
...还有我的getLocation() 方法:
private void getLocation(){
try {
location = LocationServices.FusedLocationApi.getLastLocation(mGoogleApiLocation);
if (location == null) {
LocationServices.FusedLocationApi.requestLocationUpdates(mGoogleApiLocation, locationRequest, this);
}
else{
handleNewLocation(location);
}
}catch (SecurityException e){
Toast.makeText(getApplicationContext(),
"You don't have permission!", Toast.LENGTH_LONG)
.show();
}
}
我的好奇心是一:如果根据我的理解你必须连接到电话onConnected(),我怎么会得到这个错误,二:为什么这只发生在某些时候。首先是否允许有多个客户端,或者如果不允许,您如何在同一个活动中使用两种不同的技术 (api)?
【问题讨论】:
标签: java android google-maps-api-3 google-play-services google-places-api