iOS开发进阶 - 富文本正则替换表情

原创 2016年11月28日 17:20:11

移动端访问不佳,请访问我的个人博客

最近写项目需要用到富文本解析字符串显示表情,下面是我使用正则替换实现富文本的方式,希望能帮助到大家

先上效果图和demo地址

这里写图片描述

实现过程中需要用到的知识点

  • NSRegularExpression(正则表达式)
  • NSMutableAttributedString(用来显示富文本的string)

废话不多说,直接贴代码:

import UIKit

struct WCLEmojiParse {

    //所有表情对应的字符串
    static let emotions = ["[angry]", "[beers]", "[blush]", "[bomb]", "[cool]", "[flushed]", "[grin]", "[gun]", "[heart]", "[heartseyes]", "[imp]", "[Joy]", "[kiss]", "[ok]", "[persevere]", "[pray]", "[punch]", "[scream]", "[shit]", "[skull]", "[sleeping]", "[smiley]", "[smirk]", "[sob]","[sweat]", "[thumbsup]", "[tongue]", "[unamused]", "[v]", "[weary]", "[wink]", "[yum]"]

    //String的格式
    static let textAttributes = [NSFontAttributeName: UIFont.systemFont(ofSize: 16), NSForegroundColorAttributeName: UIColor.black]
    //正则表达式的格式
    static let pattern = "\\[+[a-z]+\\]"
    //表情的bounds
    static let attachmentBounds = CGRect.init(origin: CGPoint.init(x: 0, y: -5), size: CGSize.init(width: 24, height: 24))

    //MARK: Public Methods
    static func replaceEmoji(_ str: String) -> NSAttributedString {
        //转成NSString
        let originalNSString = str as NSString
        //通过str获得NSMutableAttributedString
        let attStr = NSMutableAttributedString.init(string: str, attributes: textAttributes)
        var regex: NSRegularExpression?
        do {
            regex = try NSRegularExpression.init(pattern: pattern, options: .caseInsensitive)
        } catch let error as NSError {
            print(error.localizedDescription)
        }
        //获取到匹配正则的数据
        if let matches = regex?.matches(in: str, options: .withoutAnchoringBounds, range: NSMakeRange(0,attStr.string.characters.count)) {
            if matches.count > 0 {
                //遍历符合的数据进行解析
                for i in 0..<matches.count {
                    let result = matches[matches.count-i-1]
                    let range = result.range
                    let emojiStr = originalNSString.substring(with: range)
                    //符合的数据是否为表情
                    if emotions.contains(emojiStr) {
                        if let image = UIImage.init(named: emojiStr) {
                            //创建一个NSTextAttachment
                            let attachment    = NSTextAttachment()
                            attachment.image  = image
                            attachment.bounds = attachmentBounds
                            //通过NSTextAttachment生成一个NSAttributedString
                            let rep = NSAttributedString(attachment: attachment)
                            //把表情于之前的字符串替换
                            attStr.replaceCharacters(in: range, with: rep)
                        }
                    }
                }
            }
        }
        return attStr
    }
}

demo地址

以上是简单的富文本显示表情的方式,抛砖引玉,大家见笑了,希望大家能学到东西,谢谢大家的阅读

版权声明:本文为博主原创文章,未经博主允许不得转载。

iOS emoji表情过滤

/**  *  emoji表情过滤  */ +(NSString *)filterEmoji:(NSString *)string {     NSUInteger len...
  • saw471
  • saw471
  • 2016年10月14日 13:33
  • 568

iOS 输入框过滤emoji表情

//  通过创建一个NSString 的category类目实现最后输入的表情的过滤 (输入框粘贴功能关闭) + (BOOL)isContainsTwoEmoji:(NSString *)strin...
  • saw471
  • saw471
  • 2016年11月02日 17:16
  • 1329

富文本(讲一个字符串中的一些文本颜色显示特别的颜色,文字中替换表情)

SpannableString 的四个关键属性 Spanned.SPAN_EXCLUSIVE_EXCLUSIVE(前后都不包括)、 Spanned.SPAN_INCLUSIVE_EXCLU...
  • puyaCheer
  • puyaCheer
  • 2016年11月26日 19:21
  • 509

PHP开发小技巧①⑥—提取富文本字符串中的文本内容

富文本在我们平常的项目中应用已经很广泛了,并逐渐发展成了一个行业。最近在项目中遇到需要提取富文本字符串中的文本内容,本篇博文就是记述如何重富文本字符串中提取出文本内容,欢迎大家相互学习。 1...
  • Zhihua_W
  • Zhihua_W
  • 2017年10月31日 15:16
  • 503

iOS中Emoji表情的判断

问题服务器端不支持Emoji表情,因此客户端在上传用户输入时,不能包含Emoji表情。那么,该如何判断字符串中是否含有Emoji呢?...
  • liujinlongxa
  • liujinlongxa
  • 2015年03月11日 22:58
  • 35973

iOS 文本与图片表情混排的实现

2015-09-04 by 木易哥哥  要实现文图混排效果需要用到的有:富文本NSMutableAttributedString,字符替换substringWithRange,以及支持动画g...
  • manyxh
  • manyxh
  • 2015年09月04日 15:06
  • 2796

正则替换图片

#在线咨询 $imgsrc = 'images/zxzx.png'; $tqStrHtml =  htmlspecialchars_decode($data["tq_mobile_code"]);...
  • yteasyhappy
  • yteasyhappy
  • 2014年11月06日 10:57
  • 182

iOS 查看详情 富文本

NSString * textStr = @"周杰伦(Jay Chou),1979年1月18日出生于台湾省新北市,华语男歌手、词曲创作人、演员、MV及电影导演、编剧及制作人。2000年发行首张个人专辑...
  • sinat_35135563
  • sinat_35135563
  • 2016年06月13日 11:49
  • 239

NSAttributedString,并富文本,正则表达式,超链接,水印

重载NSAttachment传送门 正则表达式传送门 码: #import "ViewController.h" //NSAttributedString.h 中文本属性key的说明 ...
  • LivesXu
  • LivesXu
  • 2016年01月25日 20:04
  • 2758

iOS -字符串替换 富文本的简单使用

NSString *skills = [userAcc.skills stringByReplacingOccurrencesOfString:@"$$" withString:@"、"];     ...
  • Dancer2015
  • Dancer2015
  • 2016年01月20日 10:36
  • 838
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:iOS开发进阶 - 富文本正则替换表情
举报原因:
原因补充:

(最多只允许输入30个字)