`

Android ViewPager切换的N种动画

 
阅读更多
基于上一篇《Android ViewPager使用》http://gqdy365.iteye.com/blog/2114963
本文实现ViewPager切换的7中常用动画,先上效果图:








实现过程:
1、ViewPager有提供一个接口PageTransformer,ViewPager在做页面切换时(onPageScrolled方法)会调用PageTransformer,来调用我们自定义的特效,逻辑关系如图:



2、动画的实现:
从Android3.1开始,View新增了如下方法:
setsetAlpha:透明度变化;
setTranslation:位置变化;
setScale:缩放变化;
setRotation:角度变化;
我们可以用这些方法的组合来实现各种View切换特效;
那是不是说Android3.1之前的版本就没办法使用这些方法呢?当然不是,我们有万能的github,万能的开源项目:https://github.com/JakeWharton/NineOldAndroids
他提供了我们在3.1以下版本实现上述方法的调用,为开源致敬,为共享致敬!!!
下面来看一下例子,立方体效果:
public class CubeTransformer implements PageTransformer {
	
	/**
	 * position参数指明给定页面相对于屏幕中心的位置。它是一个动态属性,会随着页面的滚动而改变。当一个页面填充整个屏幕是,它的值是0,
	 * 当一个页面刚刚离开屏幕的右边时,它的值是1。当两个也页面分别滚动到一半时,其中一个页面的位置是-0.5,另一个页面的位置是0.5。基于屏幕上页面的位置
	 * ,通过使用诸如setAlpha()、setTranslationX()、或setScaleY()方法来设置页面的属性,来创建自定义的滑动动画。
	 */
	@Override
	public void transformPage(View view, float position) {
		if (position <= 0) {
			//从右向左滑动为当前View
			
			//设置旋转中心点;
			ViewHelper.setPivotX(view, view.getMeasuredWidth());
			ViewHelper.setPivotY(view, view.getMeasuredHeight() * 0.5f);
			
			//只在Y轴做旋转操作
			ViewHelper.setRotationY(view, 90f * position);
		} else if (position <= 1) {
			//从左向右滑动为当前View
			ViewHelper.setPivotX(view, 0);
			ViewHelper.setPivotY(view, view.getMeasuredHeight() * 0.5f);
			ViewHelper.setRotationY(view, 90f * position);
		}
	}
}


注释已经很详细了,怎么样,再不需要特别说明了吧!
其他效果类似!

3、使用方法:
只需一句话:
vPage.setPageTransformer(true, new CubeTransformer());

Demo见附件!
  • 大小: 39.1 KB
  • 大小: 30.5 KB
  • 大小: 6.4 MB
  • out.zip (1.7 MB)
  • 下载次数: 1867
分享到:
评论
6 楼 Mr.zhao92 2015-12-18  
楼主,你里面那个ViewHelper类封装是什么啊,看不到源码,可以发发吗?我qq:3060256646
5 楼 u013419611 2015-06-10  
非常好,感谢楼主分享
4 楼 sjf_031030 2015-04-22  
顶赞 真不错,多谢
3 楼 墨绿红晨 2015-03-05  
楼主,样式的最后一页后就会有所有页面的快速退场,这个退场能去了吗?或者慢下速度?
2 楼 gqdy365 2014-09-12  
xiaodatao 写道
楼主,下载下来全是乱码。

兄弟,重新上传了,再试试!公司电脑有加密,搞的什么都是乱码!
1 楼 xiaodatao 2014-09-11  
楼主,下载下来全是乱码。

相关推荐

    Android ViewPager切换的七种动画

    Android ViewPager切换的七种动画,分别是:深入浅出,立方体,旋转,左右折叠,右上角进入,右下角进入和淡入淡出。

    三种ViewPager切换动画

    在本文中,我们将深入探讨ViewPager的切换动画,特别是标题提到的“三种ViewPager切换动画”。首先,我们理解一下ViewPager的基本用法,然后详细讨论如何实现这三种动画效果。 1. **ViewPager基础** ViewPager通常...

    viewpager切换动画与时长控制

    以上就是关于ViewPager切换动画与时长控制的基本知识。在实际开发中,可以根据需求调整`PageTransformer`中的参数,或者结合其他动画库(如Android Animation API或第三方库如NineOldAndroids)实现更多复杂的动画...

    android 自定义酷炫ViewPager切换效果带页面弹性指示器动画

    在本教程中,我们将深入探讨如何创建一个自定义的ViewPager,使其具有酷炫的页面切换动画以及带有弹性效果的页面指示器。 首先,我们需要理解ViewPager的基本工作原理。ViewPager是Android Support Library的一部分...

    android viewpager各种滑动动画

    在Android开发中,ViewPager是一个非常重要的组件,常用于实现页面滑动切换的效果,例如在应用的引导页、图片轮播或者Tab布局中。本篇将深入讲解如何在ViewPager中实现各种自定义滑动动画,以及如何优化性能并保持...

    Android 实现个性的ViewPager切换动画

    本篇将详细介绍如何在Android中创建自定义的ViewPager切换动画。 首先,理解ViewPager的工作原理是至关重要的。ViewPager依赖于PagerAdapter来提供其内容,PagerAdapter需要实现`instantiateItem()`和`destroyItem...

    Android ViewPager多页面滑动切换以及动画效果

    Android ViewPager实现仿QQ多页面滑动切换以及动画效果

    Viewpager切换的各种动画

    在本项目“ViewPager切换的各种动画”中,开发者已经实现了多种视图间的切换动画,包括立体、渐变、淡入淡出等效果,以满足不同场景下的需求。 首先,我们来详细了解一下`ViewPager`的基本概念。`ViewPager`是...

    自定义ViewPager (禁止滑动和去除切换效果)

    自定义ViewPager (禁止滑动和去除切换效果) viewPager.setNoScroll(true);//禁止手动滑动

    Android ViewPager+Fragment超高仿微信主界面(带底部图标切换动画)

    Android ViewPager+Fragment超高仿微信主界面(带底部图标切换动画)Android ViewPager+Fragment超高仿微信主界面(带底部图标切换动画)Android ViewPager+Fragment超高仿微信主界面(带底部图标切换动画)

    Android ViewPager和Fragment 实现滑动切换页面

    在Android应用开发中,`ViewPager`和`Fragment`是两个重要的组件,它们常被结合使用以实现用户界面的滑动切换效果。`ViewPager`提供了一个可以左右滑动查看多个页面的容器,而`Fragment`则作为Activity的部分内容,...

    ViewPager实现的切换动画

    在这个“ViewPager实现的切换动画”项目中,我们将会探讨如何利用ViewPager来实现丰富的页面切换动画,包括但不限于引导动画。 首先,ViewPager的核心功能是显示和切换多个Fragment或View,它可以自动处理用户的...

    超酷炫的ViewPager切换效果和贝塞尔指示器

    通过这种方式,你可以为你的应用添加一个既美观又富有动态感的ViewPager切换效果和贝塞尔指示器。这种技术不仅提高了用户体验,还展示了Android开发中的创新思维。记住,持续优化和调整这些效果,以适应你的应用风格...

    Android Viewpager侧滑切换界面

    在Android开发中,`ViewPager`是一个非常常用的组件,它允许用户通过左右滑动来浏览多个页面,常用于实现Tab切换或者展示多个相关的视图。在这个名为"Android Viewpager侧滑切换界面"的Demo中,开发者已经成功地展示...

    Android的ViewPager多页面切换动画(仿Launcher)效果

    本教程将详细讲解如何利用ViewPager实现类似Android Launcher和QQ多标签页的页面切换动画。 首先,我们需要了解ViewPager的基本用法。ViewPager继承自 ViewGroup,它能够自动管理其子View的布局和显示,用户可以...

    Android ImageView圆环、ViewPager动画切换、流式布局实例.rar

    一个Android布局的例子:向大家演示一上结基本的UI特效技巧,比如自定义的圆环ImageView、ViewPager的动画... 2、ViewPager的切换动画; 3、流式布局。环境问题,我没有调试起来,时间关系,发上来需要的自己研究吧。

    android viewpager滑动效果

    在Android开发中,ViewPager是一个非常重要的组件,它用于展示多个页面并允许用户通过左右滑动来切换这些页面。本项目“android viewpager滑动效果”专注于实现ViewPager的滑动动态效果,提供了预封装好的接口,使得...

Global site tag (gtag.js) - Google Analytics