Kotlin超简单实现StepView的方法

 更新时间:2018年11月13日 10:41:46   作者:joketng  
这篇文章主要介绍了Kotlin超简单实现StepView的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

TimeLineStepView

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

 

 

添加依赖

implementation 'com.joketng:TimeLineStepView:1.0.1'

使用方法

在布局文件中添加TimeLineStepView

<com.joketng.timelinestepview.view.TimeLineStepView
    android:id="@+id/rvVertical"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:lineWidth="3dp"
    app:markSize="10dp"
    android:paddingStart="20dp"
    app:markStart="@drawable/shape_circle_orange"
    app:layoutType="right"
    />

在代码中调用

//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.LayoutParams
rightLayoutParams.rightMargin = context.dip(30)

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

<com.joketng.timelinestepview.view.TimeLineStepView
     android:id="@+id/rvVertical"
     android:layout_width="match_parent"
     android:layout_height="wrap_content"
     android:paddingStart="20dp"
     app:markSize="10dp"
     app:markStart="@drawable/shape_circle_orange"
     app:markEnd="@drawable/shape_circle_orange"
     app:markActive="@drawable/shape_dot_orange"
     app:markInActive="@drawable/shape_dot_gray"
     app:markCurrent="@drawable/shape_circle_orange"
     app:lineWidth="3dp"
     app:lineActiveColor="@color/c_main_orange"
     app:lineInActiveColor="@color/c_main_gray"
     app:isCustom="false"
     app:layoutType="right"
     />

如果需要可以在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)

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

 

传送门Github Demo

使用Maven

<dependency>
 <groupId>com.joketng</groupId>
 <artifactId>TimeLineStepView</artifactId>
 <version>1.0.1</version>
 <type>pom</type>
</dependency>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android实现截屏方式整理(总结)

    Android实现截屏方式整理(总结)

    本篇文章主要介绍了Android 截屏方式整理(总结),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • Android程序开发之ListView实现横向滚动(带表头与固定列)

    Android程序开发之ListView实现横向滚动(带表头与固定列)

    这篇文章主要介绍了Android程序开发之ListView实现横向滚动(带表头与固定列)的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • Android 实现手机拨打电话的功能

    Android 实现手机拨打电话的功能

    本篇文章主要介绍 Android 开发手机拨打电话的功能,这里提供示例代码,有兴趣的小伙伴可以参考下
    2016-08-08
  • Android中Service和Activity相互通信示例代码

    Android中Service和Activity相互通信示例代码

    在android中Activity负责前台界面展示,service负责后台的需要长期运行的任务。下面这篇文章主要给大家介绍了关于Android中Service和Activity相互通信的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-09-09
  • Android中SQLite 使用方法详解

    Android中SQLite 使用方法详解

    这篇文章主要介绍了Android中SQLite 使用方法详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • Android实现底部导航栏效果

    Android实现底部导航栏效果

    这篇文章主要为大家详细介绍了Android实现底部导航栏效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • android基于ListView和CheckBox实现多选和全选记录的功能

    android基于ListView和CheckBox实现多选和全选记录的功能

    本篇文章主要介绍了android基于ListView和CheckBox实现多选和全选记录的功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2016-11-11
  • Android实现视频播放--腾讯浏览服务(TBS)功能

    Android实现视频播放--腾讯浏览服务(TBS)功能

    TBS视频播放器可以支持市面上几乎所有的视频格式,包括mp4, flv, avi, 3gp, webm, ts, ogv, m3u8, asf, wmv, rm, rmvb, mov, mkv等18种视频格式。这篇文章主要介绍了Android实现视频播放--腾讯浏览服务(TBS),需要的朋友可以参考下
    2018-07-07
  • Android实现录音声波图

    Android实现录音声波图

    这篇文章主要为大家详细介绍了Android实现录音声波图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • android实现简单仪表盘效果

    android实现简单仪表盘效果

    这篇文章主要为大家详细介绍了android实现简单仪表盘效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-05-05

最新评论