@TryLoveCatch
2018-10-19T14:57:29.000000Z
字数 3326
阅读 2591
android
ViewPager
PageTransformer
PageTransformer
是一个允许你修改ViewPager
默认滑动动画的接口,当我们在滑动ViewPager
中的页面的过程中,会多次调用这个方法,并给我们传递了两个参数View page
和float position
。
public interface PageTransformer {
void transformPage(View page, float position);
}
通过它可以实现一些非常炫酷的滑动动画。今天我们来实现视觉差滚动的效果。
所谓视觉差效果,我们可以这样理解,比如
ViewPager
滑动了1px
,而该Page中的TextView
移动2px
,ImageView
移动0.5px
,这样我们看到就是TextView
比ImageView
移动的快,从而形成了视觉差。
同一个界面中的元素,由于层级不同,赋予不同的速度,在移动速度上的差异形成了视差的错觉,这就是我们要追求的效果
好了,说了这么多,我们先来了解一下PageTransformer
这个接口吧。
我自定义了一个PageTransformer
,仅仅是打印了两个参数View page
和float position
,如下:
刚进入
page1 , 0.0
page2 , 1.0
这里比较好理解,进入App,默认打开ViewPager
的第一个页面,并且 预加载第二个页面,所以会有打印两条,关于后面position
的意思,我们下面在说,当然,这个和ViewPager
的position
没有任何关系。
1-->2
page1 , -0.0055555557
page2 , 0.99444443
page1 , -0.022222223
page2 , 0.9777778
page1 , -0.03888889
page2 , 0.9611111
page1 , -0.05648148
page2 , 0.9435185
page1 , -0.9990741
page2 , 9.259259E-4
page1 , -1.0
page2 , 0.0
手指向左滑动,从page1
到page2
,通过上面的打印我们可以得出结论:
page1
从完全显示--->向左消失
,position
的值从0--->-1
page2
从屏幕右侧完全不显示--->完全显示
,position
的值从1--->0
2-->1
page1 , -0.9990741
page2 , 9.259259E-4
page3 , 1.0009259
page1 , -0.975
page2 , 0.025
page3 , 1.025
page1 , -0.95092595
page2 , 0.049074072
page3 , 1.049074
page1 , -9.259259E-4
page2 , 0.9990741
page3 , 1.9990741
page1 , 0.0
page2 , 1.0
page3 , 2.0
手指向右滑动,从page2
到page1
,通过上面的打印我们可以得出结论:
page1
从屏幕左侧完全不显示--->完全显示
,position
的值从-1--->0
page2
从完全显示--->向右消失
,position
的值从0--->1
page3
从屏幕右侧完全不显示--->屏幕右侧完全不显示
,position
的值从1--->2
1-->2
的时候,应该3
已经预加载了。2-->3
page1 , -1.0222223
page2 , -0.022222223
page3 , 0.9777778
page1 , -1.0694444
page2 , -0.06944445
page3 , 0.9305556
page1 , -1.1222222
page2 , -0.12222222
page3 , 0.87777776
page1 , -1.9990741
page2 , -0.9990741
page3 , 9.259259E-4
page1 , -2.0
page2 , -1.0
page3 , 0.0
page1
从屏幕左侧完全不显示--->屏幕左侧完全不显示
,position
的值从-1--->-2
page2
从完全显示--->屏幕左侧完全不显示
,position
的值从0--->-1
page3
从屏幕右侧完全不显示--->完全显示
,position
的值从1--->0
1、
position
并不是我们以为的View
位置,而是表示一种状态:
== 0
代表完全显示;
>= 1
代表在屏幕右侧完全不显示;
<=-1
代表在屏幕左侧完全不显示。
2、我们其实并不需要关心所有的position
,我们只需要关系正在呈现给用户的情况,所以,我们只用处理[-1,1]
,不用关心[-Infinity,-1)
和(1,+Infinity]
。
private class MyTransformer implements ViewPager.PageTransformer {
@Override
public void transformPage(View page, float position) {
if (position < -1) { // [-Infinity,-1)
//不需要处理
} else if (position <= 1) { // [-1,1]
//具体动画逻辑
} else { // (1,+Infinity]
//不需要处理
}
}
}
最好写成一个基类,以便于扩展,而且有的时候很[-1, 1]
会细分为[-1, 0]
和(0, 1]
。
public abstract class BasePageTransformer implements ViewPager.PageTransformer {
/**
* Apply a property transformation to the given page.
*
* @param view Apply the transformation to this page
* @param position Position of page relative to the current front-and-center
* position of the pager. 0 is front and center. 1 is one full
*/
@Override
public void transformPage(View view, float position) {
if (position < -1.0f) { // [-Infinity,-1) 不可见状态
// This page is way off-screen to the left.
handleInvisiblePage(view, position);
} else if (position <= 0.0f) { // [-1,0] 可见状态,设置动画效果 左边的item
// Use the default slide transition when moving to the left page
handleLeftPage(view, position);
} else if (position <= 1.0f) { // (0,1] 可见状态,设置动画效果 右边的item
handleRightPage(view, position);
} else { // (1,+Infinity] 不可见状态
// This page is way off-screen to the right.
handleInvisiblePage(view, position);
}
}
public abstract void handleInvisiblePage(View view, float position);
public abstract void handleLeftPage(View view, float position);
public abstract void handleRightPage(View view, float position);
}
PageTransformerDemo
PageTransformer
Android ViewPager切换之PageTransformer接口中transformPage方法position参数使用详解
ViewPager 从入门到带你撸个启动页之实战PageTransformer切换动画特效(四)
用PageTranformer实现更炫酷的动画