今天让咱们了解一下,Android3.0以后ViewPager切换时候的一个动画。Google给咱们展现了两个动画例子:DepthPageTransformer和ZoomOutPageTransformer,代码以下:java
public class DepthPageTransformer implements PageTransformer { private static float MIN_SCALE = 0.75f; @SuppressLint("NewApi") @Override public void transformPage(View view, float position) { int pageWidth = view.getWidth(); if (position < -1) { // [-Infinity,-1)//This page is way off-screen to the left. view.setAlpha(0); } else if (position <= 0) { // [-1,0]Use //the default slide transition when moving to the left page view.setAlpha(1); view.setTranslationX(0); view.setScaleX(1); view.setScaleY(1); } else if (position <= 1) { // (0,1]// Fade the page out. view.setAlpha(1 - position); // Counteract the default slide transition view.setTranslationX(pageWidth * -position); // Scale the page down (between MIN_SCALE and 1) float scaleFactor = MIN_SCALE + (1 - MIN_SCALE) * (1 - Math.abs(position)); view.setScaleX(scaleFactor); view.setScaleY(scaleFactor); } else { // (1,+Infinity] // This page is way off-screen to the right. view.setAlpha(0); } } }
public class ZoomOutPageTransformer implements PageTransformer { private static float MIN_SCALE = 0.85f; private static float MIN_ALPHA = 0.5f; @Override public void transformPage(View view, float position) { int pageWidth = view.getWidth(); int pageHeight = view.getHeight(); if (position < -1) { // [-Infinity,-1) // This page is way off-screen to the left. view.setAlpha(0); } else if (position <= 1) { // [-1,1] // Modify the default slide transition to // shrink the page as well float scaleFactor = Math.max(MIN_SCALE, 1 - Math.abs(position)); float vertMargin = pageHeight * (1 - scaleFactor) / 2; float horzMargin = pageWidth * (1 - scaleFactor) / 2; if (position < 0) { view.setTranslationX(horzMargin - vertMargin / 2); } else { view.setTranslationX(-horzMargin + vertMargin / 2); } // Scale the page down (between MIN_SCALE and 1) view.setScaleX(scaleFactor); view.setScaleY(scaleFactor); // Fade the page relative to its size. view.setAlpha(MIN_ALPHA + (scaleFactor - MIN_SCALE) / (1 - MIN_SCALE) * (1 - MIN_ALPHA)); } else { // (1,+Infinity] // This page is way off-screen to the right. view.setAlpha(0); } } }
咱们在使用的时候只需mPager.setPageTransformer(true, new DepthPageTransformer())便可,下面让咱们看看transformPage方法怎么实现动画的!!!ide
transformPage方法有两个参数,第一个view固然就是应用动画的那个控件,第二个是一个float类型的值,不是咱们日常见到的position位置,而是当前滑动状态的表示,相对于当前position的position。它有三个临界值-1 0 1,0表明当前屏幕显示的view的position,1表明当前view的下一个view所在的position,-1表明当前view的前一个view所在的position。不知道我讲清楚没有?动画
那么请看下面的图片:orm
下面让咱们看看当前view左滑、右滑时各个view positon的变化状况:blog
好了,上面的表格你们能够经过打log的形式验证一下。知道了各个位置的view的position的变化状况,下面让咱们看看动画吧。这里咱们不作炫酷的动画,只作透明度的动画,方便你们理解transformPage方法。图片
前提不知道你们了不了解alpha这个属性,它的取值范围在0和1之间,0表明彻底透明,1表明彻底不透明。废话很少说看动画:get
public class ViewpagerTransformAnim implements ViewPager.PageTransformer { @Override public void transformPage(View page, float position) { float alpha = 0.0f; if (0.0f <= position && position <= 1.0f) { alpha = 1.0f - position; } else if (-1.0f <= position && position < 0.0f) { alpha = position + 1.0f; } page.setAlpha(alpha); } }
那么咱们就对上面的代码简单的解释一下:无论当前view左滑仍是右滑,当我滑动的时候,根据以前的表格咱们知道上面的两个判断语句都会走到,这是由于你滑动的时候,确定是两个view作动画的切换(不算两个边界,边界的话只会走一个),因为alpha取值在0和1之间,position取值在-1和1之间。因此有了条件语句中的代码。看下效果吧:it
很简单的一个动画,但愿对你们有所帮助!!!io