专栏名称: saka
目录
相关文章推荐
51好读  ›  专栏  ›  saka

分享一个我编写的简单时间线控件

saka  · 掘金  ·  · 2018-07-28 02:10

正文

一个简单的时间线控件,采用RecyclerView实现,无任何三方依赖库,一个纯净的库。主要特性:

  1. 可定制timeline的icon图标,每个图标可以通过list作为参数传入
  2. 可定制item布局,每个item中的view都可通过anchor注解来设置不同的style
  3. 支持时间线的前景色和后景色,采用src_in方式覆盖
  4. 时间线进度可随意控制,可以实现10%,15%,96%等进度
  5. 采用编译期注解,在运行期未使用反射
  6. 支持四种时间线位置,item大小不同时会自动进行位置对齐。比如时间线在上方,所有的item会自动顶部对齐。
  7. 支持三种时间线模式

这是朋友应用的效果:

0.2.4更新:

新增可以控制icon大小的属性:

app:timeLineIconHeight="30dp"
app:timeLineIconWidth="30dp"

新增样式

app:strokeType="midEndPoint"

如图:

未设置该大小时会自动设置成为timePadding的三分之二;当其中一个设置另一个未设置时, 未设置的值会自动设置成为已设置的值。

可以设置dividerNum为浮点型,会自动调整进度,这种形式在noEndPoint模式下工作最好。

集成方式

    implementation 'com.rangaofei:sakatimeline:0.2.4'
    annotationProcessor 'com.rangaofei:JavaTimeLine:0.2.4'

然后修改app级别的module的build.gradle 文件:

android {

    defaultConfig {

        //省略代码
        javaCompileOptions{
            annotationProcessorOptions.includeCompileClasspath=true
        }
    }
}

假如没出现问题的话就集成成功了

使用StepView

StepView基于注解

StepView内部使用apt处理注解实现了adapter,adapter包含两种布局,key和value。目前推出的只需要使用value布局即可。

首先要定义一个model,这个model要编写一些注解

@TimeLine(valueLayoutId = "R.layout.item_value")
public class StepViewModel {

    @TimeLineTextView(key = false, value = "R.id.value")
    public String text;

    public StepViewModel(String text) {
        this.text = text;
    }

    public String getText() {
        return text;
    }

    public void setText(String text) {
        this.text = text;
    }
}

注意,每个变量必须采用public修饰,否则获取不到变量的值(其实是目前我没有做任何getter和setter方法)

然后先build一次,在需要使用model的时候要写入

private AbstractTimeLineAdapter adapter;

private List<StepViewModel> stepViewModels = new ArrayList<>();

系统会自动生成一个StepViewModelViewAdapter文件,这个adapter需要传入一个list作为数据源, 这个list中的item类型必须设置为被标注为TimeLine的类。

stepViewModels.add(new StepViewModel("快递发出"));
stepViewModels.add(new StepViewModel("快递签收"));
stepViewModels.add(new StepViewModel("快递丢失"));
adapter = new StepViewModelAdapter(stepViewModels);
binding.tlv.setTimeLineConfig(adapter, TimeLineType.StepViewType.RIGHT_STEP_PROGRESS);

这样我们就完成了基本设置。 运行可以看到效果图:

## 为item设置不同的样式

注意:目前只支持textview的部分属性的不同样式设置,支持imageview的src显示。

同样是前边的类,稍微修改一下:

@TimeLine(valueLayoutId = "R.layout.item_value")
public class StepViewModel {

    @TimeLineTextView(key = false, id = "R.id.value", style = "R.style.StepView1", styleAnchor = "R.style.StepView2")
    public String text;
    @TimeLineAnchor({"R.id.value"})
    public boolean right;

    public StepViewModel(String text, boolean right) {
        this.text = text;
        this.right = right;
    }

    public String getText() {
        return text;
    }

    public void setText(String text) {
        this.text = text;
    }
}

我们为TimeLineTextView加上了style和styleAnchor的值,这两个值是自己定义的style样式,这些样式只包含部分attr

    <attr name="android:textSize"/>
    <attr name="android:textColor"/>
    <attr name="android:textColorHint"/>
    <attr name="android:textColorLink"/>
    <attr name="android:textStyle"/>
    <attr name="android:typeface"/>
    <attr name="android:fontFamily"/>
    <attr name="android:shadowColor"/>
    <attr name="android:shadowDy"/>
    <attr name="android:shadowDx"/>
    <attr name="android:shadowRadius"/>

下面是示例中定义的两个style:

<style name="StepView1" parent="AppTheme">
    <item name="android:textSize">14sp</item>
    <item name="android:textColor">@color/white</item>
</style>

<style name="StepView2" parent="AppTheme">
    <item name="android:textSize">20sp</item>
    <item name="android:textColor">@color/black</item>
    <item name="backgroundProxy">@color/white</item>
</style>

修改主界面代码:

stepViewModels.add(new StepViewModel("快递发出\n我没收到", false));
stepViewModels.add(new StepViewModel("快递签收我收到了", false));
stepViewModels.add(new StepViewModel("快递丢失", true));

可以看到第三个item设置为true了,那么StepViewModel中的@TextView注解中的styleAnchor将会生效, 其他未设置为true的item生效的将会是@TextView注解中的style。







请到「今天看啥」查看全文