博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Kotlin超简单实现StepView
阅读量:6161 次
发布时间:2019-06-21

本文共 5980 字,大约阅读时间需要 19 分钟。

TimeLineStepView

支持时间轴和StepView,三种布局,支持水平布局,垂直布局和自定义布局,截图如下

添加依赖

implementation 'com.joketng:TimeLineStepView:1.0.1'复制代码

使用方法

  • 在布局文件中添加TimeLineStepView
复制代码
  • 在代码中调用
//OrientationShowType对应三种布局方式//OrientationShowType.TIMELINE(时间轴方式)//OrientationShowType.CENTER_VERTICAL(垂直方式)//OrientationShowType.CENTER_HORIZONTAL(水平方式,支持左右滑动)rvVertical.initData(listContent, OrientationShowType.CENTER_VERTICAL,                object : TimeLineStepView.OnInitDataCallBack{                    override fun onBindDataViewHolder(holder: TimeLineStepAdapter.CustomViewHolder, position: Int) {                                            }                    override fun createCustomView(leftLayout: ViewGroup, rightLayout: ViewGroup, holder: TimeLineStepAdapter.CustomViewHolder) {                         //LayoutInflater.from(context).inflate(R.layout.item_add_left_view, leftLayout, true)                         //LayoutInflater.from(context).inflate(R.layout.item_add_right_view, rightLayout, true)                    }                })                .setLayoutType(type)//设置布局显示的样式左边:LayoutType.LEFT,右边:LayoutType.RIGHT,左右:LayoutType.ALL                //设置stepview进度激活的mark图标                .setMarkActive(ContextCompat.getDrawable(context,R.drawable.shape_dot_orange)!!)                //设置stepview进度没激活的mark图标                .setMarkInActive(ContextCompat.getDrawable(context,R.drawable.shape_dot_gray)!!)                //设置stepview当前进度点的mark图标                .setMarkCurrent(ContextCompat.getDrawable(context,R.drawable.shape_current)!!)                //设置stepview第一个mark的图标                .setMarkStart(ContextCompat.getDrawable(context,R.drawable.shape_circle_orange)!!)                //设置stepview最后一个mark的图标                .setMarkEnd(ContextCompat.getDrawable(context,R.drawable.shape_circle_orange)!!)                //设置stepview线的宽度                .setLineWidth(context.dipc(2))                //设置stepview进度激活时线的颜色                .setLineActiveColor(ContextCompat.getColor(context,R.color.c_main_orange))                //设置stepview进度没有激活时线的颜色                .setLineInActiveColor(ContextCompat.getColor(context,R.color.c_main_gray))                //设置是否需要自定义布局(此时将createCustomView中的注释打开将自定义布局传入)                .setIsCustom(true)                复制代码

listContent的取值为 mutableListOf(),当存在自定义布局的时候,listContent中添加的实体需要继承BaseBean这个实体,如果不需要自定义布局,可以直接添加实体BaseBean

listContent.add(BaseBean(leftTitle = "11-11", leftTime = "08:30", rightTitle = "订单提交成功", rightTime = "订单提交成功描述", timeLineState = TimeLineState.ACTIVE))        listContent.add(BaseBean(leftTitle = "11-11", leftTime = "08:31", rightTitle = "订单付款成功", rightTime = "订单付款成功描述", timeLineState = TimeLineState.ACTIVE))        listContent.add(BaseBean(leftTitle = "11-11", leftTime = "10:00", rightTitle = "仓库已经接单", rightTime = "仓库已经接单描述", timeLineState = TimeLineState.ACTIVE))        listContent.add(BaseBean(leftTitle = "11-11", leftTime = "10:30", rightTitle = "仓库处理中", rightTime = "仓库处理中描述", timeLineState = TimeLineState.ACTIVE))        listContent.add(BaseBean(leftTitle = "11-11", leftTime = "11:00", rightTitle = "已出库", rightTime = "已出库描述", timeLineState = TimeLineState.ACTIVE))        listContent.add(BaseBean(leftTitle = "11-11", leftTime = "11:30", rightTitle = "已发货", rightTime = "已发货描述", timeLineState = TimeLineState.CURRENT))        listContent.add(BaseBean(leftTitle = "11-11", leftTime = "16:00", rightTitle = "已揽件", rightTime = "已揽件描述", timeLineState = TimeLineState.INACTIVE))        listContent.add(BaseBean(leftTitle = "11-11", leftTime = "16:30", rightTitle = "运输中", rightTime = "运输中描述", timeLineState = TimeLineState.INACTIVE))复制代码

BaseBean的五个参数前四个为控件的文本,前四个参数不传的话该控件就不会显示,最后一个TimeLineState对应进度的三种状态TimeLineState.ACTIVE,TimeLineState.INACTIVE,TimeLineState.CURRENT,根据状态在onBindDataViewHolder方法中设置markdrawable,linecolor等,在设置markSize的时候,如果大小超过30dp,需要在createCustomView方法或者onBindDataViewHolder方法中调用holder.llLine.layoutParams.width设置为大于等于markSize的大小或者设置为WrapContent,如下

holder.llLine.layoutParams.width = context.dip(35)holder.llLine.layoutParams.width = LinearLayout.LayoutParams.WRAP_CONTENT复制代码

对于布局的显示位置有要求的话可以在createCustomView方法中通过layoutParams来控制

val rightLayoutParams = rightLayout.layoutParams as LinearLayout.LayoutParamsrightLayoutParams.rightMargin = context.dip(30)复制代码

如果不喜欢在代码中设置控件属性的话可以选择布局文件中增加属性

复制代码

如果需要可以在onBindDataViewHolder方法中通过holder获取控件改变控件的样式,如果想要添加自定义的UI,可以在createCustomView方法中添加自己定义的布局文件,此时调用setIsCustom(true)即可

rvVertical.initData(listContent, OrientationShowType.CENTER_VERTICAL,                   object : TimeLineStepView.OnInitDataCallBack{                       override fun onBindDataViewHolder(holder: TimeLineStepAdapter.CustomViewHolder, position: Int) {                           holder.tvRightTitle.setTextColor(ContextCompat.getColor(context, R.color.c_main_black))                           holder.tvLeftTitle.setTextColor(ContextCompat.getColor(context, R.color.c_main_black))                           holder.tvRightTime.textSize = 12f                           holder.tvLeftTime.textSize = 12f                           holder.tvRightTime.setTextColor(ContextCompat.getColor(context, R.color.c_main_gray))                           holder.tvLeftTime.setTextColor(ContextCompat.getColor(context, R.color.c_main_gray))                       }                          override fun createCustomView(leftLayout: ViewGroup, rightLayout: ViewGroup, holder: TimeLineStepAdapter.CustomViewHolder) {                            LayoutInflater.from(context).inflate(布局id, leftLayout, true)//添加左边自定义布局                            LayoutInflater.from(context).inflate(布局id, rightLayout, true)//添加右边自定义布局                       }                      }).setLayoutType(type).setIsCustom(true)复制代码

自定义布局的一个截图如下

使用Maven

com.joketng
TimeLineStepView
1.0.1
pom
复制代码

联系方式

如果有什么问题,我没有及时回复的话,可以加我qq542490039,或者发邮件到joketng@163.com,我看到之后会回复的。

转载于:https://juejin.im/post/5be181a8f265da61137ebe32

你可能感兴趣的文章
并行程序设计学习心得1——并行计算机存储
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
css技巧
查看>>
Tyvj 1728 普通平衡树
查看>>
javascript性能优化
查看>>
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>
深入python的set和dict
查看>>
DEV实现日期时间效果
查看>>
java注解【转】
查看>>
centos 下安装g++
查看>>
下一步工作分配
查看>>
Response. AppendHeader使用大全及文件下载.net函数使用注意点(转载)
查看>>
centos64i386下apache 403没有权限访问。
查看>>
jquery用法大全
查看>>