文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Android中TextView怎么动态设置缩进距离

2023-06-30 09:35

关注

本文小编为大家详细介绍“Android中TextView怎么动态设置缩进距离”,内容详细,步骤清晰,细节处理妥当,希望这篇“Android中TextView怎么动态设置缩进距离”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

需求是需要在TextView前端加入一个标签展示。

最终效果图如下:

Android中TextView怎么动态设置缩进距离

根据效果图,很容易就能想到使用SpannableStringBuilder,在这里使用到的就是LeadingMarginSpan这个类了。

官方说明: 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.

简单说,就是设置段落的缩进距离。

相关API使用:

val spannableString = SpannableString(text)val what = LeadingMarginSpan.Standard(width, 0)spannableString.setSpan(what, 0, spannableString.length, SpannableString.SPAN_INCLUSIVE_INCLUSIVE)

LeadingMarginSpan是接口,内部的Standard是它的标准实现方式。有两个构造方法,Standard(int every)和Standard(int first, int rest)。Standard(int every)是给每一行都设置同样的缩进距离,而Standard(int first, int rest)是给第一行和其他行分别设置缩进距离。我们这里使用的就是Standard(int first, int rest)实现方式了。 接下来setSpan方法,如果有使用过其他的ForegroundColorSpan、AbsoluteSizeSpan等span就不陌生了。传入四个参数,第一个参数就是创建出来的Span,第二个参数和第三个参数为Span作用的范围,第四个参数表示是否包含前后边界,INCLUSIVE就是表示包含边界,EXCLUSIVE就是不包含边界了。

知道了怎么设置缩进距离之后,接下去就是要获取到标签的宽度。标签是View,只有在View渲染完成之后才能获取到准确的宽度。这里使用的方法就是获取到标签View的viewTreeObserver,然后addOnPreDrawListener,需要注意获取到宽度之后就及时removeOnPreDrawListener。具体实现如下:

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")    }    //动态设置缩进距离    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怎么动态设置缩进距离”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯