Android使用ViewPager實現(xiàn)左右無限滑動
前言
網(wǎng)上有很多使用ViewPager實現(xiàn)左右滑動這一效果的資料,這些資料大多數(shù)都是將PagerAdapter中getCount()方法的返回值設為Integer.MAX_VALUE使用戶看不到邊界,然后在instantiateItem()方法中通過position%(要循環(huán)顯示的數(shù)據(jù)集的長度)的方式取得對應的數(shù)據(jù)集。這樣雖然可以做到無限循環(huán),但是會有兩個弊端:首先會創(chuàng)建大量對象,容易引起內存溢出(循環(huán)加載圖片)從而影響性能;其次從第一頁向右滑動的時候是無法滑動的。
今天給大家分享的是另一種實現(xiàn)方式:創(chuàng)建三個圖片視圖放入ViewPager中默認選中第二頁,在接下來的滑動中每次滑動結束之后都將當前頁碼設置為第二頁,然后通過判斷是向左向右滑動來設置視圖中的數(shù)據(jù)集,這樣就可以實現(xiàn)無限循環(huán)了,而且只會創(chuàng)建三個圖片視圖對象。
示例源碼
package com.viewpager; import java.util.ArrayList; import java.util.List; import android.os.Bundle; import android.support.v4.view.PagerAdapter; import android.support.v4.view.ViewPager; import android.support.v4.view.ViewPager.OnPageChangeListener; import android.view.View; import android.view.ViewGroup; import android.widget.ImageView; import android.app.Activity; public class MainActivity01 extends Activity implements OnPageChangeListener { private ViewPager viewPager; static final int arrays[] = { R.drawable.guide1, R.drawable.guide2, R.drawable.guide3, R.drawable.guide4, R.drawable.guide5 }; private List<ImageView> views; private int currentPage = 0; private ImageView imageView; private MyViewPagerAdapter viewPagerAdapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initWidget(); } private void initWidget() { viewPager = (ViewPager) findViewById(R.id.viewpager); views = new ArrayList<ImageView>(); for (int i = 0; i < 3; i++) { imageView = new ImageView(this); imageView.setLayoutParams(new ViewGroup.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); views.add(imageView); } initImageData(); viewPagerAdapter = new MyViewPagerAdapter(); viewPager.setAdapter(viewPagerAdapter); viewPager.setCurrentItem(1); viewPager.setOnPageChangeListener(this); } private void initImageData() { for (int i = 0; i < 3; i++) { imageView = views.get(i); if (i == 0) { imageView.setImageResource(arrays[arrays.length - 1]); } else { imageView.setImageResource(arrays[i - 1]); } } } class MyViewPagerAdapter extends PagerAdapter { @Override public int getCount() { // TODO Auto-generated method stub return views.size(); } @Override public boolean isViewFromObject(View arg0, Object arg1) { // TODO Auto-generated method stub return arg0 == arg1; } @Override public Object instantiateItem(ViewGroup container, int position) { imageView = views.get(position); container.addView(imageView); return imageView; } @Override public void destroyItem(ViewGroup container, int position, Object object) { // TODO Auto-generated method stub container.removeView((View) object); } } // 當滑動狀態(tài)改變時調用 @Override public void onPageScrollStateChanged(int state) { // TODO Auto-generated method stub System.out.println("--onPageScrollStateChanged--state--:" + state); switch (state) { // 在滾動完成后 case ViewPager.SCROLL_STATE_IDLE: int currentItem = viewPager.getCurrentItem(); System.out.println("--currentItem--00--:" + currentItem); System.out.println("--currentPage--00--:" + currentPage); if (viewPager.getCurrentItem() == 1) { // 如果位置沒有變終止循環(huán) break; } if (viewPager.getCurrentItem() > 1) { currentPage++; } else { currentPage--; } System.out.println("--currentPage--11--:" + currentPage); if (currentPage == arrays.length) { currentPage = 0; } if (currentPage == -1) { currentPage = arrays.length - 1; } System.out.println("--currentPage--22--:" + currentPage); if (currentPage == 0) { views.get(0).setImageResource(arrays[arrays.length - 1]); } else { views.get(0).setImageResource(arrays[currentPage - 1]); } views.get(1).setImageResource(arrays[currentPage]); if (currentPage == arrays.length - 1) { views.get(2).setImageResource(arrays[0]); } else { views.get(2).setImageResource(arrays[currentPage + 1]); } viewPager.setCurrentItem(1, false); currentItem = viewPager.getCurrentItem(); System.out.println("--currentItem--11--:" + currentItem); break; } } // 當當前頁面被滑動時調用 @Override public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) { // TODO Auto-generated method stub // System.out.println("--onPageScrolled--position--:" + position); } // 當新的頁面被選中時調用 @Override public void onPageSelected(int position) { // TODO Auto-generated method stub System.out.println("--onPageSelected--position--:" + position); } }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- Android利用ViewPager實現(xiàn)滑動廣告板實例源碼
- Android App中ViewPager所帶來的滑動沖突問題解決方法
- Android App中使用ViewPager+Fragment實現(xiàn)滑動切換效果
- Android中ViewPager帶來的滑動卡頓問題解決要點解析
- Android開發(fā)之使用ViewPager實現(xiàn)圖片左右滑動切換效果
- Android ViewPager無限循環(huán)實現(xiàn)底部小圓點動態(tài)滑動
- android配合viewpager實現(xiàn)可滑動的標簽欄示例分享
- Android利用ViewPager實現(xiàn)可滑動放大縮小畫廊效果
- Android編程實現(xiàn)ViewPager多頁面滑動切換及動畫效果的方法
- Android 利用ViewPager實現(xiàn)圖片可以左右循環(huán)滑動效果附代碼下載
相關文章
Android?ViewModel創(chuàng)建不受橫豎屏切換影響原理詳解
這篇文章主要為大家介紹了Android?ViewModel創(chuàng)建不受橫豎屏切換影響原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03圖解Windows環(huán)境下Android Studio安裝和使用教程
這篇文章主要介紹了圖解Windows環(huán)境下Android Studio安裝和使用教程的相關資料,需要的朋友可以參考下2015-12-12Android仿支付寶笑臉刷新加載動畫的實現(xiàn)代碼
這篇文章主要介紹了Android仿支付寶笑臉刷新加載動畫的實現(xiàn)代碼的相關資料,需要的朋友可以參考下2016-11-11Android自定義View實現(xiàn)loading動畫加載效果
項目開發(fā)中對Loading的處理是比較常見的,安卓系統(tǒng)提供的不太美觀,引入第三發(fā)又太麻煩,這時候自己定義View來實現(xiàn)這個效果。這篇文章主要介紹了Android自定義View實現(xiàn)loading動畫加載效果,需要的朋友可以參考下2017-03-03