技术标签: Swift
博主最近在研究IM的实现,不想直接使用第三方的界面,于是就开始了自己的作死之路。今天把包含表情格式的文本转换成相应的富文本贴一下吧。
首先,博主的表情格式是现在常用的中括号+标志符,类似[11]就是一个表情格式的字符。
我们需要实现的功能就是把形如: 你好[11]
这样的字符串变成: 你好
这样的字符串,具体的步骤就不再叙述了,注释已经很详细了
/// 将字符串转换为含有表情的富文本
///
/// - Parameter str: 待转换字符串
/// - Returns: 转换后的富文本
func changeString(str: String) -> NSAttributedString {
//正则表达式规则
let pattern = "\\[[0-9]{1,2}\\]"
//将待转换字符串转换为NSString,方便取子串
let text = str as NSString
//初始化一个空的富文本字符串
let string = NSMutableAttributedString(string: "")
//正则匹配
do {
//创建正则表达式
let regex = try NSRegularExpression(pattern: pattern, options: NSRegularExpression.Options.caseInsensitive)
//创建一个范围,包括全部的字符串
let range = NSRange(location:0, length: text.length)
//正则匹配的结果
let results = regex.matches(in: text as String, options: .withoutAnchoringBounds, range: range)
//上一个表情的范围
var lastRange: NSRange? = nil
//将表情字符串替换为表情图片
for result in results {
//第一次进入循环
if lastRange == nil {
//字符串不是以表情开始,需要先将第一个表情之前的字符串放入富文本字符串中
if result.range.location > 0 {
//第一个表情之前的字符串的范围
let range = NSRange(location: 0, length: result.range.location)
//取出这个范围内的子串
let subString = text.substring(with: range)
//创建一个临时的富文本字符串
let attributeString = NSAttributedString(string: subString)
//拼接到富文本字符串中
string.append(attributeString)
}
}
//不是第一次进入循环,这时需要做两步操作,先把当前表情与上一个表情之间的子串拼接到富文本字符串中,再将当前表情拼接到富文本字符串中
else {
//上一个表情与当前表情之间字符串的起点
let location = lastRange!.location + lastRange!.length
//上一个表情与当前表情之间字符串的长度
let length = result.range.location - location
//子串的范围
let range = NSRange(location: location, length: length)
let subString = text.substring(with: range)
let attributeString = NSAttributedString(string: subString)
string.append(attributeString)
}
/// 将表情文字替换为表情图片拼接到富文本中
//表情的标志符
let name = text.substring(with: result.range)
//创建表情图片
let image = UIImage(named: "\(name).png")
//创建富文本字符串附件
let attachment = NSTextAttachment()
//将表情添加到附件中
attachment.image = image
//设置表情宽高
attachment.bounds = CGRect(x: 0, y: 0, width: 30, height: 30)
//将表情拼接到富文本字符串中
let str1 = NSAttributedString(attachment: attachment)
string.append(str1)
//记录当前表情范围
lastRange = result.range
}
//如果字符串中没有包含表情,则直接将字符串转换为富文本字符串
if lastRange == nil {
let attributeString = NSAttributedString(string: text as String)
string.append(attributeString)
}
//如果字符串不是以表情结尾,需要将结尾的字符串拼接到富文本字符串中
else if let location = lastRange?.location, let length = lastRange?.length {
//最后一个表情的位置
let len = location + length
//结尾不是表情
if len < text.length {
//末尾字符串的范围
let range = NSRange(location: len, length: text.length-len)
let subString = text.substring(with: range)
let attributeString = NSAttributedString(string: subString)
string.append(attributeString)
}
}
} catch let err as NSError {
print(err.description)
}
//返回拼接好的富文本字符串
return string
}
文章浏览阅读9k次。感觉应该算是个常见的问题。网上也找到了部分答案 ,不全 ,解决不了问题 。经过多番寻找测试 ,终于搞定 。1. 解决办法 Dockerfile 加入一下内容# 安装 en_US.UTF-8 并配置环境RUN locale-gen en_US.UTF-8ENV LANG en_US.UTF-8 ENV LANGUAGE en_US:en ENV LC_ALL en_US.UT_docker run language
文章浏览阅读2.4k次。OverviewCMCC 关于 UT 部分的说明及规范请参考 "中国移动VoLTE终端技术规范" 中的第6节说明.写在前面: 由于 CMCC 的XCAP server(UT) 和 CS Server(HLR)暂不支持 SS 业务配置SYNC. 因此, 针对支持 UT 的卡, 以及所在城市提供 UT 服务, 则如果某项 SS 业务不支持通过 UT 配置,即便强制通过 CS 配置成功(CMCC有说明..._ut接口
文章浏览阅读4k次。制作带高度的白膜数据(这步可能非必须)这步骤应该不需要处理,直接把带有高度的shp发布到geoserver中即可,mapbox代码中指定下高度字段,mapbox会自动创建白膜高度,时间问题,没有测试,以后测试了我再更新,啧啧,是个偷懒的好借口,哈哈首先水经注可以下载带高度的建筑物面数据,得到shp后,可以在arcscene中处理,按照带有的高度值进行拉高处理。选择合适的比例计算值,直接用高度值的话拉伸太高,可以选择输入:[heightnum]*3*0.00001之类的进行比..._mapbox加载白模
文章浏览阅读316次。【9A文】计算机网络管理员(三级)理论鉴定试题A-含答案【MeiWei_81重点借鉴文档】 【MeiWei_81重点借鉴文档】 计算机网络管理员(三级)理论鉴定试题A 注 意 事 项 1、考试时间:90分钟。 2、请在试卷标封处填写姓名、准考证号和所在单位的名称。 3、请仔细阅读答题要求,把答案填写到答案卷,否则以零分计。 一、单项选择题(第1题~第40题。选择一个正确的答案,将相应的..._三级理论性理论a在线
文章浏览阅读1w次,点赞16次,收藏167次。2. MBIST的插入阶段:用工具插入Mbist时,我们既可以在RTL代码插入,也可以在netlist里面插入。目前,常见的做法是在netlist插入。但是,由于插入的Mbist逻辑是RTL代码,这样如果在netlist里面插入的话,我们还需要再进行一次综合。如果在RTL代码中直接插入Mbist,则只需要综合一次。为什么现在都推荐在netlist里面插入Mbist,而不是在RTL插入呢?回答1:综合通常是针对unit来做的,而布局布线通常针对partion,而mbist逻辑会涉及到很多个uni._mbist
文章浏览阅读172次,点赞9次,收藏4次。笔记本更改物理地址,无法更改_笔记本mac地址不能改
文章浏览阅读508次。今天准备使用本地数据库创建一个新用户(创建表也是)时报数据库未打开,可是去 计算机-右键-管理- 发现监听程序(oracleserviceORCL,oracleOraDb11g_home1TNSListener)等都已经启动了,而且我登录进去了呀,怎么会没打开数据库呢???于是百度 了,结果发现大家说的都一样。。。真是无语了,最重要我按照步骤做了,可是一到最后一步 alter database o_unable to retrieve oracle clus
文章浏览阅读3.2k次。ArcGIS数据结构转换。_arcgis空间数据转换与处理
文章浏览阅读4k次。java可以通过System.getProperty获得系统变量的值。而java.library.path只是其中的一个,表示系统搜索库文件的路径。 例如这个值可以能是 c;\windows;d:\test;e:\mytest 那当你在程序中装载一个dll库时,系统就是去当前目录和这几个目录找看看有没有这个文件。 因此通过jni机制来调用dll时,只要把该dll文件拷到当前目录和这..._java library path作用
文章浏览阅读358次。IC设计和制造的整体流程,是的,这个过程包含了从初步架构设计到最终制造的多个关键步骤。每一步都至关重要,确保芯片设计满足特定的性能、功耗和成本要求。整个流程要求工程师之间有高度的协作和多个迭代,因为从设计到制造涉及众多的工程和科学原则,任何阶段的错误都可能导致产品失败。因此,从架构设计到最终产品测试,严格的质量控制和验证步骤是整个流程的重要组成部分。_ic618 生成netlist文件
文章浏览阅读598次。项目运行环境配置:Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。项目技术:SSM + mybatis + Maven + Vue 等等组成,B/S模式 + Maven管理等等。环境需要1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。2.IDE环境:IDEA,Eclipse,Myeclipse都可以。_需求分析基于python的校园二手
文章浏览阅读672次,点赞14次,收藏29次。算法第一步:先学API实在是太多了,我刷了一百道左右,整理出来了里边用到的java中的API如下,有点乱,但是用的时候可以control+f进行搜索,当然这也是我的一个简化版本的API