溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Android中TextView怎么動(dòng)態(tài)設(shè)置縮進(jìn)距離

發(fā)布時(shí)間:2022-04-25 09:09:07 來源:億速云 閱讀:310 作者:iii 欄目:開發(fā)技術(shù)

本文小編為大家詳細(xì)介紹“Android中TextView怎么動(dòng)態(tài)設(shè)置縮進(jìn)距離”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Android中TextView怎么動(dòng)態(tài)設(shè)置縮進(jìn)距離”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

需求是需要在TextView前端加入一個(gè)標(biāo)簽展示。

最終效果圖如下:

Android中TextView怎么動(dòng)態(tài)設(shè)置縮進(jìn)距離

根據(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.

簡單說,就是設(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>

讀到這里,這篇“Android中TextView怎么動(dòng)態(tài)設(shè)置縮進(jìn)距離”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI