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 ...
随机推荐
- vue父组件调用子组件资源
通过上篇博文提到的方法我们可以触发子组件的某个事件来实现调用子组件的某些资源(例如数据和方法),但是更多的情况下我们会想不通过触发子组件的事件,而直接调用子组件的资源 这个时候我们就需要用到ref了, ...
- RestFul风格接口示例
REST是英文representational state transfer(表象性状态转变)或者表述性状态转移;Rest是web服务的一种架构风格;使用HTTP,URI,XML,JSON,HTML等 ...
- 对Property进行RACObserve
@property (assign,nonatomic) int price; @property (assign,nonatomic) int time; [RACObserve(self,pric ...
- Centos 7和 Centos 6开放查看端口 防火墙关闭打开
Centos 7 firewall 命令: 查看已经开放的端口: firewall-cmd --list-ports 开启端口 firewall-cmd --zone=public --add-por ...
- [整理]Win下好用的Markdown工具
用过haroopad,MarkPad,Sublime + markdown插件,前2款勉强能用,都处于继续开发中,haroopad支持的语法相对较少,提示也不明显,MarkPad还是有不少bug. 后 ...
- zTree的简单例子
<%@ page language="java" pageEncoding="UTF-8" %> <%@ include file=" ...
- Linux中Nginx安装与配置详解
转载自:http://www.linuxidc.com/Linux/2016-08/134110.htm Linux中Nginx安装与配置详解(CentOS-6.5:nginx-1.5.0). 1 N ...
- Anaconda+django写出第一个web app(八)
今天来实现网站的登入和登出功能. 首先我们需要在urls.py中添加路径,注意此处的路径和在导航栏中设置的文字路径保持一致: from django.urls import path from . i ...
- Linux awk工具简单学习记录
awk是一个文本分析工具,它把文件逐行读入,以特定符号将每行切分(默认空格为分隔符),切开的部分再进行各种分析处理. awk其名称得自于它的创始人Alfred Aho .Peter Weinberge ...
- Dream_Spark-----Spark 定制版:004~Spark Streaming事务处理彻底掌握
Spark 定制版:004~Spark Streaming事务处理彻底掌握 本讲内容: a. Exactly Once b. 输出不重复 注:本讲内容基于Spark 1.6.1版本(在2016年5月来 ...