Fragment中动画异常

Fragment中动画异常

1.FragmentA界面有动画效果,transaction.add()方式切换到其他FragmentB后,FragmentA只是hidden且并未销毁。

2.FragmentA仍然能接收到事件(广播),并对事件处理。

3.如接收到事件开始启动动画,动画监听器并未监听到动画执行,而是FragmentB切换回FragmentA后,FragmentA才迟迟执行动画,引发逻辑异常。

动画的引用方法(llConfigOpen为执行动画的View)

//引入动画文件
outAnimation = AnimationUtils.loadAnimation(getActivity(), R.anim.slide_top_out);
outAnimation.reset();//动画重置
outAnimation.setAnimationListener(new Animation.AnimationListener() {    
 @Override    public void onAnimationStart(Animation animation){            }    @Override    public void onAnimationEnd(Animation animation){    }   
 @Override    public void onAnimationRepeat(Animation animation){    }});

 LogUtils.d(TAG, "llConfigOpen close now");
 llConfigOpen.clearAnimation();//清除动画
 llConfigOpen.startAnimation(outAnimation);//启动动画

解决方案1:

接收到事件或广播,启动动画前先判断当前Fragment是否显示,如显示才启动动画。

public synchronized void closeConfigView() {
    //当前页面隐藏不启动动画,引发异常
    if (isHidden()){
        LogUtils.e(TAG,"当前Fragment未显示,不进行动画绘制");
        return;
    }
    
    xxx
    llConfigOpen.startAnimation(outAnimation);//启动动画
}

解决方案2:

Fragment切换不使用add()方式,改为replace()方式。

A powerful library that manage Fragment for Android!为"单Activity + 多Fragment","多模块Activity 多Fragment"架构而生,简化开发,轻松解决动画、嵌套、事务相关等问题。为了更好的使用和了解该库,推荐阅读下面的文章:Fragment全解析系列(一):那些年踩过的坑Fragment全解析系列(二):正确的使用姿势Demo演示:均为单Activity 多Fragment,第一个为简单流式demo,第二个为仿微信交互的demo(全页面支持滑退出),第三个为仿知乎交互的复杂嵌套demo下载APK   特性1、可以快速开发出各种嵌套设计的Fragment App2、悬浮球/摇一摇实时查看Fragment的栈视图Dialog,降低开发难度3、增加启模式、startForResult等类似Activity方法4、类似Android事件分发机制的Fragment回退方法:onBackPressedSupport(),轻松为每个Fragment实现Back按键事件5、提供onSupportVisible()等生命周期方法,简化嵌套Fragment的开发过程; 提供统一的onLazyInitView()懒加载方法6、提供 Fragment转场动画 系列解决方案,态更换动画7、提供Activity作用域的EventBus辅助类,Fragment通信更简单、独立(需要使用EventBusActivityScope库)8、支持SwipeBack滑边缘退出(需要使用Fragmentation_SwipeBack库)      如何使用1. 项目下app的build.gradle中依赖:// appcompat-v7包是必须的,v1.1.9兼容v4-27.0.0 compile 'me.yokeyword:fragmentation:1.1.9' // 如果不想继承SupportActivity/Fragment,自己定制Support,可仅依赖: // compile 'me.yokeyword:fragmentation-core:1.1.9' // 如果想使用SwipeBack 滑边缘退出Fragment/Activity功能,完整的添加规则如下: compile 'me.yokeyword:fragmentation:1.1.9' // swipeback基于fragmentation, 如果是自定制SupportActivity/Fragment,则参照SwipeBackActivity/Fragment实现即可 compile 'me.yokeyword:fragmentation-swipeback:1.1.9' // Activity作用域的EventBus,更安全,可有效避免after onSavenInstanceState()异常 compile 'me.yokeyword:eventbus-activity-scope:1.1.0' // Your EventBus's version compile 'org.greenrobot:eventbus:{version}'2. Activity继承SupportActivity:// v1.0.0开始,不强制继承SupportActivity,可使用接口+委托形式来实现自己的SupportActivity public class MainActivity extends SupportActivity {     @Override     protected void onCreate(Bundle savedInstanceState) {         super.onCreate(savedInstanceState);         setContentView(...);         // 建议在Application里初始化         Fragmentation.builder()              // 显示悬浮球 ; 其他Mode:SHAKE: 摇一摇唤出   NONE:隐藏              .stackViewMode(Fragmentation.BUBBLE)              .debug(BuildConfig.DEBUG)              ... // 更多查看wiki或demo              .install();         if (findFragment(HomeFragment.class) == null)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值