Indicatorview--轮播图指示器

Android 封装--IndicatorView--轮播图指示器

作者:

使用场景

大多数App里都会有Banner轮播的效果,Android中实现此类功能一般是ViewPager配合Indicator指示器,实现滑动效果,配合定时器实现自动轮播及无限轮播效果,此类控件网上也有很多,最有名的要数JakeWharton大神的ViewPagerIndicator
此处实现的简单的ViewPager和Indicator联动及自动轮播,只有一个自定义View实现指示器功能,实现measure和layout,不需要太多的东西。

功能描述

通过自定义View实现Indicator的绘制及布局,提供设置ViewPager的方法,实现ViewPager与Indicator联动,通过Handler发送延时任务实现自动轮播,通过反射修改翻页时间。提供自定义属性设置默认选中项,指示器间距,以及指示器图片资源。

  • 关联ViewPager
/** @param realSize 实际数据大小,通过设置Integer.MAX_VALUE实现无限轮播,需要实际大小*/
public void setUpWithViewPager(ViewPager pager, int realSize) {
    this.viewPager = pager;
    pager.addOnPageChangeListener(this);
    PagerAdapter pagerAdapter = pager.getAdapter();
    if(pagerAdapter == null) {
        throw new RuntimeException("setAdapter must be call before");
    }
    if(pagerAdapter.getCount() <= 1) {
        this.setVisibility(GONE);
    } else {
        this.setVisibility(VISIBLE);
        setSelection(0);
    }
}
  • 修改翻页时间
try {
    Field mField = ViewPager.class.getDeclaredField("mScroller");
    mField.setAccessible(true);
    FixedSpeedScroller mScroller = new FixedSpeedScroller(viewPager.getContext(), new AccelerateInterpolator());
    mField.set(viewPager, mScroller);
} catch (Exception e) {
    e.printStackTrace();
}
private static class FixedSpeedScroller extends Scroller {
        private int mDuration = 500;

        public FixedSpeedScroller(Context context) {
            super(context);
        }

        public FixedSpeedScroller(Context context, Interpolator interpolator) {
            super(context, interpolator);
        }

        @Override
        public void startScroll(int startX, int startY, int dx, int dy, int duration) {
            // Ignore received duration, use fixed one instead
            super.startScroll(startX, startY, dx, dy, mDuration);
        }

        @Override
        public void startScroll(int startX, int startY, int dx, int dy) {
            // Ignore received duration, use fixed one instead
            super.startScroll(startX, startY, dx, dy, mDuration);
        }

        public void setDuration(int time) {
            mDuration = time;
        }

    }
  • 布局中使用
<com.adinnet.widget.IndicatorView
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    app:indicator="@mipmap/icon_delete"
    app:selection="1"
    app:interval="10dp"/>

添加依赖

  • 在Project的gradle添加仓库地址
repositories {
//        jcenter()
    maven{url "http://10.40.255.100:8081/artifactory/libs-release-local"}
    maven{url "http://10.40.255.100:8081/artifactory/jcenter"}
}
  • 在主项目的gradle添加依赖
dependencies {
    compile 'com.adinnet.widget:indicatorview:1.0.0'
}

推荐阅读更多精彩内容