前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Android彩色文字的超链接实现的封装

Android彩色文字的超链接实现的封装

原创
作者头像
wresource
发布于 2022-07-27 15:43:53
发布于 2022-07-27 15:43:53
1.1K0
举报
文章被收录于专栏:云服务器开发云服务器开发

一、前言

最近设计界面的时候碰到这样一个问题,我们经常可以看到这样的一个界面,告知用户的隐私条款和用户协议这样的这个底部彩色文字,而且这些彩色文字都是直接指向相应的链接

1.jpg
1.jpg

当时最初的想法是设置多个 TextView 来实现,然而这样会有一个问题这样一个简单的功能用了5个控件,太丢人了,而且文字对齐还需要自己调整,不自然,搜索了一下,实现方式并不困难,只是没有进行一个比较好的封装,故今天带大家用kotlin的扩展函数封装一个colorText的方法,这里不得不夸一下kotlin的扩展函数,真的好用。

二、设计点击事件

首先需要创建一个SpannableStringBuilder用于应用点击事件等等的容器

代码语言:text
AI代码解释
复制
val style = SpannableStringBuilder()
val parent = "我已阅读并同意用户协议和隐私政策"
val colorText = "用户协议"
//寻找第一个colorText的下标
val index = indexOf(colorText,0)
style.append(parent)

然后我们来设置点击事件

代码语言:text
AI代码解释
复制
//相当于重写了一个匿名类里面的一个点击事件的方法
val clickableSpan = object : ClickableSpan(){
    override fun onClick(widget: View) {
        //具体事件
    }
}
//第一个参数是设置点击事件的选项,第二个是colorText在parent中的位置,第二个是最后一个文字的位置,第三个是一个固定的参数
style.setSpan(clickableSpan, index, index+colorText.length, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)

至此,当前的colorText已经具备事件的点击了

三、设置无下划线

这部分也挺重要的,没有设置你的文字就加了一个莫名其妙的下划线

首先需要创建一个类来进行无下划线

代码语言:text
AI代码解释
复制
class NoUnderlineSpan: UnderlineSpan(){
    override fun updateDrawState(ds: TextPaint) {
        super.updateDrawState(ds)
        ds.color = ds.linkColor
        ds.isUnderlineText = false
    }
}

最后设置一下即可

代码语言:text
AI代码解释
复制
//这里的参数和上一个差不多,第一个是设置无下划线,2,3,同上,第四个可选项更换了一下
val noUnderlineSpan = NoUnderlineSpan()
style.setSpan(noUnderlineSpan,index , index+colorText.length, Spanned.SPAN_MARK_MARK)

四、设置颜色

设置链接的颜色,这部分跟上面的也差不多,设置一下前景颜色,其他参数差不多

代码语言:text
AI代码解释
复制
val foregroundColorSpan = ForegroundColorSpan(Color.parseColor("#118EEA"))
style.setSpan(foregroundColorSpan, index, index+colorText.length, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)

最后需要应用一下即可实现彩色链接的点击事件

代码语言:text
AI代码解释
复制
MyTextView.movementMethod = LinkMovementMethod.getInstance()
MyTextView.text = style

五、封装

分部分讲完了,接下来就是最精彩的封装了,用到了 Kotlin 的扩展函数

  • 首先分析需要扩展的类为 TextView 类,这样的话,只要是继承 TextView 类的控件都能用到这个扩展函数的功能
  • 其次分析需要的参数,本来应该是需要完整的text、colorText、colorString、点击事件的函数型参数,后来想想不对啊,在TextView中已经拥有它的上下文,直接获取完整的text即可,所以最后需要三个参数,colorText、colorString、函数型参数

以下便是最终的封装,看上去好像挺长的,不过使用起来就非常的方便

代码语言:text
AI代码解释
复制
//这里可能会出现找不到文字的情况,发生错误记得检查一下文字是否正确
class NoUnderlineSpan: UnderlineSpan(){
    override fun updateDrawState(ds: TextPaint) {
        super.updateDrawState(ds)
        ds.color = ds.linkColor
        ds.isUnderlineText = false
    }
}
fun TextView.colorText(colorText:String, color:String, click:()->Unit){
    val style = SpannableStringBuilder()
    val index = text.indexOf(colorText,0)
    style.append(text)
    val clickableSpan = object : ClickableSpan(){
        override fun onClick(widget: View) {
            click()
        }
    }
    style.setSpan(clickableSpan, index, index+colorText.length, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)
    val noUnderlineSpan = NoUnderlineSpan()
    style.setSpan(noUnderlineSpan,index , index+colorText.length, Spanned.SPAN_MARK_MARK)
    val foregroundColorSpan = ForegroundColorSpan(Color.parseColor(color))
    style.setSpan(foregroundColorSpan, index, index+colorText.length, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE)
    movementMethod = LinkMovementMethod.getInstance()
    text = style
}

它的使用

代码语言:text
AI代码解释
复制
myTextView.colorText("用户协议","#118EEA"){
   //自己的点击事件
}

六、总结

这次封装总体上还不错,做到了简化代码的效果,也应用了Kotlin的知识,欢迎留言交流哦

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
直播预告|腾讯云国产数据库系列直播火热进行中
在各行业爆发式增长的云时代,传统IT架构已无法满足企业需求。国内移动互联网的崛起为国产数据库创造了得天独厚的成长沃土,相比较于传统数据库,国产数据库技术取得了长足进步,也更适用于企业的生产环境和IT系统。 数据库作为数字经济发展的底层核心技术,未来是上云。腾讯云始终致力于实现数据库技术的自主可控,帮助企业降低上云成本,目前已为微信支付、微众银行、张家港行、猎豹、搜狐畅游、蘑菇街、猫眼等全行业用户提供服务。 为帮助开发者更好地了解和学习国产数据库技术,腾讯云数据库特推出为期3个月的国产数据库专题线上技术沙龙
腾讯云数据库 TencentDB
2020/03/12
6270
腾讯云数据库拼团,邀请1人即可获得120元无门槛券,最高700元!
2019开年折上折,腾讯云数据库拼团活动开始啦,参与即享700元无门槛代金券,8元包月MySQL 买三送一!拼的多赚得多!新老用户皆可参与。
腾讯云数据库 TencentDB
2019/01/11
2.5K0
腾讯云数据库拼团,邀请1人即可获得120元无门槛券,最高700元!
关注腾讯云数据库,有机会获得腾讯云1000元代金券
扫描下方二维码,关注腾讯云数据库官方微信,可以获得: 在公众号底部菜单快速进入DBbrain,快捷管理数据库实例,订阅数据库日报,7×24小时实时监控告警。 点击公众号底部菜单“免费套餐”,参与调研即有机会获得腾讯云1000元代金券,买服务器和数据库可直接抵现! 接收到最新鲜的腾讯云数据库优惠信息,惊喜早知道! 小白到高阶都能有收获的【迪B课堂】系列教程,教你玩转数据库! 腾讯云数据库微信订阅号二维码 - 副本.jpg
腾讯云数据库 TencentDB
2019/09/12
2.5K0
关注腾讯云数据库,有机会获得腾讯云1000元代金券
腾讯云代金券如何领取及使用?
腾讯云代金券是腾讯云专用的一种代金券,也可以称为腾讯云优惠券。在购买腾讯云的时候,可获得相应的优惠折扣。一般购买腾讯云的时候,建议使用腾讯云代金券,这样可以节省购买腾讯云的费用。
主机精选@主机点评
2019/07/23
5.4K0
什么是腾讯云代金券及如何抵用省钱教程
什么是腾讯云代金券?腾讯云代金券怎么使用?很多网友只是知道腾讯云代金券可以在付款时抵用,但是对腾讯云代金券及如何使用并不了解,为了给大家答疑解惑,快速上云,顺利购买使用腾讯云产品,所以魏艾斯博客写下本文帮助大家快速理解、详细说明这些问题。
魏艾斯博客www.vpsss.net
2018/10/15
3K0
酷炫!在手机上能随时随地一键管理数据库啦
听说很多程序猿在“名义放假实际值班”的假期(这真的叫假期吗)里,呼朋唤友出去体验被异性包围感受的时候,经常会这样:
腾讯云数据库 TencentDB
2019/03/26
2.6K0
酷炫!在手机上能随时随地一键管理数据库啦
腾讯云代金券是什么?有续费代金券吗?
腾讯云代金券只限于客户首购或产品首购,在支付订单的时候可以选择使用代金券进行抵扣一部分金额,从而一定程度上节约我们的上云成本。
tengxunyun8点com活动整理
2019/05/14
15.6K0
腾讯云代金券是什么?有续费代金券吗?
腾讯云代金券使用方法与说明
用户在购买、续费、变更配置包年包月产品时,可在付款页面自主选用代金券。(选购流程可参考 购买云服务)
return null
2019/10/05
5.6K0
【迪B课堂】如何正确的选择云数据库?
话不多说,请看本期《如何选正确的云数据库》。搜索关注“腾讯云数据库”官方微信立得10元腾讯云无门槛代金券,体验移动端一键管理数据库,学习更多数据库技术实战教程。
腾讯云数据库 TencentDB
2019/01/24
8.8K2
【迪B课堂】如何正确的选择云数据库?
腾讯云特大优惠活动上线产品3折起新用户更有2860优惠券可领取
腾讯云活动上线啦,凡完成腾讯云官网注册且完成实名认证的国内站用户均可参与。活动期间,除了可以参加每天5场的秒杀活动外,还有代金券大礼包可以领取,同时,云服务器、云数据库等5款热门云产品的折扣优惠。
勤劳的小蜜蜂
2019/06/27
2.9K0
如何正确的选择云数据库?
江湖传说在选择和使用云数据库过程中 10个人有9个会遇到以下问题: 数据库正常使用过程中莫名卡顿 经常遭遇主从延迟和主从不一致 不知如何实现无损跨云跨数据库迁 话不多说,请看本期《如何选正确的云数据库
勤劳的小蜜蜂
2019/06/18
1.9K0
磊哥测评之数据库篇:云Redis vs 自建Redis
上期我比较了腾讯云和阿里云的MySQL数据库,文章发布之后引起了一些反响,有质疑数据的,也有希望了解更多细节的同学。其实一个数据库产品的好坏,不光是QPS、TPS这种吞吐量指标,其他特性如主从复制、灾备、稳定性、可视化管理等也起着重要作用,有兴趣的同学可以自己去体验一下,我也会逐步完善这些数据库测试。这期我们来看另一个常用的数据库:Redis。
腾讯云数据库 TencentDB
2019/01/17
13.2K0
磊哥测评之数据库篇:云Redis vs 自建Redis
磊哥测评之数据库SaaS篇:腾讯云控制台、DMC和小程序
随着云计算和数据库技术的发展,数据库正在变得越来越强大。数据库的性能如处理速度、对高并发的支持在节节攀升,同时分布式、实时的数据分析、兼容主流数据库等强大的性能正在越来越多的新型数据库上实现。
腾讯云数据库 TencentDB
2019/02/18
10.5K0
磊哥测评之数据库SaaS篇:腾讯云控制台、DMC和小程序
磊哥测评之数据库篇:自建数据库VS云数据库,到底怎么选?
最近在学习数据库相关知识,经常跟一个在某金融公司做DBA的大学朋友交流问题。听说他们公司最近在使用云数据库,我立马来了兴趣,以前只听说过云主机,没想到数据库这种产品也可以在云上买。正好最近在学习使用sysbench,索性我就买了腾讯云数据库(因为他们家的可以按量付费,用完了就释放掉哈哈),配合自己购买的腾讯云主机进行一个对比测试。下面就贴出测试过程和结果,仅供大家参考。
腾讯云数据库 TencentDB
2019/01/02
20.5K0
磊哥测评之数据库篇:自建数据库VS云数据库,到底怎么选?
腾讯云数据库回档解决方案
作者介绍:李明,腾讯云数据库架构师华南区负责人,曾在某专业数据库服务商、51job任职DBA。
腾讯云数据库 TencentDB
2018/08/08
7.1K1
【腾讯云 MongoDB】 基于snapshot的从库读优化
导语 我们发现腾讯云上一些腾讯云MongoDB实例在主库写压力比较大的情况下,这时从库上会出现很多慢查询,经过调查发现,从库在回放oplog的时候加了全局锁,阻塞了所有的读直到回放结束。经过我们的优化
腾讯云数据库 TencentDB
2017/11/24
2.9K0
【腾讯云 MongoDB】 基于snapshot的从库读优化
本地IDC机房数据库容灾解决方案
下文以腾讯云数据库 MySQL为例,介绍如何充分利用腾讯云的优势,减轻DBA的负担,轻松来搭建数据库。
腾讯云数据库 TencentDB
2018/07/13
4.4K0
腾讯云双十一薅羊毛攻略:云数据库Redis
今年的腾讯云双十一活动,玩出了新花样——“百款折扣商品任意拼,双人成团PK有大礼”!
后台技术汇
2024/11/18
3500
腾讯云双十一薅羊毛攻略:云数据库Redis
腾讯云网站解决方案专享特惠 一站式上云 热门云产品低至 3 折
最近推出的腾讯云网站解决方案专享特惠,一站式上云,热门云产品低至 3 折。这套方案主要是为初创客户提供一站式云端解决方案,快速低成本部署业务,利用云产品配置灵活、高可用,高可靠,全面防护的特点保障业务稳定安全。
魏艾斯博客www.vpsss.net
2018/08/22
2.9K0
腾讯云网站解决方案专享特惠 一站式上云 热门云产品低至 3 折
Gartner最新报告:腾讯云数据库增速国内第一
近日,国际权威研究机构Gartner公司发布《The Future of the Database Management System (DBMS) Market Is Cloud》研究报告显示,腾讯云数据库市场份额增速达123%,位列国内所有数据库厂商之首,在全球范围内保持了连续两年增速前三的迅猛势头。
勤劳的小蜜蜂
2019/08/02
1.4K0
推荐阅读
相关推荐
直播预告|腾讯云国产数据库系列直播火热进行中
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档