Android 在同一个TextView中展示不同颜色、不同字体大小

同一个TextView中展示不同颜色

xml代码片段

 <androidx.appcompat.widget.AppCompatTextView
        android:id="@+id/tangram"
        android:layout_width="match_parent"
        android:layout_height="@dimen/x50"
        android:gravity="center"
        android:text="" />

 <androidx.appcompat.widget.AppCompatTextView
        android:id="@+id/tangram1"
        android:layout_width="match_parent"
        android:layout_height="@dimen/x50"
        android:gravity="center"
        android:text="" />

kotlin代码片段
①通过Html.fromHtml()来实现

        tangram.text =  Html.fromHtml("<font color=\"#FFA500\">登录</font><font color=\"#0000FF\">即代表同意</font><font color=\"#ADFF2F\">《用户使用协议》</font>")

②通过SpannableString来实现

  val spannableString = SpannableString("登录即代表同意《用户使用协议》")
        spannableString.setSpan(
            ForegroundColorSpan(Color.parseColor("#FFA500")),
            0, 2,
            Spanned.SPAN_EXCLUSIVE_EXCLUSIVE
        )
        spannableString.setSpan(
            ForegroundColorSpan(Color.parseColor("#0000FF")),
            2, 7,
            Spanned.SPAN_INCLUSIVE_INCLUSIVE
        )
        spannableString.setSpan(
            ForegroundColorSpan(Color.parseColor("#ADFF2F")),
            7, spannableString.length,
            Spanned.SPAN_EXCLUSIVE_INCLUSIVE
        )
        tangram1.text = spannableString

setSpan方法有四个参数,ForegroundColorSpan是为文本设置前景色,也就是文字颜色。如果要为文字添加背景颜色,可替换为BackgroundColorSpan。

Spanned.SPAN_INCLUSIVE_EXLUSIVE 从起始下标到终了下标,包括起始下标
Spanned.SPAN_INCLUSIVE_INCLUSIVE 从起始下标到终了下标,同时包括起始下C标和终了下标
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE 从起始下标到终了下标,但都不包括起始下标和终了下标
Spanned.SPAN_EXCLUSIVE_INCLUSIVE 从起始下标到终了下标,包括终了下标
如图:
在这里插入图片描述

同一TextView中展示不同字体大小

①Html.fromHtml()是不支持用size属性设置字体的大小的,只能使用标签进行格式化。
通过使用big、small来实现

        tangram.text = Html.fromHtml("登录即代表同意<font color= \"#0000FF\"><small>《用户使用协议》</small></font>")
        tangram1.text = Html.fromHtml("登录即代表同意<font color= \"#0000FF\"><big>《用户使用协议》</big></font>")

如图
在这里插入图片描述
big、small 可以接连使用

 tangram.text = Html.fromHtml("登录即代表同意<font color= \"#0000FF\"><small><small>《用户使用协议》</small><small></font>")
 tangram1.text = Html.fromHtml("登录即代表同意<font color= \"#0000FF\"><big><big>《用户使用协议》<big></big></font>")

②通过SpannableString实现

        val spannableString = SpannableString("登录即代表同意《用户使用协议》")
        spannableString.setSpan(
            AbsoluteSizeSpan(28),
            0, 2,
            Spanned.SPAN_EXCLUSIVE_EXCLUSIVE
        )
        spannableString.setSpan(
            AbsoluteSizeSpan(18),
            2, 7,
            Spanned.SPAN_INCLUSIVE_INCLUSIVE
        )
        spannableString.setSpan(
            AbsoluteSizeSpan(38),
            7, spannableString.length,
            Spanned.SPAN_EXCLUSIVE_INCLUSIVE
        )
        tangram1.text = spannableString

如图:
在这里插入图片描述

了解更多SpannableString知识,可查看以下文档:

https://blog.csdn.net/jdsjlzx/article/details/19122103
https://blog.csdn.net/zuo_er_lyf/article/details/80340819
https://blog.csdn.net/lukejunandroid/article/details/25892737

TextView 实现左右滑动
Android之复制文本(TextView)剪贴板

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值