android做题imageview缩放,巧用ViewPager实现驾考宝典做题翻页效果

效果如下所示:

15059017241.gif?20172810408

思路:

a.利用ViewPager自带的动画效果,略作修改,实现滑动覆盖翻页效果。

b.移动时加入阴影效果。

1.关键代码如下所示:

public class ReaderViewPager extends ViewPager {

public ReaderViewPager(Context context) {

this(context,null);

}

public ReaderViewPager(Context context,AttributeSet attrs) {

super(context,attrs);

setReadEffect();

setScrollerDuration();

}

private void setScrollerDuration() {

try {

Field field = ViewPager.class.getDeclaredField("mScroller");

field.setAccessible(true);

FixedSpeedScroller scroller = new FixedSpeedScroller(getContext(),new DecelerateInterpolator());

field.set(this,scroller);

scroller.setmDuration(300);

} catch (Exception e) {

Log.e("@","",e);

}

}

public void setReadEffect() {

setPageTransformer(true,new PageTransformer() {

private static final float MIN_SCALE = 0.75f;

@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 <= 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.setAlpha(1);

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);

}

}

});

}

}

2.阴影效果添加(其实阴影是一张图片,本来是要在ReadViewPager内部添加阴影效果,但是不显示,貌似被ReadViewPage自己遮住了,就用笨办法实现了^_^):

android:layout_width="match_parent"

android:layout_height="match_parent">

android:id="@+id/readerViewPager"

android:layout_width="match_parent"

android:layout_height="match_parent" />

android:id="@+id/shadowView"

android:layout_width="20dp"

android:layout_height="match_parent"

android:background="@mipmap/shadow_right"/>

3.阴影随翻页而移动效果实现

readerViewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {

@Override

public void onPageScrolled(int position,float positionOffset,int positionOffsetPixels) {

shadowView.setTranslationX(readerViewPager.getWidth()-positionOffsetPixels);

}

@Override

public void onPageSelected(int position) {

}

@Override

public void onPageScrollStateChanged(int state) {

}

});

4.OK,就是这么简单,快去做一个自己的驾考宝典吧 。。。

5.我自己写了一些简单的实现方法,有3个View的实现方式,还有其他使用开源控件实现的,这是地址,欢迎提意见哦

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持编程小技巧!

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

小编个人微信号 jb51ccc

喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值