将多个字符串高亮显示之TTTAttributedLabel

2022-10-21,

本文介绍了将多个字符串高亮显示之TTTAttributedLabel。在此需要对每个字符串进行匹配,可以研究下kmp和bm算法,在这里应用了oc自带的NSRegularExpression 来进行正则表达式匹配,算是比较简单的方法,需要的朋友可以参考下

下面通过代码图和效果图展示给大家

TTTAttributedLabel进行多个字符串的高亮显示。

需要对每个字符串进行匹配,从而得到所有需要高亮的NSRange,然后利用NSMutableAttributedString对每个NSRange添加attribute

首先 是字符串匹配算法,可以研究下kmp和bm算法,这里我直接用了OC自带的 NSRegularExpression 来进行正则表达式匹配,应该算是最简单直接的方式了

传入字符串text,和需要高亮的字串patterns , 正则表达式就是字串的 "|" 集合, 根据正则表达式进行字串的大小写不敏感匹配, 然后枚举生成的NSTextCheckingResult,保存在数组中,接下来就可以对label字体进行设置了

这里用的是TTTAttribute的setText:afterInheritingLabelAttributesAndConfiguringWithBlock:方法, 在代码块里面遍历所有的NSTextCheckingResult对象,对其中的NSRange进行颜色字体的设置就完成了想要的效果

当然,也可以进行字符串的裁剪,本人自己的一个解决方案是给定一个需要的最大的字符串长度,进行裁剪

<

因为需求多种多样,裁剪的部分也不尽相同,这个就只能帮到这里了,如果有比较有趣或者奇葩的裁剪需求,欢迎和本人交流。

附上效果图一枚 :

以上就是本文的全部内容,希望大家喜欢。

您可能感兴趣的文章:

  • jquery实现带复选框的表格行选中删除时高亮显示
  • flex实现DataGrid高亮显示数据功能的解决方案
  • 比较完整的android MP3 LRC歌词滚动高亮显示(附源码)
  • 用JS将搜索的关键字高亮显示实现代码
  • javascript简单实现表格行间隔显示颜色并高亮显示
  • Jquery如何实现点击时高亮显示代码
  • jQuery实现当前页面标签高亮显示的方法
  • jquery实现页面关键词高亮显示的方法

《将多个字符串高亮显示之TTTAttributedLabel.doc》

下载本文的Word格式文档,以方便收藏与打印。