使用扩展函数为 AppCompatTextView 提供了多段文本点击区域设置功能

使用 Kotlin 扩展函数为 AppCompatTextView 提供了多段文本点击区域设置功能,允许在单个文本视图中设置多个可点击区域,每个区域可独立设置点击事件和文字颜色。

一、核心代码

1、ClickablePart 数据结构

kotlin 复制代码
data class ClickablePart(
    val targetText: String, // 需要高亮点击的文本
    val linkColor: Int? = null, // 高亮颜色
    val onClick: () -> Unit // 点击回调
)

1、扩展函数

kotlin 复制代码
import android.graphics.Color
import android.text.Spannable
import android.text.SpannableStringBuilder
import android.text.TextPaint
import android.text.method.LinkMovementMethod
import android.text.style.ClickableSpan
import android.text.style.ForegroundColorSpan
import android.view.View
import androidx.appcompat.widget.AppCompatTextView
import androidx.core.content.ContextCompat
import com.hongtu.utils.entity.ClickablePart
import kotlin.collections.forEach

/**
 * 扩展函数:简化多段文本点击设置
 * @param fullText 全部文本
 * @param clickableParts 多段文本点击区域
 * @param linkColor 点击区域文字颜色
 */
fun AppCompatTextView.setMultiClickableSpan(
    fullText: String,
    clickableParts: List<ClickablePart>,
    linkColor: Int = R.color.utils_link_color
) {
    val spannable = SpannableStringBuilder(fullText)

    clickableParts.forEach { part ->
        val startIndex = fullText.indexOf(part.targetText)
        if (startIndex == -1) return@forEach

        val endIndex = startIndex + part.targetText.length

        // 设置点击事件
        spannable.setSpan(
            object : ClickableSpan() {
                override fun onClick(widget: View) = part.onClick()
                override fun updateDrawState(ds: TextPaint) {
                    ds.color = ds.linkColor
                    ds.isUnderlineText = false
                }
            },
            startIndex,
            endIndex,
            Spannable.SPAN_EXCLUSIVE_EXCLUSIVE
        )

        // 设置文字颜色
        spannable.setSpan(
            ForegroundColorSpan(part.linkColor?:ContextCompat.getColor(context, linkColor)),
            startIndex,
            endIndex,
            Spannable.SPAN_EXCLUSIVE_EXCLUSIVE
        )
    }

    // 配置TextView
    movementMethod = LinkMovementMethod.getInstance()
    highlightColor = Color.TRANSPARENT
    text = spannable
}

二、使用示例

kotlin 复制代码
binding.tvAgreement.setMultiClickableSpan(
    fullText = "已阅读并同意《用户服务协议》、《个人信息保护政策》",
    clickableParts = listOf(
        ClickablePart(
            targetText = "已阅读并同意",
            onClick = {
                //选中CheckBox
            },
            linkColor = ContextCompat.getColor(this, R.color.design_white)
        ),
        ClickablePart(
            targetText = "《用户服务协议》",
            onClick = {
                //点击用户服务协议
            }
        ),
        ClickablePart(
            targetText = "《个人信息保护政策》",
            onClick = {
                //点击个人信息保护政策
            }
        )
    )
)

三、典型应用场景

  • 用户协议/隐私政策条款
  • 文本中的超链接
  • 可点击的免责声明
  • 动态生成的带操作提示文本
相关推荐
_李小白1 小时前
【Android GLSurfaceView源码学习】第二天:GLSurfaceView深度分析
android·学习
元气满满-樱2 小时前
LNMP架构学习
android·学习·架构
starrycode8882 小时前
【每日一个知识点】Kotlin开发基础知识
ui·kotlin
allk552 小时前
Android 渲染性能优化实战总结:从监控体系到架构落地
android·性能优化·架构
思成不止于此2 小时前
C++红黑树封装map/set核心揭秘
android
走在路上的菜鸟2 小时前
Android学Dart学习笔记第十七节 类-成员方法
android·笔记·学习·flutter
歪楼小能手3 小时前
Android16底部导航栏添加音量加减虚拟按键
android·java·平板
又是努力搬砖的一年3 小时前
elasticsearch修改字段类型
android·大数据·elasticsearch
走在路上的菜鸟3 小时前
Android学Dart学习笔记第十八节 类-继承
android·笔记·学习·flutter
Colinnian3 小时前
Android Studio创建新项目时需要更改哪些地方
android·ide·android studio