ViewPager 无限循环
Overview
我们在使用ViewPager来制作图片轮播的时候,常常为ViewPager不能一直无限循环的问题所苦恼。对于这个问题,目前从网上找到了两个思路来解决:
将 ViewPager 的Count 的数量设置的尽可能的大,然后就造成了无限循环的假象。
第二种,方式是,假如三个图片无限循环,那么就需要用5张图片,如下图所示
使用这种方式启动的时候,需要将 2 号图片,设置为第一张,当向前滑动的时候,因为前面的 1号图片 是和 4 号图片一样,那么,给人的错觉就像是无线循环的一样,当选中一号图片后,立即将当前选中的图片设置为 4 号图片,4号图片向5号图片滑动也是同理。
实现
关于第一种方式,我想对大家来说都不是问题,本文主要是介绍第二种方式的实现方式
Step 1: 准备好任意3张图片
Step 2: 建立Adapter,为了一劳永逸,我们需要做一些简单的封装,来方便我们以后的使用
通用的Adapter
package com.example.it.recycleviewpager;
import android.content.Context;
import android.support.v4.view.PagerAdapter;
import android.view.View;
import android.view.ViewGroup;
import java.util.List;
/**
* Created by 鲁迅认识的那只猹 on 9/25/2017 10:58 AM.
* Emial 1258730808@qq.com
* Desc:
*/
public abstract class BaseRecycleViewPagerAdapter<T> extends PagerAdapter {
private Context context;
private List<T> dataSource;
public BaseRecycleViewPagerAdapter(Context context, List<T> dataSource) {
this.context = context;
this.dataSource = dataSource;
//为了无线循环添加两个冗余项目
T t1 = dataSource.get(0);
T t2 = dataSource.get(dataSource.size() - 1);
this.dataSource.add(dataSource.size() , t1);
this.dataSource.add(0, t2);
}
/**
* 返回视图的数量
*/
@Override
public int getCount() {
return dataSource.size();
}
/**
* 实例化,Page
*/
@Override
public Object instantiateItem(ViewGroup container, int position) {
View view = bindingView(position);
container.addView(view);
return view;
}
/***
* 抽象方法,绑定视图,需要子类实现
*/
abstract View bindingView(int position);
/**
* 回收资源
*/
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
}
@Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
}
public Context getContext() {
return context;
}
public List<T> getDataSource() {
return dataSource;
}
}
建立Adapter,从BaseRecycleViewPagerAdapter 继承
public class AdvertisingAdapter extends BaseRecycleViewPagerAdapter<Integer> {
public AdvertisingAdapter(Context context, List<Integer> dataSource) {
super(context, dataSource);
}
/**
* 建立我们需要用来轮播的图片
*/
@Override
View bindingView(int postion) {
ImageView imageView = new ImageView(getContext());
imageView.setLayoutParams(new ViewGroup.LayoutParams(-1, -1));
imageView.setImageResource(getDataSource().get(postion));
return imageView;
}
}
Step3: 测试我们的Adapter
public class MainActivity extends AppCompatActivity {
private ViewPager viewPager;
private AdvertisingAdapter advertisingAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
viewPager = (ViewPager) this.findViewById(R.id.vp);
init();
}
void init() {
List<Integer> resIdList = new ArrayList<>();
resIdList.add(R.drawable.pet2);
resIdList.add(R.drawable.pet3);
resIdList.add(R.drawable.pet4);
advertisingAdapter = new AdvertisingAdapter(this, resIdList);
viewPager.setAdapter(advertisingAdapter);
//设置第二张图片为最初显示的图片
viewPager.setCurrentItem(1);
//设置Item的选中事件,实现循环
viewPager.setOnPageChangeListener(new ViewPager.SimpleOnPageChangeListener() {
@Override
public void onPageSelected(int position) {
if (position == 0)
viewPager.setCurrentItem(viewPager.getAdapter().getCount() - 2, false);
if (position == viewPager.getAdapter().getCount() - 1)
viewPager.setCurrentItem(1, false);
}
});
}
}
源码下载
基本的需求已经实现,如果还有更多的需求,还可以根据上面的扩展。
我的码云: https://gitee.com/ShareKnowledge/RecycleViewPager
ViewPager 无限循环的更多相关文章
- 一行代码引入 ViewPager 无限循环 + 页码显示
(出处:http://www.cnblogs.com/linguanh) 前序: 网上的这类 ViewPager 很多,但是很多都不够好,体现在 bug多.对少页面不支持,例如1~2张图片.功能整合不 ...
- Android实现ViewPager无限循环滚动回绕
Android实现ViewPager无限循环滚动回绕 Android系统提供的ViewPager标准方式是左右可以自由滑动,但是滑动到最左边的极限位置是第一个page,滑动到最右边的位置是最后一 ...
- 详细分析Android viewpager 无限循环滚动图片
由于最近在忙于项目,就没时间更新博客了,于是趁着周日在房间把最近的在项目中遇到的技术总结下.最近在项目中要做一个在viewpager无限滚动图片的需求,其实百度一下有好多的例子,但是大部分虽然实现了, ...
- ViewPager 无限循环遇到的坑 viewpager.setOffscreenPageLimit(2);
viewpager.setOffscreenPageLimit(limit);这个方法,是表示viewpage除了当前显示的页面外,左右个预加载的页面个数,也就是 为limit=2时表示当前一共加载了 ...
- viewpager双层嵌套,子viewpager无限循环无法手动滑动
项目中首页是用viewpager+fragment集成的,第一个fragment有广告轮播图使用viewpager实现的,开始就遇到是广告图无法手动滑动,事件被外层的viewpager拦截响应切换到下 ...
- Android无限循环轮播广告位Banner
Android无限循环轮播广告位Banner 现在一些app通常会在头部放一个广告位,底部放置一行小圆圈指示器,指示广告位当前的页码,轮播展示一些图片,这些图片来自于网络.这个广告位banner ...
- android 无限循环的viewpager
思路 例如存在 A -B -C 需要在viewpager滑动时无限循环 1.我们可以设计 C' A B C A' C'与C相同,A'与A相同 2.滑动到A'时,则index回到1 3.滑动到C'时, ...
- ViewPager,实现真正的无限循环(定时+手动)
利用定时器,实现循环轮播,很简单:只需在定时器的消息里加如下代码即可: int count = adapter.getCount(); if (count > 1) { // 多于1个,才循环 ...
- 扩展ViewFlow避免和ViewPager滑动冲突,同时支持无限循环,并完美和CircleFlowIndicator结合
首先,为了避免滑动冲突,我们要继承ViewFlow,重写onInterceptTouchEvent public class MyViewFlow extends ViewFlow { private ...
随机推荐
- linux中eth0原何变成了eth1
Linux的网卡由eth0变成了eth1,如何修复使用wmware安装了linux,安装成功后,使用的网卡是eth0,没有eth1.但是用过一段时间后,不知道为什么eth0无法使用,系统却自动生成了e ...
- hdu 5755 Gambler Bo (高斯消元法解同余方程组)
http://acm.hdu.edu.cn/showproblem.php?pid=5755 题意: n*m矩阵,每个格有数字0/1/2 每选择一个格子,这个格子+2,4方向相邻格子+1 如何选择格子 ...
- css 基础1
css 层叠样式表 css手册 样式写在head 中间 style标签 css 样式规则: 选择器 {属性:属性值:属性:属性值} 字体样式属性:font-size 字号大小 color 字体颜色 f ...
- History of Monte Carlo Methods - Part 1
History of Monte Carlo Methods - Part 1 Some time ago in June 2013 I gave a lab tutorial on Monte Ca ...
- 一些js的小技巧
这里收集了一些编码上的小技巧,大家可以学习学习. 1.浮点转整型 使用|0快速转换 var a=(12.002)|0;//12 使用~~快速转换 ~取反运算符,2=0010,~2=1101,因为第一位 ...
- [译]使用chage来管理Linux密码过期时间的七个例子
本文译自 7 Examples to Manage Linux Password Expiration and Aging Using chage 本文主要介绍命令chage的使用,译文会对原文内容会 ...
- object-c 数学计算公式
1. 三角函数 double sin (double);正弦 double cos (double);余弦 double tan (double);正切 2 .反三角函数 double as ...
- Linux输出重定向>和>>的区别是什么
[简介:>与>>的区别] 1 > 是定向输出到文件,如果文件不存在,就创建文件:如果文件存在,就将其清空:一般我们备份清理日志文件的时候,就是这种方法:先备份日志,再用`& ...
- 大数据系列之并行计算引擎Spark介绍
相关博文:大数据系列之并行计算引擎Spark部署及应用 Spark: Apache Spark 是专为大规模数据处理而设计的快速通用的计算引擎. Spark是UC Berkeley AMP lab ( ...
- react-router 4 路由的嵌套
1.在component组件内部需要嵌套的位置直接嵌套Route标签 这个方法会使得路由标签比较分散,子组件我们必须直接将Route标签写入到父组件之中,而且路由必须包含根路径. // Dashboa ...