初探NSAttributedString和NSMutableAttributedString的使用

时间:2023-02-01 00:16:43

由于iOS7新出的NSTextStorge是NSMutableAttributedString的子类,所以要用好NSTextStorage,首先要学好NSMutableAttributedString和NSAttributedString。

按个人的理解,NSAttributedString是一个带有属性的字符串,通过该类可以灵活地操作和呈现多种样式的文字数据。

因为是初步使用,所以基本上都是对照着文档上的指导和介绍的方法来写Demo。

首先是两种类的初始化方法(基本上是相似的):

    // initWithString:
    NSAttributedString *attributedString_str = [[NSAttributedString alloc] initWithString:@"attributedString"];
    NSLog(@"%@", attributedString_str);
    // textView.attributedText = attributedString_str;
    
    
    // initWithAttributedString:
    NSAttributedString *attributedString_atts = [[NSAttributedString alloc] initWithAttributedString:attributedString_str];
    NSLog(@"%@", attributedString_atts);
    // textView.attributedText = attributedString_atts;
    
    
    // initWithString:attributes:
    UIColor *backgroundColor = [UIColor blackColor];
    NSNumber *baseLineOffset = [NSNumber numberWithFloat:20.0];
    UIColor *foregroundColor = [UIColor whiteColor];
    NSNumber *kern = [NSNumber numberWithFloat:5.0];
    NSNumber *ligature = [NSNumber numberWithFloat:3.0];
    NSURL *linkURL = [NSURL URLWithString:@"http://www.baidu.com"];
    NSNumber *underline = [NSNumber numberWithInt:NSUnderlineStyleSingle];
    NSDictionary *attrsDic = @{NSForegroundColorAttributeName: foregroundColor,
                               NSBackgroundColorAttributeName: backgroundColor,
                               NSBaselineOffsetAttributeName: baseLineOffset,
                               NSKernAttributeName: kern,
                               NSLigatureAttributeName: ligature,
                               NSLinkAttributeName: linkURL,
                               NSUnderlineStyleAttributeName: underline
                               };
    NSAttributedString *attributedString_str_atts = [[NSAttributedString alloc] initWithString:@"http://www.baidu.com" attributes:attrsDic];
    NSLog(@"%@", attributedString_str_atts);
    // textView.attributedText = attributedString_str_atts;
    
    
    // initWithFileURL:options:documentAttributes:error:
    NSURL *fileURL = nil;
    fileURL = [[NSBundle mainBundle] URLForResource:@"Dynamic Coloring" withExtension:@"rtf"];
    NSAttributedString *attributedString_fileURL = [[NSAttributedString alloc] initWithFileURL:fileURL options:@{} documentAttributes:nil error:nil];
    NSLog(@"%@", attributedString_fileURL);
    // textView.attributedText = attributedString_fileURL;
    
    
    // initWithData:options:documentAttributes:error:
    fileURL = nil;
    fileURL = [[NSBundle mainBundle] URLForResource:@"View Layout" withExtension:@"rtf"];
    NSData *data = [[NSData alloc] initWithContentsOfURL:fileURL];
    NSAttributedString *attributedString_data = [[NSAttributedString alloc] initWithData:data options:@{} documentAttributes:nil error:nil];
    NSLog(@"%@", attributedString_data);
    // textView.attributedText = attributedString_data;
    
    
    // initWithAttributedString:
    NSMutableAttributedString *mutableAttributedString_attrs = [[NSMutableAttributedString alloc] initWithAttributedString:attributedString_fileURL];
非常简单。


由于NSAttributedString的属性以字典的形式记录,所以要弄清楚其中一些属性对应的键值:

初探NSAttributedString和NSMutableAttributedString的使用
说说几个自己使用上或者了解作用的。

NSBackgroundColorAttributeName:文字背景的颜色。

NSBaselineOffsetAttributeName:设置行距。

NSFontAttributeName:字体的样式,必须设置NSFont作为Value,NSFont在iOS中不能使用,这个属性的设置上我还不会。

NSForegroundColorAttributeName:文字颜色。

NSUnderlineStyleAttributeName:为文字添加下划线。必须设置NSNumber对象为Value。如:

    NSNumber *underline = [NSNumber numberWithInt:NSUnderlineStyleSingle];

以上attribute在NSAttributedString和NSMutableAttributedString对象创建时可以设定,不同的是NSAttributedString对象在创建成功后其属性便不可改变,而NSMutableAttributedString的属性是可以改变的。如下所示:

    // Change NSMutableAttributedString
    [mutableAttributedString_attrs beginEditing];
    /*
    // addAttributes:range:
    [mutableAttributedString_attrs addAttributes:@{NSLinkAttributeName: @"www.baidu.com",
                                                   NSBackgroundColorAttributeName: [UIColor greenColor],
                                                   NSUnderlineStyleAttributeName: [NSNumber numberWithInt:NSUnderlineStyleDouble]
                                                   }
                                           range:NSMakeRange(0, [attributedString_fileURL length])]; */
    // addAttribute:value:range:
    [mutableAttributedString_attrs addAttribute:NSUnderlineStyleAttributeName value:[NSNumber numberWithInt:NSUnderlineStyleThick] range:NSMakeRange(0, 10)];
    [mutableAttributedString_attrs addAttribute:NSBaselineOffsetAttributeName value:[NSNumber numberWithFloat:20.0] range:NSMakeRange(20, 100)];
    [mutableAttributedString_attrs endEditing];
    NSLog(@"%@", mutableAttributedString_attrs);

在修改文字属性的开头和结尾要分别调用beginEditing和endEditing方法,这些方法可以在文字属性发生变化时发送消息给事件监听者。

可以为某个范围内的文字单个地添加属性key-value对,也可以添加一个属性字典。
注意到在控制台输出NSAttributedString或NSMutableAttributedString时,输出的不仅是字符内容,还有对应的属性值:

2013-08-11 16:40:44.737 AttributedString_i7_Demo[43468:a0b] http://www.baidu.com{
    NSBackgroundColor = "UIDeviceWhiteColorSpace 0 1";
    NSBaselineOffset = 20;
    NSColor = "UIDeviceWhiteColorSpace 1 1";
    NSKern = 5;
    NSLigature = 3;
    NSLink = "http://www.baidu.com";
    NSUnderline = 1;
}

也可以获取某一段文字的属性:

    // get attribute
    NSRange range = NSMakeRange(0, mutableAttributedString_attrs.length);
    // attributesAtIndex:effectiveRange:
    NSDictionary *dic = [mutableAttributedString_attrs attributesAtIndex:0 effectiveRange:&range];
    NSLog(@"%@", [dic objectForKey:NSFontAttributeName]);

如果要将NSMutableAttributedString对象赋值给NSAttributedString时,要使用copy方法:
    textView.attributedText = [mutableAttributedString_attrs copy];


以上是对NSAttributedString和NSMutableAttributedString最基本的使用(主要还是NSAttributedString),为了强化作为NSMutableAttributedString的子类NSTextStorage处理文本的能力,明显在这两个类中增加了许多新的成员,如NSTextAttachment,在这里没有用上,必须继续深入学习。