漂亮而强大的IndicatorSeekBar,滑动显示进度气泡指示器

本文项目地址:https://github.com/warkiz/IndicatorSeekBar

IndicatorSeekBar

漂亮而强大的IndicatorSeekBar,滑动显示进度气泡指示器_第1张图片
overview.png

在 上一篇分享的文章中,笔者介绍了IndicatorSeekBar的编写的基本思路和主要代码,在本篇文章中,笔者主要介绍IndicatorSeekBar的基本使用姿势。

项目介绍:
Android 自定义SeekBar, 能改变尺寸、颜色、滑块(thumb)图片、刻度(tick)图片、刻度文字(text)和气泡指示器(indicator),当滑动时显示带有进度的气泡指示器。

如果需要英文版,点击: English here


惯例, 先上截图:

漂亮而强大的IndicatorSeekBar,滑动显示进度气泡指示器_第2张图片
custom.gif
漂亮而强大的IndicatorSeekBar,滑动显示进度气泡指示器_第3张图片
java_build.gif

更多 gif 演示场景请查看:https://github.com/warkiz/IndicatorSeekBar/blob/master/README.md

2. 使用

1. 先在app/build.gradle下引入:

dependencies {
    compile 'com.github.warkiz.widget:indicatorseekbar:1.1.2'
}

2. 在布局文件或java类中使用:

xml



or Java

IndicatorSeekBar indicatorSeekBar = new IndicatorSeekBar.Builder(this)
                .setMax(200)
                .setMin(0)
                .setProgress(35)
                .setSeekBarType(IndicatorSeekBarType.DISCRETE_TICKS)
                .setTickType(TickType.OVAL)
                .setTickColor(Color.parseColor("#0000FF"))
                .setTickSize(8)//dp size
                .setTickNum(8)
                .setBackgroundTrackSize(2)//dp size
                .setBackgroundTrackColor(Color.parseColor("#666666"))
                .setProgressTrackSize(3)//dp size
                .setProgressTrackColor(Color.parseColor("#0000FF"))
                .showIndicator(true)
                .setIndicatorType(IndicatorType.SQUARE_CORNERS)
                .setIndicatorColor(Color.parseColor("#0000FF"))
                .build();

更多使用方式请参考源码Demo : https://github.com/warkiz/IndicatorSeekBar


3. 支持的功能

3.1 多种的SeekBar类型

IndicatorSeekBar 提供了两种系列的类型:

  1. 连续(continuous)的滑动: CONTINUOUS/CONTINUOUS_TEXTS_ENDS.

  2. 非连续(discrete)的滑动: DISCRETE_TICKS/ DISCRETE_TICKS_TEXTS/ DISCRETE_TICKS_TEXTS_ENDS.

使用时引用一种type类型:


3.2 自定义 颜色、尺寸

SeekBar以下部分的颜色或尺寸可以被自定义,可按照业务需求自定义size和color。

漂亮而强大的IndicatorSeekBar,滑动显示进度气泡指示器_第4张图片
overview.png
  • 背景条 track_background_bar
  • 进度条 track_progress_bar
  • 刻度 tick
  • 刻度文字 text
  • 滑块 thumb
  • 指示器 indicator
  • 指示器文字 indicator_text

自定义尺寸和颜色功能适合大部分业务需求。

3.3 隐藏刻度tick

SeekBar的两个端点的刻度或者滑块左边的刻度可以被隐藏。




3.4 给SeekBar选择圆角/方角

默认两端是圆角,可以设置为方形。


3.5 滑块thumb下显示进度

当 seekabr 的类型为 CONTINUOUS or DISCRETE_TICKS时 , 可以设置滑动后滑块下显示保留进度。


3.6 自定义SeekBar两端的文字text

当 seekabr 的类型是 CONTINUOUS_TEXTS_ENDSDISCRETE_TICKS_TEXTS_ENDS 时, 可以设置两端的文字.


3.7 自定义刻度下的文字text

当 seekabr 的类型是 DISCRETE_TICKS_TEXTS , 可以通过设置数组的方式自定义刻度下的文字, 数组的长度应当和刻度相等。


or
indicatorSeekBar.setTextArray(R.array.texts_below_tick_length_5);

3.8 自定义滑块thumb的图片

滑块可以使用图片去自定义:


3.9 自定义刻度tick的图片

刻度可以使用图片去自定义.


3.10 自定义指示器indicator

IndicatorSeekbar提供了3种指示器的类型: ROUNDED_CORNERS / SQUARE_CORNERS / CUSTOM,当指示器的类型为 CUSTOM 时, 可以自定义指示器的view.


or
indicatorSeekBar.setCustomIndicator(R.layout.indicator);

注意:如果自定义指示器需要显示进度, 那么指示器必须要有一个TextView,而且其id必须设置为isb_progress.

3.11 自定义指示器顶部的内容

当 indicator 的类型为 ROUNDED_CORNERS 或者 SQUARE_CORNERS , 可以设置指示器顶部的view.


or
indicatorSeekBar.getIndicator().setIndicatorTopContentLayout(R.layout.top_content_view);

注意:如果自定义指示器顶部的view需要显示进度, 那么这个view必须要有一个TextView,而且其id必须设置为isb_progress.

4. 支持进度监听

indicatorSeekBar.setOnSeekChangeListener(new IndicatorSeekBar.OnSeekBarChangeListener() {

    @Override
    public void onProgressChanged(IndicatorSeekBar seekBar, int progress, float progressFloat, boolean fromUserTouch) {

    }

    @Override
    public void onSectionChanged(IndicatorSeekBar seekBar, int thumbPosOnTick, String textBelowTick, boolean fromUserTouch) {
        //only callback on discrete series SeekBar type.
    }

    @Override
    public void onStartTrackingTouch(IndicatorSeekBar seekBar, int thumbPosOnTick) {
    }

    @Override
    public void onStopTrackingTouch(IndicatorSeekBar seekBar) {

    }
});

onSectionChanged: 当SeekBar的类型为非连续 discrete系列 时, 这个回调会获得滑块的位置和滑块下的文字. 当为连续 continuous系列则不回调。

5. 混淆配置

-keep class com.warkiz.widget.** { *; }

6. 支持多种自定义属性

自定义的属性较多,具体的属性介绍可参照以下 源码文档介绍。

行文至此,笔者对里IndicatorSeekBar的介绍也要完结了。
通过这篇文章,相信你已经对IndicatorSeekBar的使用有了大体的感知与认识,若想更深入了解源码,可去GitHub阅读原作者的源码。

源码地址:https://github.com/warkiz/IndicatorSeekBar

IndicatorSeekBar实现思路:http://www.jianshu.com/p/debb0541b219

你可能感兴趣的:(漂亮而强大的IndicatorSeekBar,滑动显示进度气泡指示器)