Android中TextView動(dòng)態(tài)設(shè)置縮進(jìn)距離的方法
需求是需要在TextView前端加入一個(gè)標(biāo)簽展示。
最終效果圖如下:
根據(jù)效果圖,很容易就能想到使用SpannableStringBuilder,在這里使用到的就是LeadingMarginSpan這個(gè)類了。
官方說明: A paragraph style affecting the leading margin. There can be multiple leading margin spans on a single paragraph; they will be rendered in order, each adding its margin to the ones before it. The leading margin is on the right for lines in a right-to-left paragraph.
LeadingMarginSpans should be attached from the first character to the last character of a single paragraph.
簡(jiǎn)單說,就是設(shè)置段落的縮進(jìn)距離。
相關(guān)API使用:
val spannableString = SpannableString(text) val what = LeadingMarginSpan.Standard(width, 0) spannableString.setSpan(what, 0, spannableString.length, SpannableString.SPAN_INCLUSIVE_INCLUSIVE)
LeadingMarginSpan是接口,內(nèi)部的Standard是它的標(biāo)準(zhǔn)實(shí)現(xiàn)方式。有兩個(gè)構(gòu)造方法,Standard(int every)和Standard(int first, int rest)。Standard(int every)是給每一行都設(shè)置同樣的縮進(jìn)距離,而Standard(int first, int rest)是給第一行和其他行分別設(shè)置縮進(jìn)距離。我們這里使用的就是Standard(int first, int rest)實(shí)現(xiàn)方式了。 接下來setSpan方法,如果有使用過其他的ForegroundColorSpan、AbsoluteSizeSpan等span就不陌生了。傳入四個(gè)參數(shù),第一個(gè)參數(shù)就是創(chuàng)建出來的Span,第二個(gè)參數(shù)和第三個(gè)參數(shù)為Span作用的范圍,第四個(gè)參數(shù)表示是否包含前后邊界,INCLUSIVE就是表示包含邊界,EXCLUSIVE就是不包含邊界了。
知道了怎么設(shè)置縮進(jìn)距離之后,接下去就是要獲取到標(biāo)簽的寬度。標(biāo)簽是View,只有在View渲染完成之后才能獲取到準(zhǔn)確的寬度。這里使用的方法就是獲取到標(biāo)簽View的viewTreeObserver,然后addOnPreDrawListener,需要注意獲取到寬度之后就及時(shí)removeOnPreDrawListener。具體實(shí)現(xiàn)如下:
class MainActivity2 : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val tv1 = findViewById<TextView>(R.id.tv1) val tv2 = findViewById<TextView>(R.id.tv2) tv1.text = "New" calculateTag(tv1, tv2, "This is a long long long long title") } //動(dòng)態(tài)設(shè)置縮進(jìn)距離 fun calculateTag(tag: TextView, title: TextView, text: String?) { val observer = tag.viewTreeObserver observer.addOnPreDrawListener(object : ViewTreeObserver.OnPreDrawListener { override fun onPreDraw(): Boolean { val spannableString = SpannableString(text) val what = LeadingMarginSpan.Standard(tag.width + dip2px(this@MainActivity2, 3.0), 0) spannableString.setSpan( what, 0, spannableString.length, SpannableString.SPAN_INCLUSIVE_INCLUSIVE ) title.text = spannableString tag.viewTreeObserver.removeOnPreDrawListener( this ) return false } }) } fun dip2px(context: Context, dpValue: Double): Int { val density: Float = context.resources.displayMetrics.density return (dpValue * density + 0.5).toInt() } }
布局文件:
<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent"> <FrameLayout android:layout_width="200dp" android:layout_height="wrap_content" android:layout_marginStart="10dp" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent"> <TextView android:id="@+id/tv1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="5dp" android:layout_marginEnd="3dp" android:background="@drawable/bg_tag" android:includeFontPadding="false" android:paddingHorizontal="2dp" android:textColor="@color/white" android:textSize="13sp" /> <TextView android:id="@+id/tv2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textColor="@color/black" android:textSize="17sp" android:textStyle="normal" /> </FrameLayout> </androidx.constraintlayout.widget.ConstraintLayout>
總結(jié)
到此這篇關(guān)于Android中TextView動(dòng)態(tài)設(shè)置縮進(jìn)距離的文章就介紹到這了,更多相關(guān)Android TextView縮進(jìn)距離內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
android二級(jí)listview列表實(shí)現(xiàn)代碼
今天來實(shí)現(xiàn)以下大眾點(diǎn)評(píng)客戶端的橫向listview二級(jí)列表,感興趣的朋友可以研究下2013-01-012021最新Android筆試題總結(jié)美團(tuán)Android崗職能要求
這篇文章主要介紹了2021最新Android筆試題總結(jié)以及美團(tuán)Android崗職能要求,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-08-08Android判斷App前臺(tái)運(yùn)行還是后臺(tái)運(yùn)行(運(yùn)行狀態(tài))
這篇文章主要介紹了Android判斷App前臺(tái)運(yùn)行還是后臺(tái)運(yùn)行的相關(guān)資料,需要的朋友可以參考下2016-04-04Android 利用三階貝塞爾曲線繪制運(yùn)動(dòng)軌跡的示例
本篇文章主要介紹了Android 利用三階貝塞爾曲線繪制運(yùn)動(dòng)軌跡的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-03-03Android手機(jī)聯(lián)系人帶字母索引的快速查找
這篇文章主要為大家詳細(xì)介紹了Android手機(jī)聯(lián)系人帶字母索引的快速查找實(shí)現(xiàn)方法,感興趣的小伙伴們可以參考一下2016-03-03Android 8.0如何完美適配全局dialog懸浮窗彈出
這篇文章主要給大家介紹了關(guān)于Android 8.0如何完美適配全局dialog懸浮窗彈出的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起看看吧2018-07-07Android編程之ICS式下拉菜單PopupWindow實(shí)現(xiàn)方法詳解(附源碼下載)
這篇文章主要介紹了Android編程之ICS式下拉菜單PopupWindow實(shí)現(xiàn)方法,結(jié)合實(shí)例詳細(xì)分析了ICS式下拉菜單的實(shí)現(xiàn)原理與相關(guān)技巧,并附帶源碼供讀者下載,需要的朋友可以參考下2015-12-12設(shè)備APP開發(fā)環(huán)境配置細(xì)節(jié)介紹
隨著工業(yè)自動(dòng)化的不斷發(fā)展,設(shè)備APP也越來越重要,本文就設(shè)備APP開發(fā)軟件配置細(xì)節(jié)做一個(gè)深入詳解2022-09-09Android?實(shí)現(xiàn)卡片堆疊錢包管理動(dòng)畫效果
這篇文章主要介紹了Android?實(shí)現(xiàn)卡片堆疊錢包管理動(dòng)畫效果,實(shí)現(xiàn)思路是在動(dòng)畫回調(diào)中requestLayout?實(shí)現(xiàn)動(dòng)畫效果,用Bounds?對(duì)象記錄每一個(gè)CardView?對(duì)象的初始位置,當(dāng)前位置,運(yùn)動(dòng)目標(biāo)位置,需要的朋友可以參考下2022-07-07