Android使用ViewPager实现左右无限滑动
前言
网上有很多使用ViewPager实现左右滑动这一效果的资料,这些资料大多数都是将PagerAdapter中getCount()方法的返回值设为Integer.MAX_VALUE使用户看不到边界,然后在instantiateItem()方法中通过position%(要循环显示的数据集的长度)的方式取得对应的数据集。这样虽然可以做到无限循环,但是会有两个弊端:首先会创建大量对象,容易引起内存溢出(循环加载图片)从而影响性能;其次从第一页向右滑动的时候是无法滑动的。
今天给大家分享的是另一种实现方式:创建三个图片视图放入ViewPager中默认选中第二页,在接下来的滑动中每次滑动结束之后都将当前页码设置为第二页,然后通过判断是向左向右滑动来设置视图中的数据集,这样就可以实现无限循环了,而且只会创建三个图片视图对象。
示例源码
packagecom.viewpager; importjava.util.ArrayList; importjava.util.List; importandroid.os.Bundle; importandroid.support.v4.view.PagerAdapter; importandroid.support.v4.view.ViewPager; importandroid.support.v4.view.ViewPager.OnPageChangeListener; importandroid.view.View; importandroid.view.ViewGroup; importandroid.widget.ImageView; importandroid.app.Activity; publicclassMainActivity01extendsActivityimplementsOnPageChangeListener{ privateViewPagerviewPager; staticfinalintarrays[]={R.drawable.guide1,R.drawable.guide2, R.drawable.guide3,R.drawable.guide4,R.drawable.guide5}; privateListviews; privateintcurrentPage=0; privateImageViewimageView; privateMyViewPagerAdapterviewPagerAdapter; @Override protectedvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); initWidget(); } privatevoidinitWidget(){ viewPager=(ViewPager)findViewById(R.id.viewpager); views=newArrayList (); for(inti=0;i<3;i++){ imageView=newImageView(this); imageView.setLayoutParams(newViewGroup.LayoutParams( ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.MATCH_PARENT)); views.add(imageView); } initImageData(); viewPagerAdapter=newMyViewPagerAdapter(); viewPager.setAdapter(viewPagerAdapter); viewPager.setCurrentItem(1); viewPager.setOnPageChangeListener(this); } privatevoidinitImageData(){ for(inti=0;i<3;i++){ imageView=views.get(i); if(i==0){ imageView.setImageResource(arrays[arrays.length-1]); }else{ imageView.setImageResource(arrays[i-1]); } } } classMyViewPagerAdapterextendsPagerAdapter{ @Override publicintgetCount(){ //TODOAuto-generatedmethodstub returnviews.size(); } @Override publicbooleanisViewFromObject(Viewarg0,Objectarg1){ //TODOAuto-generatedmethodstub returnarg0==arg1; } @Override publicObjectinstantiateItem(ViewGroupcontainer,intposition){ imageView=views.get(position); container.addView(imageView); returnimageView; } @Override publicvoiddestroyItem(ViewGroupcontainer,intposition,Objectobject){ //TODOAuto-generatedmethodstub container.removeView((View)object); } } //当滑动状态改变时调用 @Override publicvoidonPageScrollStateChanged(intstate){ //TODOAuto-generatedmethodstub System.out.println("--onPageScrollStateChanged--state--:"+state); switch(state){ //在滚动完成后 caseViewPager.SCROLL_STATE_IDLE: intcurrentItem=viewPager.getCurrentItem(); System.out.println("--currentItem--00--:"+currentItem); System.out.println("--currentPage--00--:"+currentPage); if(viewPager.getCurrentItem()==1){ //如果位置没有变终止循环 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 publicvoidonPageScrolled(intposition,floatpositionOffset, intpositionOffsetPixels){ //TODOAuto-generatedmethodstub //System.out.println("--onPageScrolled--position--:"+position); } //当新的页面被选中时调用 @Override publicvoidonPageSelected(intposition){ //TODOAuto-generatedmethodstub System.out.println("--onPageSelected--position--:"+position); } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。