前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android使用ViewPager实现左右无限滑动

Android使用ViewPager实现左右无限滑动

作者头像
砸漏
发布2020-11-05 10:47:22
2.5K0
发布2020-11-05 10:47:22
举报
文章被收录于专栏:恩蓝脚本

前言

网上有很多使用ViewPager实现左右滑动这一效果的资料,这些资料大多数都是将PagerAdapter中getCount()方法的返回值设为Integer.MAX_VALUE使用户看不到边界,然后在instantiateItem()方法中通过position%(要循环显示的数据集的长度)的方式取得对应的数据集。这样虽然可以做到无限循环,但是会有两个弊端:首先会创建大量对象,容易引起内存溢出(循环加载图片)从而影响性能;其次从第一页向右滑动的时候是无法滑动的。

今天给大家分享的是另一种实现方式:创建三个图片视图放入ViewPager中默认选中第二页,在接下来的滑动中每次滑动结束之后都将当前页码设置为第二页,然后通过判断是向左向右滑动来设置视图中的数据集,这样就可以实现无限循环了,而且只会创建三个图片视图对象。

示例源码

代码语言:javascript
复制
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); 
} 
} 
// 当滑动状态改变时调用 
@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) { 
// 如果位置没有变终止循环 
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); 
} 
} 

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档