您好,登錄后才能下訂單哦!
這期內容當中小編將會給大家帶來有關怎么利用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實現一個翻頁效果了,如果剛好有類似的疑惑,不妨參照上述分析進行理解。如果想知道更多相關知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。