麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 開發(fā) > 綜合 > 正文

Kotlin超簡(jiǎn)單實(shí)現(xiàn)StepView的方法

2024-07-21 23:03:51
字體:
供稿:網(wǎng)友

TimeLineStepView

支持時(shí)間軸和StepView,三種布局,支持水平布局,垂直布局和自定義布局,截圖如下

Kotlin,StepView

Kotlin,StepView

Kotlin,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對(duì)應(yīng)三種布局方式//OrientationShowType.TIMELINE(時(shí)間軸方式)//OrientationShowType.CENTER_VERTICAL(垂直方式)//OrientationShowType.CENTER_HORIZONTAL(水平方式,支持左右滑動(dòng))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進(jìn)度激活的mark圖標(biāo)        .setMarkActive(ContextCompat.getDrawable(context,R.drawable.shape_dot_orange)!!)        //設(shè)置stepview進(jìn)度沒激活的mark圖標(biāo)        .setMarkInActive(ContextCompat.getDrawable(context,R.drawable.shape_dot_gray)!!)        //設(shè)置stepview當(dāng)前進(jìn)度點(diǎn)的mark圖標(biāo)        .setMarkCurrent(ContextCompat.getDrawable(context,R.drawable.shape_current)!!)        //設(shè)置stepview第一個(gè)mark的圖標(biāo)        .setMarkStart(ContextCompat.getDrawable(context,R.drawable.shape_circle_orange)!!)        //設(shè)置stepview最后一個(gè)mark的圖標(biāo)        .setMarkEnd(ContextCompat.getDrawable(context,R.drawable.shape_circle_orange)!!)        //設(shè)置stepview線的寬度        .setLineWidth(context.dipc(2))        //設(shè)置stepview進(jìn)度激活時(shí)線的顏色        .setLineActiveColor(ContextCompat.getColor(context,R.color.c_main_orange))        //設(shè)置stepview進(jìn)度沒有激活時(shí)線的顏色        .setLineInActiveColor(ContextCompat.getColor(context,R.color.c_main_gray))        //設(shè)置是否需要自定義布局(此時(shí)將createCustomView中的注釋打開將自定義布局傳入)        .setIsCustom(true)

listContent的取值為 mutableListOf(),當(dāng)存在自定義布局的時(shí)候,listContent中添加的實(shí)體需要繼承BaseBean這個(gè)實(shí)體,如果不需要自定義布局,可以直接添加實(shí)體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 = "倉(cāng)庫(kù)已經(jīng)接單", rightTime = "倉(cāng)庫(kù)已經(jīng)接單描述", timeLineState = TimeLineState.ACTIVE))    listContent.add(BaseBean(leftTitle = "11-11", leftTime = "10:30", rightTitle = "倉(cāng)庫(kù)處理中", rightTime = "倉(cāng)庫(kù)處理中描述", timeLineState = TimeLineState.ACTIVE))    listContent.add(BaseBean(leftTitle = "11-11", leftTime = "11:00", rightTitle = "已出庫(kù)", rightTime = "已出庫(kù)描述", 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 = "運(yùn)輸中", rightTime = "運(yùn)輸中描述", timeLineState = TimeLineState.INACTIVE))

BaseBean的五個(gè)參數(shù)前四個(gè)為控件的文本,前四個(gè)參數(shù)不傳的話該控件就不會(huì)顯示,最后一個(gè)TimeLineState對(duì)應(yīng)進(jìn)度的三種狀態(tài)TimeLineState.ACTIVE,TimeLineState.INACTIVE,TimeLineState.CURRENT,根據(jù)狀態(tài)在onBindDataViewHolder方法中設(shè)置markdrawable,linecolor等,在設(shè)置markSize的時(shí)候,如果大小超過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

對(duì)于布局的顯示位置有要求的話可以在createCustomView方法中通過layoutParams來控制

val rightLayoutParams = rightLayout.layoutParams as LinearLayout.LayoutParamsrightLayoutParams.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方法中添加自己定義的布局文件,此時(shí)調(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)

自定義布局的一個(gè)截圖如下

Kotlin,StepView

傳送門Github Demo

使用Maven

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

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到kotlin教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 一级免费大片 | 欧美性受xxxx人人本视频 | 视屏一区| 高清国产午夜精品久久久久久 | 永久免费在线观看av | 日韩精品中文字幕一区 | 一级毛片特黄 | 亚洲一级电影在线观看 | 香蕉国产9| 欧美成人做爰高潮片免费视频 | 久久精品站 | 精品国产一区二区三区久久久狼牙 | 鲁丝一区二区二区四区 | www.国产一区.com | 久久综合久久美利坚合众国 | 美女在线观看视频一区二区 | 成年人黄色免费网站 | www.guochanav.com| 国产精品成人免费一区久久羞羞 | 午夜精品区 | 欧美成人免费一级 | 草逼一区| www深夜成人 | 99精品视频一区二区三区 | 黄色毛片视频在线观看 | 国产资源视频在线观看 | 日韩在线播放第一页 | 久久久久国产成人精品亚洲午夜 | 一级毛片真人免费播放视频 | 久久国产精品99国产 | 欧产日产国产精品99 | www.17c亚洲蜜桃| 久久另类视频 | 精品国产91久久久久久久 | v11av在线播放 | 亚洲成人免费网站 | 草莓福利视频在线观看 | 国产精品一品二区三区四区18 | 国产一级毛片高清视频 | h视频在线观看免费 | 日韩电影一区二区三区 |