温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么利用ViewPager实现一个翻页效果

发布时间:2020-11-26 16:50:24 来源:亿速云 阅读:358 作者:Leah 栏目:移动开发

这期内容当中小编将会给大家带来有关怎么利用ViewPager实现一个翻页效果,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

思路:

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自己遮住了,就用笨办法实现了^_^):

<FrameLayout   android:layout_width="match_parent"   android:layout_height="match_parent"> <com.example.zhangyipeng.anwerdemo.view.ReaderViewPager    android:id="@+id/readerViewPager"    android:layout_width="match_parent"    android:layout_height="match_parent" />   <!--阴影-->   <ImageView    android:id="@+id/shadowView"    android:layout_width="20dp"    android:layout_height="match_parent" android:background="@mipmap/shadow_right"/>  </FrameLayout>

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

上述就是小编为大家分享的怎么利用ViewPager实现一个翻页效果了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI