Android ViewPager小圆点指示器
作者:lvshaorong 发布时间:2022-05-09 11:21:43
标签:Android,ViewPager,指示器
一个很常用的功能,一个ViewPager会自动滚动,并且有一排小圆点黑和白来指示当前的滚动进度
首先写一个ViewPager的适配器,这里这个适配器为了方便里面的元素全都是ImageView
import android.content.Context;
import android.os.Handler;
import android.support.v4.view.PagerAdapter;
import android.support.v4.view.ViewPager;
import android.view.View;
import android.view.ViewGroup;
import android.view.animation.Interpolator;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.Scroller;
/**
* Created by Administrator on 2016/2/24.
*/
public class HomeHomeBannerAdapter extends PagerAdapter{
private Context context;
private ImageView[] eventImageViews;
private String[] eventUrls;
int destWidth,destHeight;
public HomeHomeBannerAdapter(Context context, String[] eventUrls,int destWidth,int destHeight) {
this.context = context;
this.eventUrls = eventUrls;
this.destHeight = destHeight;
this.destWidth = destWidth;
initImageViews();
}
/**
* 初始化viewPager里的几张图
*/
private void initImageViews(){
if(eventUrls==null)return;
eventImageViews = new ImageView[eventUrls.length];
for (int i=0;i<eventUrls.length;i++) {
eventImageViews[i] = new ImageView(context);
eventImageViews[i].setLayoutParams(new LinearLayout.LayoutParams(destWidth, destHeight));
eventImageViews[i].setPadding(0, 0, 0, 0);
eventImageViews[i].setScaleType(ImageView.ScaleType.FIT_XY);
JImageUtils.loadImageFromServerByUrl(context,eventImageViews[i],eventUrls[i]);
}//显示图片
}
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
if (eventImageViews != null && eventImageViews.length > position && position >= 0)
container.removeView(eventImageViews[position]);
}
@Override
public Object instantiateItem(ViewGroup container, int position) {
container.addView(eventImageViews[position], 0);
return eventImageViews[position];
}
@Override
public int getCount() {return eventUrls==null?0:eventUrls.length;}
@Override
public boolean isViewFromObject(View arg0, Object arg1) {
return arg0 == arg1;
}
//ViewPager * 集成到内部类去
static public class EventViewPagerChangeListener implements ViewPager.OnPageChangeListener {
LinearLayout llGuideGroup;
int oldEventPosition;
int currentItem;
public EventViewPagerChangeListener(LinearLayout llGuideGroup){
this.llGuideGroup = llGuideGroup;
}
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {}
/**
* 控制小点的白色还是黑色的显示
* @param position
*/
public void onPageSelected(int position) {
llGuideGroup.getChildAt(oldEventPosition).setBackgroundResource(R.drawable.dot_normal);//黑色点
llGuideGroup.getChildAt(position).setBackgroundResource(R.drawable.dot_focused);//白色点
oldEventPosition = position;
currentItem = position;
}
@Override
public void onPageScrollStateChanged(int state) {
}
}
/**
* 控制viewpager自动滑动的定时任务
*/
public static class ScrollTask implements Runnable {
EventViewPagerChangeListener listener;
ViewPager vpEvent;
int eventSize;
Handler handler;
public ScrollTask(EventViewPagerChangeListener listener,final ViewPager vpEvent, int eventSize){
this.listener = listener;
this.vpEvent = vpEvent;
this.eventSize = eventSize;
handler = new Handler();
}
public void run() {
if(listener==null||vpEvent==null||eventSize==0)return;
listener.currentItem = (listener.currentItem + 1) % eventSize;
Log.i("Alex","currentItem是"+listener.currentItem);
handler.post(new Runnable() {
@Override
public void run() {
vpEvent.setCurrentItem(listener.currentItem); // 通过Handler切换图片
}
});
}
}
public static class FixedSpeedScroller extends Scroller {
private static final int mDuration = 400;
private int eventCount;
public FixedSpeedScroller(Context context, Interpolator interpolator,int eventCount) {
super(context, interpolator);
this.eventCount = eventCount;
}
@Override
public void startScroll(int startX, int startY, int dx, int dy, int duration) {
if (duration % 100 == 0 && duration > 0) {
//"现在是自动划"
if (duration / 100 == eventCount) super.startScroll(startX, startY, dx, dy, 1);//如果是最后一张
else super.startScroll(startX, startY, dx, dy, mDuration);
} else {
// "现在是手动划"
super.startScroll(startX, startY, dx, dy, 80);
}
}
}
}
在上面适配器的内部类有一个 * ,这个 * 里有一个成员LinearLayout llGuideGroup,这个线性布局里面装有几个小点,下面是这个布局的定义:
<RelativeLayout
android:id="@+id/rlEvents"
android:layout_width="match_parent"
android:layout_height="200dp"
android:visibility="gone">
<android.support.v4.view.ViewPager
android:id="@+id/vpEvent"
android:layout_width="match_parent"
android:layout_height="200dp"
android:background="@color/black666666" />
<LinearLayout
android:id="@+id/llGuideGroup"
android:layout_width="match_parent"
android:layout_height="10dp"
android:layout_alignParentBottom="true"
android:layout_marginBottom="10dp"
android:layout_centerHorizontal="true"
android:gravity="center"
android:orientation="horizontal" >
</LinearLayout>
</RelativeLayout>
设置小圆点的数量并初始化 *
/**
* 向一个线性布局里添加小圆点,具体的控制逻辑在listener里
* @param llGuideGroup
* @param count 要添加多少个小圆点
*/
public EventViewPagerChangeListener addViewPagerDots(LinearLayout llGuideGroup,ViewPager vpEvents,int count){
if(llGuideGroup==null||vpEvents==null||count<1)return null;
LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(15, 15);
lp.leftMargin = 5;
lp.rightMargin = 5;
for(int i=0;i<count;i++){
ImageView imageView = new ImageView(llGuideGroup.getContext());
imageView.setLayoutParams(lp);
imageView.setBackgroundResource(i==0?R.drawable.dot_focused:R.drawable.dot_normal);
llGuideGroup.addView(imageView);
}
//控制小圆点显示的 *
EventViewPagerChangeListener listener = new EventViewPagerChangeListener(llGuideGroup);
vpEvents.addOnPageChangeListener(listener);
return listener;
}
通过多线程实现定时切换页面
HomeHomeBannerAdapter.EventViewPagerChangeListener listener = producer.addViewPagerDots(holder.llGuideGroup,holder.viewPager,eventUrls.length);//添加用于指示的小圆点
// 当Activity显示出来后,每3秒钟切换一次图片显示
ScheduledExecutorService scheduledExecutorService = Executors.newSingleThreadScheduledExecutor();
scheduledExecutorService.scheduleAtFixedRate(new HomeHomeBannerAdapter.ScrollTask(listener,holder.viewPager,eventUrls.length), 3, 3, TimeUnit.SECONDS);
设置自定义滚动器降低viewPager的切换速度
/**
* 给ViewPager设置自定义的滚动器,降低默认的滚动速度
* @param vpEvent
*/
public void setViewPagerScroller(ViewPager vpEvent){
if(vpEvent==null)return;
Field mField;
Scroller mScroller;
try {
mField = ViewPager.class.getDeclaredField("mScroller");
mField.setAccessible(true);
mScroller = new HomeHomeBannerAdapter.FixedSpeedScroller(vpEvent.getContext(), new AccelerateInterpolator(),vpEvent.getChildCount());
try {
mField.set(vpEvent, mScroller);
} catch (IllegalAccessException e) {
e.printStackTrace();
}
} catch (NoSuchFieldException e) {
e.printStackTrace();
}
}
来源:https://blog.csdn.net/lvshaorong/article/details/50763415


猜你喜欢
- 1、接口:一种把类抽象的更彻底,接口里只能包含抽象方法的“特殊类”。接口不关心类的内部状态数据,定义的是一批类所遵守的规范。(它只规定这批类
- 父类空间优先于子类对象产生在每次创建子类对象时,先初始化父类空间,再创建其子类对象本身。目的在于子类对象中包含了其对应的父类空间,便可以包含
- 一、先明确几个基本概念1、伪随机数:pseudo-random number generators ,简称为:PRNGs,是计算机利用一定的
- 首先我们先创建项目 注意:创建SpringBoot项目时一定要联网不然会报错项目创建好后我们首先对 application.yml 进行编译
- 一、获取当前时间, 格式为: yyyy-mm-dd hh-mm-ss
- Java 爬虫工具Jsoup详解Jsoup是一款 Java 的 HTML 解析器,可直接解析某个 URL 地址、HTML 文本内
- 一、实现效果图二、实现代码1.自定义viewpackage com.czhappy.showintroduce.view;import an
- MapTask工作机制如图所示。 (1)Read阶段:MapTask通过用户编写的RecordReader,从输入InputSpl
- 一、ArrayList是什么ArrayList 类是一个可以动态修改的数组,与普通数组的区别就是它是没有固定大小的限制,我们可以添加或删除元
- 23种设计模式第七篇:java代理模式定义:为其他对象提供一种代理以控制对这个对象的访问。在某些情况下,一个对象不适合或者不能直接引用另一个
- Kotlin的对象表达式与Java中的匿名内部类的主要区别:匿名内部类只能指定一个父类型,但对象表达式可以指定0~N个肤类型。一、对象表达式
- 在正常开发中,我们客户端需要用webView加载网页,再遇到网络慢或者访问的服务器响应时,页面是空白的,所以为了用户更好的体验,我们可以提供
- Mybatis与JPA的优缺点JPA java持久层API可理解为一种规范,Hibernate就是其具体一个实现。它的实现应用是Spring
- 前言在消息发送过程中,生产者从NameServer中获取到了指定Topic对应的Broker信息,在同步发送消息的代码中,如果消息发送失败,
- 可能经常看面经的同学都知道,面试所遇到的排序算法,快速排序占主要位置,热度只增不减啊,其次就是归并和堆排序。其实以前写过一篇排序的文章,写的
- 简介现在的app功能越来越强大,除了基本的图文之外,还需要各种各样的其他的功能,比如视频,和直播。直播可能会比较复杂,因为涉及到了拉流和推流
- 本文实例为大家分享了Android实现圆圈倒计时的具体代码,供大家参考,具体内容如下1. 显示效果如下2. 首先是创建shape的xml文件
- 一、spring定时任务执行两次问题重现和解析最近使用quartz定时任务框架,结果发现开发环境执行无任何问题,部署到服务器上后,发现同一时
- 问题描述:1. 项目集成WebSocket,且打包发布tomcat时出现websocket is already in CLOSING or
- Collections工具类Java里关于聚合的工具类,包含有各种有关集合操作的静态多态方法,不能实例化(把构造函数私有化)public c