Android AOS 4.x动画崩溃问题

Android AOS 4.x动画崩溃问题,android,animation,Android,Animation,我有一个窗口弹出类,它在AOS2.x中运行良好(如2.2.2、2.3.5等),但在AOS4.x中崩溃。导致崩溃的代码如下所示: public void dismissPopup(){ if (!isVisible) return; isVisible = false; final Animation animation = AnimationUtils.loadAnimation(activity, R.anim.popup_hide); ani

我有一个窗口弹出类,它在AOS2.x中运行良好(如2.2.2、2.3.5等),但在AOS4.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中运行良好,但不提供动画。这里可能有什么问题?android不应该提供任何向后兼容性吗?
坠机日志

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中崩溃

我发现它很愚蠢,但解决方法是:

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中没有它会有帮助,为什么它不起作用…

堆栈溢出俱乐部的第一条规则:如果你的应用程序崩溃,发布你的日志(并将人们指向特定的行号).我在崩溃日志中没有看到任何指向我的代码的链接,所以我忘记了…可能是
R.anim.popup\u hide
没有被您定义,而是您在那里使用了Android动画吗?也许Android 4上已经出现了这种情况?不,它在我的res/anim文件夹中。在4.1.1
drawAccessibilityFocusedDrawableIf needed
中只有很少的东西可以抛出NPE。实际上,只有一个。可能是
manager=AccessibilityManager.getInstance(mView.mContext)失败。也许这整个可访问性的东西不能很好地处理混乱的
Context
s。也许您想在代码中用
popupWindow.getContextView().getContext()
替换
activity
,以协调动画的上下文和动画弹出窗口的上下文。也许安卓4在这方面很挑剔。如果不是这样的话,那么整个可访问性主题都必须考虑一下……你救了我一天。在微调器项目上应用动画时遇到相同问题。非常感谢您的解决方案。