Android - 尝试使用 mGeoDataClient.getPlaceById(id) 从任务中获取 PlaceBufferResponse,但失败了

Android - Trying to get a PlaceBufferResponse from a Task using mGeoDataClient.getPlaceById(id), but failed

我试图在 Android 中使用 Google 的 GeoDataClient 使用 Android studio 获取地点信息。 具体来说,我已经设置了一个 OnPoiClicklistener,因此当单击一个兴趣点时,会显示一个标记,并出现一个 InfoWindow 以显示详细信息。为了获取详细信息,我使用了 GeoDataClient 的 getPlaceById(id) 方法。如下图:

Task<PlaceBufferResponse> placeBufferResponseTask = mGeoDataClient.getPlaceById(mPlaceId);
placeBufferResponseTask.addOnCompleteListener(new OnCompleteListener<PlaceBufferResponse>() {
    @Override
    public void onComplete(@NonNull Task<PlaceBufferResponse> task) {
        try {
            PlaceBufferResponse bufferResponse = task.getResult();
            final Place resultPlace = bufferResponse.get(0);

            placeName.setText(resultPlace.getName());
            placeType.setText(resultPlace.getPlaceTypes().get(0));
            placeAddress.setText(resultPlace.getAddress());


            bufferResponse.release();
            } catch (RuntimeException e) {
                Log.e(TAG, "Place query did not complete.", e);
            }
        }

然而,我总是得到一个错误,logcat如下所示:

12-16 10:31:22.735 7218-7218/com.justinlee.whichpay E/MapsActivity:地点查询未完成。 com.google.android.gms.tasks.RuntimeExecutionException: com.google.android.gms.common.api.ApiException: 13: 错误 在 com.google.android.gms.tasks.zzn.getResult(来源不明) 在 com.justinlee.whichpay.MapsActivity$5.onComplete(MapsActivity.java:363) 在 com.google.android.gms.tasks.zzf.run(来源不明) 在 android.os.Handler.handleCallback(Handler.java:751) 在 android.os.Handler.dispatchMessage(Handler.java:95) 在 android.os.Looper.loop(Looper.java:154) 在 android.app.ActivityThread.main(ActivityThread.java:6119) 在 java.lang.reflect.Method.invoke(本机方法) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776) 原因:com.google.android.gms.common.api.ApiException: 13: 错误 在 com.google.android.gms.common.internal.zzb.zzy(来源不明) 在 com.google.android.gms.common.internal.zzbk.zzz(来源不明) 在 com.google.android.gms.common.internal.zzbl.zzr(来源不明) 在 com.google.android.gms.common.api.internal.zzs.zzc(来源不明) 在 com.google.android.gms.common.api.internal.zzs.setResult(来源不明) 在 com.google.android.gms.location.places.zzm.zzar(来源不明) 在 com.google.android.gms.location.places.internal.zzx.onTransact(来源不明) 在 android.os.Binder.execTransact(Binder.java:565)

问题好像出在加粗的那一行,参考了

PlaceBufferResponse bufferResponse = task.getResult();

来自代码。谁能帮忙?非常感谢!

您正在使用以下语句从后台线程修改 UI:

placeName.setText(resultPlace.getName());
placeType.setText(resultPlace.getPlaceTypes().get(0));
placeAddress.setText(resultPlace.getAddress());

如果你想这样做,你需要使用处理程序将修改操作排队到 UI 线程,完整代码如下所示:

placeBufferResponseTask.addOnCompleteListener(new OnCompleteListener<PlaceBufferResponse>() {
        @Override
        public void onComplete(@NonNull Task<PlaceBufferResponse> task) {
            try {
                PlaceBufferResponse bufferResponse = task.getResult();
                final Place resultPlace = bufferResponse.get(0);

                Handler mainHandler = new Handler(Looper.getMainLooper());

                Runnable myRunnable = new Runnable() {
                    @Override
                    public void run() {
                        placeName.setText(resultPlace.getName());
                        placeType.setText(resultPlace.getPlaceTypes().get(0));
                        placeAddress.setText(resultPlace.getAddress());
                    }
                };
                mainHandler.post(myRunnable);

                bufferResponse.release();
            } catch (RuntimeException e) {
                Log.e(TAG, "Place query did not complete.", e);
            }

    }

或者您可以使用 activity 的方法 runOnUiThread