欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Kotlin超簡單實現(xiàn)StepView的方法

 更新時間:2018年11月13日 10:41:46   作者:joketng  
這篇文章主要介紹了Kotlin超簡單實現(xiàn)StepView的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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"
    />

在代碼中調(diào)用

//OrientationShowType對應(yīng)三種布局方式
//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)//設(shè)置布局顯示的樣式左邊:LayoutType.LEFT,右邊:LayoutType.RIGHT,左右:LayoutType.ALL
        //設(shè)置stepview進度激活的mark圖標(biāo)
        .setMarkActive(ContextCompat.getDrawable(context,R.drawable.shape_dot_orange)!!)
        //設(shè)置stepview進度沒激活的mark圖標(biāo)
        .setMarkInActive(ContextCompat.getDrawable(context,R.drawable.shape_dot_gray)!!)
        //設(shè)置stepview當(dāng)前進度點的mark圖標(biāo)
        .setMarkCurrent(ContextCompat.getDrawable(context,R.drawable.shape_current)!!)
        //設(shè)置stepview第一個mark的圖標(biāo)
        .setMarkStart(ContextCompat.getDrawable(context,R.drawable.shape_circle_orange)!!)
        //設(shè)置stepview最后一個mark的圖標(biāo)
        .setMarkEnd(ContextCompat.getDrawable(context,R.drawable.shape_circle_orange)!!)
        //設(shè)置stepview線的寬度
        .setLineWidth(context.dipc(2))
        //設(shè)置stepview進度激活時線的顏色
        .setLineActiveColor(ContextCompat.getColor(context,R.color.c_main_orange))
        //設(shè)置stepview進度沒有激活時線的顏色
        .setLineInActiveColor(ContextCompat.getColor(context,R.color.c_main_gray))
        //設(shè)置是否需要自定義布局(此時將createCustomView中的注釋打開將自定義布局傳入)
        .setIsCustom(true)

listContent的取值為 mutableListOf(),當(dāng)存在自定義布局的時候,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 = "倉庫已經(jīng)接單", rightTime = "倉庫已經(jīng)接單描述", 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 = "已發(fā)貨", rightTime = "已發(fā)貨描述", 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的五個參數(shù)前四個為控件的文本,前四個參數(shù)不傳的話該控件就不會顯示,最后一個TimeLineState對應(yīng)進度的三種狀態(tài)TimeLineState.ACTIVE,TimeLineState.INACTIVE,TimeLineState.CURRENT,根據(jù)狀態(tài)在onBindDataViewHolder方法中設(shè)置markdrawable,linecolor等,在設(shè)置markSize的時候,如果大小超過30dp,需要在createCustomView方法或者onBindDataViewHolder方法中調(diào)用holder.llLine.layoutParams.width設(shè)置為大于等于markSize的大小或者設(shè)置為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)

如果不喜歡在代碼中設(shè)置控件屬性的話可以選擇布局文件中增加屬性

<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方法中添加自己定義的布局文件,此時調(diào)用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>

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Android實現(xiàn)截屏方式整理(總結(jié))

    Android實現(xiàn)截屏方式整理(總結(jié))

    本篇文章主要介紹了Android 截屏方式整理(總結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • Android程序開發(fā)之ListView實現(xiàn)橫向滾動(帶表頭與固定列)

    Android程序開發(fā)之ListView實現(xiàn)橫向滾動(帶表頭與固定列)

    這篇文章主要介紹了Android程序開發(fā)之ListView實現(xiàn)橫向滾動(帶表頭與固定列)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-07-07
  • Android 實現(xiàn)手機撥打電話的功能

    Android 實現(xiàn)手機撥打電話的功能

    本篇文章主要介紹 Android 開發(fā)手機撥打電話的功能,這里提供示例代碼,有興趣的小伙伴可以參考下
    2016-08-08
  • Android中Service和Activity相互通信示例代碼

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

    在android中Activity負(fù)責(zé)前臺界面展示,service負(fù)責(zé)后臺的需要長期運行的任務(wù)。下面這篇文章主要給大家介紹了關(guān)于Android中Service和Activity相互通信的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-09-09
  • Android中SQLite 使用方法詳解

    Android中SQLite 使用方法詳解

    這篇文章主要介紹了Android中SQLite 使用方法詳解的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • Android實現(xiàn)底部導(dǎo)航欄效果

    Android實現(xiàn)底部導(dǎo)航欄效果

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)底部導(dǎo)航欄效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • android基于ListView和CheckBox實現(xiàn)多選和全選記錄的功能

    android基于ListView和CheckBox實現(xiàn)多選和全選記錄的功能

    本篇文章主要介紹了android基于ListView和CheckBox實現(xiàn)多選和全選記錄的功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2016-11-11
  • Android實現(xiàn)視頻播放--騰訊瀏覽服務(wù)(TBS)功能

    Android實現(xiàn)視頻播放--騰訊瀏覽服務(wù)(TBS)功能

    TBS視頻播放器可以支持市面上幾乎所有的視頻格式,包括mp4, flv, avi, 3gp, webm, ts, ogv, m3u8, asf, wmv, rm, rmvb, mov, mkv等18種視頻格式。這篇文章主要介紹了Android實現(xiàn)視頻播放--騰訊瀏覽服務(wù)(TBS),需要的朋友可以參考下
    2018-07-07
  • Android實現(xiàn)錄音聲波圖

    Android實現(xiàn)錄音聲波圖

    這篇文章主要為大家詳細(xì)介紹了Android實現(xiàn)錄音聲波圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • android實現(xiàn)簡單儀表盤效果

    android實現(xiàn)簡單儀表盤效果

    這篇文章主要為大家詳細(xì)介紹了android實現(xiàn)簡單儀表盤效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05

最新評論