Android视图切换动画库SwitchLayout的简单使用

本文介绍了Android视图切换动画库SwitchLayout的使用方法,包括如何配置和导入库,以及如何通过实现SwichLayoutInterFace接口来设置进入和退出动画。SwitchLayout提供了丰富的动画效果,如滑入滑出、3D反转、淡入淡出和抖动等,为应用的UI交互增添动态效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SwitchLayout是一个第三方的视图切换开源库,提供了15种基本切换动画,8种扩展切换动画,可以组合成105种特效,适用于activity和View


  • 配置:在github上有开源库文件下载或者直接在网上找打包好的jar文件,导入到新建的工程里面
  • 使用:一种是直接在代码里使用SwitchLayout.来配置各种动画,像下面这样
    SwitchLayout.getSlideFromLeft(this, false, BaseEffects.getBounceEffect());
    另一种推荐使用方式是,让需要使用切换动画的类实现SwichLayoutInterFace这个接口,类似于这样
    public class Login extends Activity implements SwichLayoutInterFace
    然后在代码里需要实现俩个方法
    @Override
        public void setEnterSwichLayout() {
            //设置的是进入时的动画效果
            SwitchLayout.getSlideFromLeft(this, false, BaseEffects.getBounceEffect());
        }
    
        @Override
        public void setExitSwichLayout() {
            //设置的是退出时的动画效果,如果设置的是activity的退出动画,第二个参数应该为true
            SwitchLayout.getSlideToLeft(this, true, BaseEffects.getQuickToSlowEffect());
        }
    在需要设置动画的地方引用这俩个方法就行,比如在activity的oncreat()方法里
    protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_login);
            
            setEnterSwichLayout();
    }

  • 说明:动画效果基本上可以分为滑入滑出
    <span style="white-space:pre">	</span>//从左边滑出效果
            SwitchLayout.getSlideFromLeft(this, false, BaseEffects.getBounceEffect());
            //从右边滑出效果
            SwitchLayout.getSlideFromRight();
            //从底部滑出效果
            SwitchLayout.getSlideFromBottom();
            //从顶部滑出效果
            SwitchLayout.getSlideFromTop();
    这几种效果需要设置三个参数,第一个是目标activity或者view,第二个参数指定动画效果之后是否关闭activity,第三个参数指定扩展动画效果,可以为null。对应的滑出动画效果为
    <span style="white-space:pre">	</span>//滑出到左边
            SwitchLayout.getSlideToLeft(this, true, BaseEffects.getQuickToSlowEffect());
            //滑出到右边
            SwitchLayout.getSlideToRight();
            //滑出到底部
            SwitchLayout.getSlideToBottom();
            //滑出到顶部
            SwitchLayout.getSlideToTop();
    3D反转动画效果,参数和上面的滑入滑出一样
    <span style="white-space:pre">	</span>//从左向右反转
            SwitchLayout.get3DRotateFromLeft(this, false, null);
            //从右向左反转
            SwitchLayout.get3DRotateFromLeft(this, false, null);
    淡入淡出效果
    <span style="white-space:pre">	</span>//淡入效果,只有一个参数指定目标activity或view
            SwitchLayout.getFadingIn(this);
            //淡出效果,只有一个参数指定目标activity或view
            SwitchLayout.getFadingIn(this);
    以及切换之后视图会抖动的效果
    <span style="white-space:pre">	</span>//抖动效果,第四个参数指定抖动次数
            SwitchLayout.getShakeMode(this, false, null, 5);

还有没提到的动画效果及在view上的使用请自行尝试。
    

    


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值