2

aos 2.x (2.2.2、2.3.5 など) では問題なく動作するウィンドウ ポップアップ クラスがありますが、aos 4.x ではクラッシュします。クラッシュの原因となるコードは次のとおりです。

public void dismissPopup(){
    if (!isVisible)
        return;
    isVisible = false;

    final Animation animation = AnimationUtils.loadAnimation(activity, R.anim.popup_hide);
    animation.setAnimationListener(new AnimationListener() {
        public void onAnimationEnd(final Animation animation) {
            // The animation has ended
            popupWindow.dismiss();
        }
        public void onAnimationRepeat(final Animation animation) {}
        public void onAnimationStart(final Animation animation) {}
    });
    popupView.startAnimation(animation);
}

aos 4.x で動作させるには、2b があるように、すべてのアニメーション行にコメントを付ける必要があります。

public void dismissPopup(){
    if (!isVisible)
        return;
    isVisible = false;

    popupWindow.dismiss();
}

これは aos 4.1.x では問題なく動作しますが、アニメーションは提供されません。ここで何が問題になる可能性がありますか? アンドロイドは後方互換性を提供すべきではありませんか?
クラッシュログ

04-25 21:05:50.387: E/AndroidRuntime(8997): FATAL EXCEPTION: main
04-25 21:05:50.387: E/AndroidRuntime(8997): java.lang.NullPointerException
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.ViewRootImpl.drawAccessibilityFocusedDrawableIfNeeded(ViewRootImpl.java:2301)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.ViewRootImpl.onHardwarePostDraw(ViewRootImpl.java:1931)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.HardwareRenderer$GlRenderer.draw(HardwareRenderer.java:1182)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.ViewRootImpl.draw(ViewRootImpl.java:2147)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.ViewRootImpl.performDraw(ViewRootImpl.java:2019)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1830)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:998)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:4212)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.Choreographer$CallbackRecord.run(Choreographer.java:736)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.Choreographer.doCallbacks(Choreographer.java:566)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.Choreographer.doFrame(Choreographer.java:536)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:722)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.os.Handler.handleCallback(Handler.java:615)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.os.Handler.dispatchMessage(Handler.java:92)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.os.Looper.loop(Looper.java:137)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at android.app.ActivityThread.main(ActivityThread.java:4745)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at java.lang.reflect.Method.invokeNative(Native Method)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at java.lang.reflect.Method.invoke(Method.java:511)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:786)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
04-25 21:05:50.387: E/AndroidRuntime(8997):     at dalvik.system.NativeStart.main(Native Method)

UPD:アニメーションは aos 4.0.3 で動作しますが、4.1.1 でクラッシュします

4

1 に答える 1

3

そのばかげていますが、私が見つけた回避策は次のとおりです。

animation.setAnimationListener(new AnimationListener() {
    public void onAnimationEnd(final Animation animation) {
        // The animation has ended
        new Handler().post(new Runnable() {
            @Override
            public void run() {
                popupWindow.dismiss();
            }
        });
    }
    public void onAnimationRepeat(final Animation animation) {}
    public void onAnimationStart(final Animation animation) {}
});

なぜこれが役立つのか、なぜ 4.1.1 でこれがないと機能しないのか想像もつきません...

于 2013-04-25T19:18:15.583 に答える