安卓:Nexus 5上的grpc失败

10
我正在使用geocoder。在所有设备上,代码都能正常工作,但在Nexus 5手机上,日志中会出现异常。

我的代码:

override fun fromAddress(address: Address): Observable<Geolocation> {
    val location = geocoder.getFromLocationName("${address.street} ${address.number}, ${address.postcode}, ${address.city}", LOCATIONS_MAX_RESULTS).first()
    return Observable.just(Geolocation(latitude = location.latitude, longitude = location.longitude))
}

我的错误:

java.io.IOException: grpc failed
  at android.location.Geocoder.getFromLocationName(Geocoder.java:178)
  at nl.ah.appienow.data.address.AndroidGeocoder.fromAddress(AndroidGeocoder.kt:20)
  at nl.ah.appienow.address.ValidatePostcode$execute$1.apply(ValidatePostcode.kt:31)
  at nl.ah.appienow.address.ValidatePostcode$execute$1.apply(ValidatePostcode.kt:17)
  at io.reactivex.internal.operators.observable.ObservableFlatMap$MergeObserver.onNext(ObservableFlatMap.java:121)
  at io.reactivex.internal.operators.observable.ObservableMap$MapObserver.onNext(ObservableMap.java:64)
  at retrofit2.adapter.rxjava2.BodyObservable$BodyObserver.onNext(BodyObservable.java:51)
  at retrofit2.adapter.rxjava2.BodyObservable$BodyObserver.onNext(BodyObservable.java:37)
  at retrofit2.adapter.rxjava2.CallExecuteObservable.subscribeActual(CallExecuteObservable.java:43)
  at io.reactivex.Observable.subscribe(Observable.java:10842)
  at retrofit2.adapter.rxjava2.BodyObservable.subscribeActual(BodyObservable.java:34)
  at io.reactivex.Observable.subscribe(Observable.java:10842)
  at io.reactivex.internal.operators.observable.ObservableMap.subscribeActual(ObservableMap.java:33)
  at io.reactivex.Observable.subscribe(Observable.java:10842)
  at io.reactivex.internal.operators.observable.ObservableFlatMap.subscribeActual(ObservableFlatMap.java:55)
  at io.reactivex.Observable.subscribe(Observable.java:10842)
  at io.reactivex.internal.operators.observable.ObservableSubscribeOn$SubscribeTask.run(ObservableSubscribeOn.java:96)
  at io.reactivex.Scheduler$DisposeTask.run(Scheduler.java:452)
  at io.reactivex.internal.schedulers.ScheduledRunnable.run(ScheduledRunnable.java:61)
  at io.reactivex.internal.schedulers.ScheduledRunnable.call(ScheduledRunnable.java:52)
  at java.util.concurrent.FutureTask.run(FutureTask.java:237)
  at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:269)
  at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1113)
  at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:588)
  at java.lang.Thread.run(Thread.java:818)

我到处都看到解决方案是重新安装Android Studio或更新Android Studio,但这对我没有用。


你使用的是哪个版本的playservices? Nexus 5运行的是哪个Android版本? 其他测试设备是否安装了相同的Android版本? - W3hri
日志中只有这一个异常吗?没有原因异常吗? - kichik
2个回答

0

我遇到了在Nexus 5X上出现的相同问题,原因是使用了VPN。


0

当我从纬度和经度获取地址时,遇到了相同的问题。我使用模拟器和另一个卡车屏幕设备。在这两个设备上都出现了同样的问题,GRPC失败了。但是当我在我的手机和另一个三星设备上运行这段代码时,它完美地工作了。我必须在那个卡车屏幕设备上运行它。所以我找到了一个解决方案,就是使用Google地图位置API从纬度和经度获取位置。

String url = "https://maps.googleapis.com/maps/api/geocode/json?latlng="+log.getLattitude()+","+log.getLongitude()+"&key="+context.getResources().getString(R.string.geocodeAPiKey);

或者简单地说

String url = "https://maps.googleapis.com/maps/api/geocode/json?latlng=33.25845,75.256489&key=API_KEY;

您可以像搜索反向地理编码一样进行搜索

通过此链接,您可以获取地理编码API密钥

https://developers.google.com/maps/documentation/geocoding/get-api-key

在结果中,您将获得一个JSONObject。从JSONArray中获取其第一个元素,并像这样从中获取地址。
    JSONObject info = new JSONObject(result);
    JSONObject locationInfo = info.getJSONArray("results").getJSONObject(0);
    String locationDescription = locationInfo.getString("formatted_address");

这是反向地理编码。如果你想进行简单的地理编码,它几乎和这个一样。我有反向地理编码代码,所以我与你分享了它。
如需更多帮助和支持,请访问此链接 Google Geocoding API

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接