Android实现轮播图无限循环效果
本文实例为大家分享了Android轮播图无限循环的具体代码,供大家参考,具体内容如下
实现无限循环
在getCount()方法中,返回一个很大的值,Integer.MAX_VALUE
在instantiateItem()方法中,获取当前View的索引时,进行取于操作,传递进来的intposition是个非常大的数,对他进行求余数
在destroyItem()方法中,同样
在onPageSelected()监听方法中,对传递进来的索引进行取于
反向的无限循环
调用ViewPager对象的setCurrentItem()方法,设置第一次进来时候的当前页,参数:int数字,我们把它定位到Integer.MAX_VALUE的中间,并且保证第一条是当前位置,Integer.MAX_VALUE/2-((Integer.MAX_VALUE/2)%banners.size())
目前有个左划空白页的问题没解决
packagecom.tsh.myviewpager; importjava.util.ArrayList; importjava.util.List; importandroid.app.Activity; 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.widget.LinearLayout; importandroid.widget.TextView; publicclassMainActivityextendsActivity{ privateViewPagervp_banner; privateLinearLayoutll_points; privateTextViewtv_title; privateList<View>banners; privateString[]titles=newString[]{ "新闻标题1", "新闻标题2", "新闻标题3" }; privateList<ImageView>points=newArrayList<ImageView>(); @Override protectedvoidonCreate(BundlesavedInstanceState){ super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); //初始化 vp_banner=(ViewPager)findViewById(R.id.vp_banner); ll_points=(LinearLayout)findViewById(R.id.ll_points); tv_title=(TextView)findViewById(R.id.tv_title); //banner部分 banners=newArrayList<>(); ImageViewimg1=newImageView(this); img1.setImageResource(R.drawable.a); banners.add(img1); ImageViewimg2=newImageView(this); img2.setImageResource(R.drawable.b); banners.add(img2); ImageViewimg3=newImageView(this); img3.setImageResource(R.drawable.c); banners.add(img3); //小图标 ll_points=(LinearLayout)findViewById(R.id.ll_points); for(inti=0;i<banners.size();i++){ ImageViewimage=newImageView(this); image.setImageResource(R.drawable.point_selector); LinearLayout.LayoutParamsparams=newLinearLayout.LayoutParams(5,5); params.rightMargin=4; image.setLayoutParams(params); if(i==0){ image.setEnabled(true); }else{ image.setEnabled(false); } points.add(image); ll_points.addView(image); } //设置适配器 vp_banner.setAdapter(newMyPagerAdapter()); vp_banner.setCurrentItem(Integer.MAX_VALUE/2-((Integer.MAX_VALUE/2)%banners.size())); vp_banner.setOnPageChangeListener(newOnPageChangeListener(){ @Override publicvoidonPageSelected(intarg0){ tv_title.setText(titles[arg0%banners.size()]); //小图标处理 for(ImageViewpoint:points){ point.setEnabled(false); } points.get(arg0%banners.size()).setEnabled(true); } @Override publicvoidonPageScrolled(intarg0,floatarg1,intarg2){ //TODOAuto-generatedmethodstub } @Override publicvoidonPageScrollStateChanged(intarg0){ //TODOAuto-generatedmethodstub } }); } privateclassMyPagerAdapterextendsPagerAdapter{ @Override publicvoiddestroyItem(ViewGroupcontainer,intposition,Objectobject){ System.out.println("销毁:"+position); container.removeView((View)object); object=null; } @Override publicObjectinstantiateItem(ViewGroupcontainer,intposition){ System.out.println("初始化:"+position); position=position%banners.size(); //解决右划出错 if(banners.get(position).getParent()!=null){ //container.removeView(banners.get(position)); }else{ container.addView(banners.get(position)); } returnbanners.get(position); } @Override publicintgetCount(){ returnInteger.MAX_VALUE; } @Override publicbooleanisViewFromObject(Viewarg0,Objectarg1){ returnarg0==arg1; } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。