封装一个ViewPager真正的实现图片无限循环滚动带导航点
效果图:
大家在写项目的过程中常常会碰到须要实现Viewpager里面载入几张图片来循环自己主动轮播的效果,假设不封装一下的话代码分散在activity里面会显得非常乱。并且也不利于我们下次复用,所以这里我把viewpager的相关代码抽取出来放在了一个类里面,使用的时候仅仅须要new 这个对象就可以。
直接看代码:
MyViewPager.java类:在activity中仅仅须要在初始化数据的时候增加MyViewPager myViewPager=new MyViewPager(this)这段代码就ok。
package com.duora.bobge.duoradeliverly_version2.custom_view; import android.app.Activity;
import android.os.Handler;
import android.os.Message;
import android.support.v4.view.ViewPager;
import android.util.Log;
import android.view.View;
import android.widget.ImageView;
import android.widget.LinearLayout; import com.duora.bobge.duoradeliverly_version2.R;
import com.duora.bobge.duoradeliverly_version2.adapter.EventPageAdapter;
import com.duora.bobge.duoradeliverly_version2.base.BaseConfig;
import com.duora.bobge.duoradeliverly_version2.listener.NavigationPageChangeListener; import java.util.ArrayList; /**
* Created by bobge on 15/8/10.
*/
public class MyViewPager {
private Activity activity;
private ViewPager viewPager;
private LinearLayout mViewPoints;
private ArrayList<View> pageViews;
private ImageView imageView;
/** 将小圆点的图片用数组表示 */
private ImageView[] imageViews; private Handler mHandler = new Handler() {
@Override
public void dispatchMessage(Message msg) {
switch (msg.what) {
case BaseConfig.MSG_CHANGE_PHOTO:
int index = viewPager.getCurrentItem();
viewPager.setCurrentItem(index + 1);
mHandler.sendEmptyMessageDelayed(BaseConfig.MSG_CHANGE_PHOTO,
BaseConfig.PHOTO_CHANGE_TIME);
break;
}
super.dispatchMessage(msg);
}
}; public MyViewPager(Activity activity) {
this.activity = activity;
findViewById(activity);
addData();
initPoint();
} private void addData() {
pageViews = new ArrayList<View>();
for (int i = 0; i < 5; i++) {
ImageView imageView = new ImageView(activity);
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
//picasso载入图片
switch (i){
case 0:
imageView.setBackgroundResource(R.mipmap.a);
break;
case 1:
imageView.setBackgroundResource(R.mipmap.b);
break;
case 2:
imageView.setBackgroundResource(R.mipmap.c);
break;
case 3:
imageView.setBackgroundResource(R.mipmap.e);
break;
case 4:
imageView.setBackgroundResource(R.mipmap.f);
break;
}
pageViews.add(imageView);
}
} private void findViewById(Activity activity) {
this.viewPager= (ViewPager)activity.findViewById(R.id.viewPager_main);
this.mViewPoints= (LinearLayout)activity.findViewById(R.id.viewGroup);
} //创建viewpager的那几个滑动的点
private void initPoint() {
// 创建imageviews数组,大小是要显示的图片的数量
imageViews = new ImageView[pageViews.size()];
// 加入小圆点的图片
for (int i = 0; i < pageViews.size(); i++) {
imageView = new ImageView(activity);
// 设置小圆点imageview的參数
LinearLayout.LayoutParams layoutParams = new LinearLayout.LayoutParams(
20, 20);
layoutParams.setMargins(5, 0, 5, 0);
imageView.setLayoutParams(layoutParams);// 创建一个宽高均为20 的布局
// 将小圆点layout加入到数组中
imageViews[i] = imageView;
// 默认选中的是第一张图片,此时第一个小圆点是选中状态,其它不是
if (i == 0) {
imageViews[i]
.setBackgroundResource(R.mipmap.face_float_icon_on);
} else {
imageViews[i]
.setBackgroundResource(R.mipmap.face_float_icon);
} // 将imageviews加入到小圆点视图组
mViewPoints.addView(imageViews[i]);
}
// 设置viewpager的适配器和监听事件
Log.i("test", pageViews.size() + "====");
viewPager.setAdapter(new EventPageAdapter(pageViews));
viewPager.setOnPageChangeListener(new NavigationPageChangeListener(pageViews, imageViews));
viewPager.setCurrentItem((pageViews.size()) * 50);
if(pageViews.size()>1){
mHandler.sendEmptyMessageDelayed(BaseConfig.MSG_CHANGE_PHOTO, BaseConfig.PHOTO_CHANGE_TIME);
}
}
}
它的滑动监听和适配器:
NavigationPageChangeListener.java看命名应该就能知道这个类的作用了,不多说。
package com.duora.bobge.duoradeliverly_version2.listener; import android.support.v4.view.ViewPager;
import android.view.View;
import android.widget.ImageView; import com.duora.bobge.duoradeliverly_version2.R; import java.util.ArrayList; /**
* Created by bobge on 15/8/5.
*/
//viewpager滑动监听
public class NavigationPageChangeListener implements ViewPager.OnPageChangeListener { private ArrayList<View> pageViews;
/** 将小圆点的图片用数组表示 */
private ImageView[] imageViews;
public NavigationPageChangeListener(ArrayList<View> pageViews, ImageView[] imageViews) {
this.pageViews=pageViews;
this.imageViews=imageViews;
} @Override
public void onPageScrollStateChanged(int arg0) {
} @Override
public void onPageScrolled(int arg0, float arg1, int arg2) {
} @Override
public void onPageSelected(int position) {
//当页面切换时设置导航点的状态
setPointStatus(position);
}
//设置导航点的状态
private void setPointStatus(int position) {
position=position%pageViews.size();
for (int i = 0; i < imageViews.length; i++) {
imageViews[position]
.setBackgroundResource(R.mipmap.face_float_icon_on);
// 不是当前选中的page。其小圆点设置为未选中的状态
if (position != i) {
imageViews[i]
.setBackgroundResource(R.mipmap.face_float_icon);
}
}
} }
EventPagerAdapter.java类是viewpager的适配器。instantiateItem方法做了一些处理。使事实上现无限循环。
package com.duora.bobge.duoradeliverly_version2.adapter; import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View; import java.util.ArrayList; /**
* Created by bobge on 15/7/30.
*/
public class EventPageAdapter extends PagerAdapter {
private ArrayList<View> pageViews;
public EventPageAdapter(ArrayList<View> pageViews) {
this.pageViews=pageViews;
} // 销毁position位置的界面
@Override
public void destroyItem(View container, int position, Object object) { ((ViewPager) container).removeView(pageViews.get(position%pageViews.size()));
} // 获取当前窗口界面数
@Override
public int getCount() {
return Integer.MAX_VALUE;
} // 初始化position位置的界面
@Override
public Object instantiateItem(View v, int position) {
try{
//((ViewPager) arg0).addView(list.get(arg1),0);
((ViewPager) v).addView((View)pageViews.get(position%pageViews.size()),0);
}catch (Exception e) {
// TODO: handle exception
}
return pageViews.get(position%pageViews.size());
} @Override
public boolean isViewFromObject(View v, Object arg1) {
return v == arg1;
} @Override
public void startUpdate(View arg0) {
} @Override
public int getItemPosition(Object object) {
return super.getItemPosition(object);
} }
布局:custom_viewpager.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<!--带导航点的viewpager布局-->
<android.support.v4.view.ViewPager
android:id="@+id/viewPager_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
/> <LinearLayout
android:id="@+id/viewGroup"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="20dp"
android:gravity="center_horizontal"
android:orientation="horizontal" >
</LinearLayout>
</RelativeLayout>
在activity的布局中仅仅须要导入上面那个布局就可以:
<include
layout="@layout/custom_viewpager"
android:id="@+id/myViewPager"
android:layout_width="match_parent"
android:layout_height="@dimen/viewpager_height"
/>
封装一个ViewPager真正的实现图片无限循环滚动带导航点的更多相关文章
- ViewPager,实现真正的无限循环(定时+手动)
利用定时器,实现循环轮播,很简单:只需在定时器的消息里加如下代码即可: int count = adapter.getCount(); if (count > 1) { // 多于1个,才循环 ...
- Android实现ViewPager无限循环滚动回绕
Android实现ViewPager无限循环滚动回绕 Android系统提供的ViewPager标准方式是左右可以自由滑动,但是滑动到最左边的极限位置是第一个page,滑动到最右边的位置是最后一 ...
- 利用jQuery实现图片无限循环轮播(不借助于轮播插件)
原来我主要是用Bootstrap框架或者swiper插件实现轮播图的功能,而这次是用jQuery来实现图片无限循环轮播! 用到的技术有:html.css.JavaScript(少).jQuery(主要 ...
- Android实现真正的ViewPager【平滑过渡】+【循环滚动】!!!顺带还有【末页跳转】。
实现真正的ViewPager[平滑过渡]+[循环滚动]!!!顺带还有[末页跳转]. 首先呢, 我要对网上常见的3种ViewPager的循环滚动方法做个概述.急需看真正实现方法的同志请选择性忽略下面这一 ...
- unity 背景无限循环滚动效果
背景无限循环滚动效果如下示: 步骤如下: 导入背景图片后,设置图片的格式,如下图: 2.图片格式也可以设置是Texture格式,但是Wrap Mode 一定要是Repeat[重复发生]:然后记得App ...
- 详细分析Android viewpager 无限循环滚动图片
由于最近在忙于项目,就没时间更新博客了,于是趁着周日在房间把最近的在项目中遇到的技术总结下.最近在项目中要做一个在viewpager无限滚动图片的需求,其实百度一下有好多的例子,但是大部分虽然实现了, ...
- jquery的焦点图片无限循环关键思维
在循环的时候,关键的是按(下一页按钮)到最后一页的时候和按(上一页按钮)到到第一页的时候如何转换: 首先必须知道3个js方法,prepend().append()和clone(); prepend() ...
- iOS无限循环滚动scrollview
经常有园友会问"博主,有没有图片无限滚动的Demo呀?", 正儿八经的图片滚动的Demo我这儿还真没有,今天呢就封装一个可以在项目中直接使用的图片轮播.没看过其他iOS图片无限轮播 ...
- Cocos2dx中利用双向链表实现无限循环滚动层
[Qboy原创] 在Cocos2dX 3.0 中已经实现一些牛逼的滚动层,但是对于有一些需要实现循环滚动的要求确没有实现,笔者在前段时间的一个做了一个游戏,需求是实现在少有的(13个)英雄中进行循环滚 ...
随机推荐
- flex 通过htmlservices链接moss的rest(rest 的get post方式)
一:flex debug(调试)--trace() --moss导入 flex学习:1.flex出现不能使用trace调试语句的问题,控制台无信息输出.这个问题不须要改动安装文件的參量. 仅仅须要下载 ...
- 模式匹配的KMP 算法
常见的字符串匹配时,模式串长度为n,源串长度为m,则从头匹配,两个指针i指向源串,j指向模式串,如遇到不同则回溯使j=0,这样就要反复匹配会使效率变低. 因为在如今i之前 的模式串与匹配串的匹配是同样 ...
- Hibernate关系映射中的注解
一.@Entity 写在映射表的类上面,表示这是映射来的实体 二.@Id @Column(name = "fid", nullable = false) @Basic @Colum ...
- poj_3071概率dp
确定好对手就简单了. #include<iostream> #include<cstdio> #include<cstring> #include<algor ...
- C#中的CSP(Communicating sequential processes)
说起Golang(后面统称为Go),就想到他的高并发特性,在深入一些就是 Goroutine.在大家被它优雅的语法和简洁的代码实现的高并发程序所折服时,其实C#/.NET也可以很容易的做到.今天我们来 ...
- eclipse启动错误:An internal error occurred during: "reload maven project".
解决方案一: 简单粗暴!直接删除E:\eclipseWorkspace\.metadata目录!然后再单个导入eclipseWorkspace中的项目. 解决方案二: 打开这个配置文件:E:\ecli ...
- SparkShuffle调优原理和最佳实践
在网络层,互联网提供所有应用程序都要使用的两种类型的服务,尽管目前理解这些服务的细节并不重要,但在所有TCP/IP概述中,都不能忽略他们: 无连接分组交付服务(Connectionless Packe ...
- .net垃圾回收-原理浅析
本文引自:http://www.cnblogs.com/wilber2013/p/4357910.html 在开发.NET程序过程中,由于CLR中的垃圾回收(garbage collection)机制 ...
- (转)js document.all的用法
document.all用法 一. document.all是页面内所有元素的一个集合.例如: document.all(0)表示页面内第一个元素 二.document.all可以判断浏览器 ...
- 还是bib问题
虽然昨天把添加bib的基本问题解决了,但是bib的参考文献没有了中括号.查了一下华东师大,只是给出了如何去掉中括号的方法. http://math.ecnu.edu.cn/~latex/doc.htm ...