here-api - java.lang.RuntimeException:无法创建地图:无法读取配置文件:
问题描述
我正在为 Android 应用程序实现 HERE 地图,我在 HERE 地图 SDK 中不断崩溃,并出现以下错误
Process: my.app.package, PID: 30682
java.lang.RuntimeException: Cannot create map: Failed to read configuration file: /data/user/0/my.app.package/files/.here-maps/someid/mwconfig_client
at com.nokia.maps.MapImpl.<init>(MapImpl.java:451)
at com.here.android.mpa.mapping.Map.<init>(Map.java:710)
at com.nokia.maps.bw.m(MapFragmentImpl.java:546)
at com.nokia.maps.bw.a(MapFragmentImpl.java:583)
at com.nokia.maps.bw.a(MapFragmentImpl.java:85)
at com.nokia.maps.bw$1.onEngineInitializationCompleted(MapFragmentImpl.java:135)
at com.nokia.maps.MapsEngine$10.run(MapsEngine.java:2471)
at android.os.Handler.handleCallback(Handler.java:790)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:164)
at android.app.ActivityThread.main(ActivityThread.java:6753)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:482)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:807)
它并不总是可重现的,但它发生在 50% 的时间。
我可以在 HERE 地图站点中看到此问题仍然存在,https://github.com/hermaps/here-android-sdk-examples/issues/134
我向 HERE 地图团队寻求帮助,任何解决此问题的方法都会有所帮助。
提前致谢。
解决方案
很可能是您的设备上有另一个使用 SDK 的应用程序,并且这两个应用程序的 MapServices 相互冲突。您可以尝试按照文档( https://developer.here.com/documentation/android-premium/dev_guide/topics/map-service.html)中的描述为您的应用程序设置隔离磁盘缓存
AndroidManifest.xml
<service
android:name="com.here.android.mpa.service.MapService"
android:label="{YOUR_LABEL_NAME}"
android:exported="false">
<intent-filter>
<action android:name="{YOUR_INTENT_NAME}">
</action>
</intent-filter>
</service>
MapActivity.java
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Search for the map fragment to finish setup by calling init().
mapFragment = (MapFragment) getFragmentManager().findFragmentById(R.id.mapfragment);
boolean success = com.here.android.mpa.common.MapSettings.setIsolatedDiskCacheRootPath(
getApplicationContext().getExternalFilesDir(null) + File.separator + ".here-maps",
"{YOUR_INTENT_NAME}");
if (!success) {
// Setting the isolated disk cache was not successful, please check if the path is valid and
// ensure that it does not match the default location
// (getExternalStorageDirectory()/.here-maps).
// Also, ensure the provided intent name does not match the default intent name.
} else {
mapFragment.init(new OnEngineInitListener() {
...
}