若是本文帮助到你,本人不胜荣幸,若是浪费了你的时间,本人深感抱歉。 但愿用最简单的大白话来帮助那些像我同样的人。若是有什么错误,请必定指出,以避免误导你们、也误导我。 本文来自:www.jianshu.com/users/320f9… 感谢您的关注。git
前段时间偶然看到一个使用 ViewFlipper 实现图片轮播的。 我认可,以前我是没有听过 ViewFlipper 这个东西的。那么我脑海中就出现了一个问题:ViewFlipper 是个什么东西?为何继承它能实现图片的轮播。而后有了以后的探索,咱们一块儿来看看。github
在 studio 中 F4 查看层级关系,通过一番寻找以后有了下图。 呦呵,看到了熟人。ViewFlipper 我没见过,可是我见过 TextSwitcher 和 ImageSwitcher 啊,他两都是内容改变时有个动画的效果。ide
首先看上图最右边的层级关系,经过 ViewFlipper 找到了 TextSwitcher 和ImageSwitcher 。他们有一个共同的父类 ViewAnimator ,也就是说他们确定是有关联的,并且应该是很相近。动画
既然 TextSwitcher 和 ImageSwitcher ,咱们认识,那么咱们就小小的分析一下这两个类。他两提供的功能基本相同,只不过一个针对文字,一个对图片。这两个类自己也是很是简单,提供的方法在左边的目录能够看到,还有一些在父类里。this
由于类自己比较简单,因此类里面的代码也没有多少。 咱们看中间的代码窗口,除了构造器剩余的方法一目了然。 能够发现,最终都是调用了 showNext() 显示切换后的内容,而 showNext() 是由他们的共同父类 ViewAnimator 执行的,而 ViewAnimator 自己就是一个管理动画的类。spa
也就是说,咱们今天的主角 ViewFlipper 最终应该也是调用 showNext() 来执行动画的。 那 ViewFlipper 跟他们到底有什么区别呢? 咱们来看下面的图,对 ViewFlipper 的分析。code
这个咱们以前已经看过了。cdn
能够看到最左边的目录明显比上面要多不少东西(其实上面两个是有个父类帮他们分担了,可是这个功能仍是比他多(^__^))。blog
那最根本的区别究竟是什么呢? 看中间的内容,咱们就发现,在这个类当中是有个 Handler Message 存在的。也就是说咱们能够设置定时播放动画,也正是基于此,该类才比上面多了一些功能。 开始、结束动画,是否自动播放,间隔时间,都是上面的所不具有的。继承
这样一波看下来,咱们大概就知道了 ViewFlipper 为何能用来实现轮播了。
那 ViewFlipper 到底该怎么使用呢?
嗯....... 仍是直接上代码吧,注释很详细一目了然。
private void setViewFlipper() {
mViewFlipper = (ViewFlipper) findViewById(R.id.flipper);
//添加要滚动的View
mViewFlipper.addView(getImageView(R.drawable.abcde_a));
mViewFlipper.addView(getImageView(R.drawable.abcde_b));
mViewFlipper.addView(getImageView(R.drawable.abcde_c));
//设置开始和结束动画
mViewFlipper.setInAnimation(this, R.anim.push_up_in);
mViewFlipper.setOutAnimation(this, R.anim.push_up_out);
//设置间隔时间
mViewFlipper.setFlipInterval(3000);
//动画的监听
mViewFlipper.getInAnimation().setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {
//动画开始时
}
@Override
public void onAnimationEnd(Animation animation) {
//动画结束时
}
@Override
public void onAnimationRepeat(Animation animation) {
//重复
}
});
//开始轮播
mViewFlipper.startFlipping();
}
private ImageView getImageView(int res) {
ImageView imageView = new ImageView(this);
imageView.setBackgroundResource(res);
return imageView;
}
复制代码
有了 setInAnimation() 、 setOutAnimation(),这两个方法的存在,咱们就能够设置各类各样的本身想要的动画效果,而其他提供的方法,更是让咱们很是方便的控制动画。有没有以为很不错呢?
你有没有什么好的想法? 能够本身去动手实践看看。
setInAnimation 设置View进入屏幕时候使用的动画
setOutAnimation 设置View退出屏幕时候使用的动画
showPrevious 显示ViewFlipper里面的上一个View
showNext 显示ViewFlipper里面的下一个View
setFlipInterval 设置View之间切换的时间间隔
startFlipping 使用setFlipInterval方法设置的时间间隔来开始切换全部的View,切换会循环进行
stopFlipping 中止View切换
isFlipping 用来判断View切换是否正在进行
setDisplayedChild 切换到指定子View
复制代码
以前在群里,听到有人问:已经有 ViewPager 了,ViewFlipper还有没有存在的必要? 看完本篇以后,还有没有这样的疑问? ViewFlipper 是为了动画而生的,可是 ViewPager 呢?
好了,本篇就到这里。 O(∩_∩)O