zoukankan      html  css  js  c++  java
  • 富文本常用封装(NSAttributedString)

    最近经常遇到关于富文本的一些需求,特此封装了几个最常用的API分享给大家,但授之以鱼不如授之以渔,接下来会顺便谈谈NSAttributedString,确保你读了本篇文章能够自己封装关于富文本的API,本文封装API的示例Demo再此,拿去用吧!骚年们!

    一、常用需求封装

    需求:在我们日常开发中,某些句子中会有改变某些字颜色的需求,当然颜色一般而言就是为了着重强调,常为同一种颜色,所以下面代码是单纯改变一句话中的某些字的颜色

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    /**
     *  单纯改变一句话中的某些字的颜色
     *
     *  @param color    需要改变成的颜色
     *  @param totalStr 总的字符串
     *  @param subArray 需要改变颜色的文字数组
     *
     *  @return 生成的富文本
     */
    + (NSMutableAttributedString *)ls_changeCorlorWithColor:(UIColor *)color TotalString:(NSString *)totalStr SubStringArray:(NSArray *)subArray {
        NSMutableAttributedString *attributedStr = [[NSMutableAttributedString alloc] initWithString:totalStr];
        for (NSString *rangeStr in subArray) {
            NSRange range = [totalStr rangeOfString:rangeStr options:NSBackwardsSearch];
            [attributedStr addAttribute:NSForegroundColorAttributeName value:color range:range];
        }
        return attributedStr;
    }

    需求:需要更改字间距来适应整体UI

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    /**
     *  单纯改变句子的字间距(需要 <coretext coretext.h="">)
     *
     *  @param totalString 需要更改的字符串
     *  @param space       字间距
     *
     *  @return 生成的富文本
     */
    + (NSMutableAttributedString *)ls_changeSpaceWithTotalString:(NSString *)totalString Space:(CGFloat)space {
        NSMutableAttributedString *attributedStr = [[NSMutableAttributedString alloc] initWithString:totalString];
        long number = space;
        CFNumberRef num = CFNumberCreate(kCFAllocatorDefault,kCFNumberSInt8Type,&number);
        [attributedStr addAttribute:(id)kCTKernAttributeName value:(__bridge id)num range:NSMakeRange(0,[attributedStr length])];
        CFRelease(num);
        return attributedStr;
    }</coretext>

    需求:需要改变行间距来适应整体UI

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    /**
     *  单纯改变段落的行间距
     *
     *  @param totalString 需要更改的字符串
     *  @param lineSpace   行间距
     *
     *  @return 生成的富文本
     */
    + (NSMutableAttributedString *)ls_changeLineSpaceWithTotalString:(NSString *)totalString LineSpace:(CGFloat)lineSpace {
        NSMutableAttributedString *attributedStr = [[NSMutableAttributedString alloc] initWithString:totalString];
        NSMutableParagraphStyle * paragraphStyle = [[NSMutableParagraphStyle alloc] init];
        [paragraphStyle setLineSpacing:lineSpace];
        [attributedStr addAttribute:NSParagraphStyleAttributeName value:paragraphStyle range:NSMakeRange(0, [totalString length])];
        return attributedStr;
    }

    需求:同时更改行间距和字间距

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    /**
     *  同时更改行间距和字间距
     *
     *  @param totalString 需要改变的字符串
     *  @param lineSpace   行间距
     *  @param textSpace   字间距
     *
     *  @return 生成的富文本
     */
    + (NSMutableAttributedString *)ls_changeLineAndTextSpaceWithTotalString:(NSString *)totalString LineSpace:(CGFloat)lineSpace textSpace:(CGFloat)textSpace {
        NSMutableAttributedString *attributedStr = [[NSMutableAttributedString alloc] initWithString:totalString];
        NSMutableParagraphStyle * paragraphStyle = [[NSMutableParagraphStyle alloc] init];
        [paragraphStyle setLineSpacing:lineSpace];
        [attributedStr addAttribute:NSParagraphStyleAttributeName value:paragraphStyle range:NSMakeRange(0, [totalString length])];
        long number = textSpace;
        CFNumberRef num = CFNumberCreate(kCFAllocatorDefault,kCFNumberSInt8Type,&number);
        [attributedStr addAttribute:(id)kCTKernAttributeName value:(__bridge id)num range:NSMakeRange(0,[attributedStr length])];
        CFRelease(num);
        return attributedStr;
    }

    需求:更改某些文字的颜色并修改其字体,突出重点强调

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    /**
     *  改变某些文字的颜色 并单独设置其字体
     *
     *  @param font        设置的字体
     *  @param color       颜色
     *  @param totalString 总的字符串
     *  @param subArray    想要变色的字符数组
     *
     *  @return 生成的富文本
     */
    + (NSMutableAttributedString *)ls_changeFontAndColor:(UIFont *)font Color:(UIColor *)color TotalString:(NSString *)totalString SubStringArray:(NSArray *)subArray {
        NSMutableAttributedString *attributedStr = [[NSMutableAttributedString alloc] initWithString:totalString];
        for (NSString *rangeStr in subArray) {
            NSRange range = [totalString rangeOfString:rangeStr options:NSBackwardsSearch];
            [attributedStr addAttribute:NSForegroundColorAttributeName value:color range:range];
            [attributedStr addAttribute:NSFontAttributeName value:font range:range];
        }
        return attributedStr;
    }

    以上几种API综合效果图如下

    1471920007290124.png

    二、谈谈NSAttributedString

    1、初始化方法

    1
    2
    3
    - (instancetype)initWithString:(NSString *)str;
    - (instancetype)initWithString:(NSString *)str attributes:(nullable NSDictionary<nsstring *, id> *)attrs;
    - (instancetype)initWithAttributedString:(NSAttributedString *)attrStr;</nsstring *, id>

    第一种使用字符串初始化初始化富文本

    第二种使用字符串及属性字典(就是配置富文本的相关属性)初始化富文本

    第三种就是用其他富文本初始化富文本

    2、常用操作API

    为某一范围内文字添加某个属性

    1
    - (void)addAttribute:(NSString *)name value:(id)value range:(NSRange)range;

    示例:

    1471920079271624.png

    为某一范围内文字添加多个属性(两个API效果与格式一样)

    1
    2
    - (void)addAttributes:(NSDictionary<nsstring *, id> *)attrs range:(NSRange)range;
    - (void)setAttributes:(nullable NSDictionary<nsstring *, id> *)attrs range:(NSRange)range;</nsstring *, id></nsstring *, id>

    示例:

    1471920098759788.png

    移除某范围内的某个属性(可与添加属性API对照,不在示例)

    1
    - (void)removeAttribute:(NSString *)name range:(NSRange)range;

    其他部分API(见名知意,可与NSString对照不在赘述)

    1
    2
    3
    4
    5
    - (void)replaceCharactersInRange:(NSRange)range withAttributedString:(NSAttributedString *)attrString;
    - (void)insertAttributedString:(NSAttributedString *)attrString atIndex:(NSUInteger)loc;
    - (void)appendAttributedString:(NSAttributedString *)attrString;
    - (void)deleteCharactersInRange:(NSRange)range;
    - (void)setAttributedString:(NSAttributedString *)attrString;

    3、相关可设置属性对照

    通过API我们可以知道,对于富文本来说添加单个属性和添加属性字典称为其核心方法,就是一个key对应一个Value,只要能了解各种属性所对应效果就可以随意组合,搞出适合各种需求的封装API。

    • NSFontAttributeName :字体字号

    • value值:UIFont类型

    • NSParagraphStyleAttributeName : 段落样式

    value值:NSParagraphStyle类型(其属性如下)

      • lineSpacing 行间距(具体用法可查看上面的设置行间距API)

      • paragraphSpacing 段落间距

      • alignment 对齐方式

      • firstLineHeadIndent 指定段落开始的缩进像素

      • headIndent 调整全部文字的缩进像素

      • NSForegroundColorAttributeName 字体颜色

    value值:UIColor类型

    • NSBackgroundColorAttributeName 背景颜色

    value值:UIColor类型

    • NSObliquenessAttributeName 字体粗倾斜

    value值:NSNumber类型

    • NSExpansionAttributeName 字体加粗

    value值:NSNumber类型(比例) 0就是不变 1增加一倍

    • NSKernAttributeName 字间距

    value值:CGFloat类型

    • NSUnderlineStyleAttributeName 下划线

    value值:1或0

    • NSUnderlineColorAttributeName 下划线颜色

    value值:UIColor类型

    • NSStrikethroughStyleAttributeName 删除线

    value值:1或0

    • NSStrikethroughColorAttributeName 删除线颜色

    value值:UIColor类型

    • NSStrokeColorAttributeName 字体颜色

    value值:UIColor类型

    • NSStrokeWidthAttributeName 字体描边

    value值:CGFloat

    • NSLigatureAttributeName 连笔字

    value值:1或0

    • NSShadowAttributeName 阴影

    value值:NSShawdow类型(下面是其属性)

    •     shadowOffset 影子与字符串的偏移量

    •     shadowBlurRadius 影子的模糊程度

    •     shadowColor 影子的颜色

    • NSTextEffectAttributeName 设置文本特殊效果,目前只有图版印刷效果可用

    value值:NSString类型

    • NSAttachmentAttributeName 设置文本附件

    value值:NSTextAttachment类型(没研究过,可自行百度研究)

    • NSLinkAttributeName 链接

    value值:NSURL (preferred) or NSString类型

    • NSBaselineOffsetAttributeName 基准线偏移

    value值:NSNumber类型

    • NSWritingDirectionAttributeName 文字方向 分别代表不同的文字出现方向

    value值:@[@(1),@(2)]

    • NSVerticalGlyphFormAttributeName 水平或者竖直文本 在iOS没卵用,不支持竖版

    value值:1竖直 0水平

    三、示例Demo讲解

    Demo在此,点击可跳转

    API路径地址如下:

    /YiDing/Class/Helpers/LSCoreToolCenter

    截图如下:

    1471920240647190.png

    使用示例路径如下:

    /YiDing/Class/Sections/LSSection/NSMutableAttributedString

    截图如下:

    1471920243998913.png

  • 相关阅读:
    servlet中调用注入spring管理的dao(转)
    java枚举类(转)
    压缩包太大导致的部署问题
    oracle数据泵导出导入
    全错位排列
    母函数及相关的算法题
    Effective Modern C++翻译(5)-条款4:了解如何观察推导出的类型
    Effective Modern C++翻译(4)-条款3:了解decltype
    Effective Modern C++翻译(3)-条款2:明白auto类型推导
    Effective Modern C++翻译(2)-条款1:明白模板类型推导
  • 原文地址:https://www.cnblogs.com/xiao-love-meng/p/5848332.html
Copyright © 2011-2022 走看看