[skmaps][android] Ущипнуть, чтобы увеличить приложение вылетает

Я только начал оценивать scobbler/scout для проекта и столкнулся с проблемой.

Я настроил одно действие для отображения карты с помощью Skobbler SDK 2.3.0 на Android, API уровня 18 (IDE=Android Studio 1.0.2). Карта отображается и может быть панорамирована, но масштабирование всегда убивает приложение сразу со следующей ошибкой:

java.lang.NullPointerException
        at com.skobbler.ngx.map.MapRenderer.a(SourceFile:886)
        at com.skobbler.ngx.map.SKMapSurfaceView.onTouchEvent(SourceFile:637)
        at android.view.View.dispatchTouchEvent(View.java:7817)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2441)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2174)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2441)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2174)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2441)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2174)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2441)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2174)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2441)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2174)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2441)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2174)
        at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:2441)
        at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2174)
        at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:2326)
        at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1612)
        at android.app.Activity.dispatchTouchEvent(Activity.java:2494)
        at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:2274)
        at android.view.View.dispatchPointerEvent(View.java:8025)
        at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:4668)
        at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:4556)
        at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4150)
        at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:4207)
        at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:4176)
        at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:4261)
        at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:4184)
        at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:4318)
        at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4150)
        at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:4207)
        at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:4176)
        at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:4184)
        at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:4150)
        at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:6302)
        at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:6240)
        at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:6211)
        at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:6382)
        at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:188)
        at android.view.InputEventReceiver.nativeConsumeBatchedInputEvents(Native Method)
        at android.view.InputEventReceiver.consumeBatchedInputEvents(InputEventReceiver.java:177)
        at android.view.ViewRootImpl.doConsumeBatchedInput(ViewRootImpl.java:6355)
        at android.view.ViewRootImpl$ConsumeBatchedInputRunnable.run(ViewRootImpl.java:6401)
        at android.view.Choreographer$CallbackRecord.run(Choreographer.java:791)
        at android.view.Choreographer.doCallbacks(Choreographer.java:591)
        at android.view.Choreographer.doFrame(Choreographer.java:559)
        at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:777)
        at android.os.Handler.handleCallback(Handler.java:730)
        at android.os.Handler.dispatchMessage(Handler.java:92)
        at android.os.Looper.loop(Looper.java:176)
        at android.app.ActivityThread.main(ActivityThread.java:5419)
        at java.lang.reflect.Method.invokeNative(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:525)
        at com.android.internal.os.Z

На данный момент все инициализация и отображение выполняются в одном действии. Метод onCreate():

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    mapResDirPath = getFilesDir() + "/" + "SKMaps";

    Log.i(TAG, "Preparing maps in " + mapResDirPath);
    final SKPrepareMapTextureThread prepThread = new SKPrepareMapTextureThread(this, mapResDirPath, "SKMaps.zip", this);
    prepThread.start();

    while (!mapsPrepared) {
        Common.sleep(100);
    }

    Log.i(TAG, "Maps have been prepared. Continuing");
    SKMapsInitSettings settings = new SKMapsInitSettings();
    //settings.setMapResourcesPaths(mapResDirPath, new SKMapViewStyle(mapResDirPath + "daystyle/", "daystyle.json"));
    settings.setMapResourcesPaths(mapResDirPath, new SKMapViewStyle(mapResDirPath + "/daystyle/", "daystyle.json"));


    final SKAdvisorSettings advisorSettings = settings.getAdvisorSettings();
    advisorSettings.setLanguage("en");
    advisorSettings.setAdvisorVoice("en");
    settings.setAdvisorSettings(advisorSettings);

    SKMaps.getInstance().initializeSKMaps(this, settings, "<my api key>");

    setContentView(R.layout.activity_skobbler);
    SKMapViewHolder mapViewGroup  = (SKMapViewHolder)findViewById(R.id.skobbler_main_map);
    mapViewGroup.setScaleViewEnabled(true);
    mapView = mapViewGroup.getMapSurfaceView();

    mapView.getMapSettings().setMapZoomingEnabled(true);
    mapView.setPositionAsCurrent(new SKCoordinate(-33.0, 18.0), 1.0f, true);
}

В качестве теста я реализовал SKPrepareMapTextureListener, SKMapSurfaceListener и SKMapUpdateListener, но ошибка по-прежнему сохраняется.

Любая помощь будет оценена.

1 ответ

Не берите в голову. Я только что понял, что реализовал SKMapSurfaceListener, но никогда не вызывал SKMapSurfaceView.setMapSurfaceListener()

Другие вопросы по тегам