SCRAttributedStringBuilder 是一种链式构建 NSAttributedString 的库,参考 Masonry 中的链式思路,用于简化 NSAttributedString 冗长的构建和配置,支持 Objective-C 与 Swift。
使用 Associated Object 的方式给 NSMutableAttributedString 增加一个 Range 数组,将方法分成 Content、Range、Attribute 三类,Content 和 Range 类的方法会影响 Attribute 的作用域(Range)。
使用方式如下:
NSString *text = @"测试多行文字链接测试多行文字链接测试多行文字测试多行文字链接测试多行文字";
self.label.attributedText = @"颜色/字体\n".attributedBuild.fontSize(30).color([UIColor purpleColor])
.append(text).firstLineHeadIndent(20).lineHeight(25).paragraphSpacing(20)
.match(@"链接").hexColor(0xFF4400).backgroundColor([UIColor lightGrayColor])
.matchFirst(@"链接").underlineStyle(NSUnderlineStyleThick).underlineColor([UIColor greenColor])
.matchLast(@"链接").strikethroughStyle(NSUnderlineStyleSingle).strikethroughColor([UIColor yellowColor])
.append(text).alignment(NSTextAlignmentCenter).lineSpacing(10)
.append(@"路飞").font([UIFont systemFontOfSize:25]).strokeWidth(2).strokeColor([UIColor darkGrayColor])
.appendSizeImage([UIImage imageNamed:@"luffer"], CGSizeMake(50, 50))
具体见 Demo 工程和 NSMutableAttributedString+SCRAttributedStringBuilder.h
文件。
实现一个 AttributedStringBuilder,使用 Builder 来链式构建 AttributedString,将方法分成 Content、Range、Attribute 三类,Content 和 Range 类的方法会影响 Attribute 的作用域(Range)。
使用方式如下:
let text = "测试多行文字测试多行文字测试多行文字链接测试多行文字测试多行文字链接测试多行文字"
label.attributedText = AttributedStringBuilder.build { builder in
builder
.append("颜色字体\n").fontSize(30).color(UIColor.purple)
.append(text).firstLineHeadIndent(20).lineHeight(25).paragraphSpacing(20)
.match("链接").hexColor(0xFF4400).backgroundColor(UIColor.lightGray)
.matchFirst("链接").underlineStyle(.thick).underlineColor(UIColor.green)
.matchLast("链接").strikethroughStyle(.single).strikethroughColor(UIColor.yellow)
.append(text).alignment(.center).lineSpacing(10)
.append("路飞").font(UIFont.systemFont(ofSize:25)).strokeWidth(2).strokeColor(UIColor.darkGray)
.appendImage(UIImage(named:"luffer")!, CGSize(width: 50, height: 50))
}
具体见 Demo 工程和 SCRAttributedStringBuilder.swift
文件。
为了将 SCRAttributedStringBuilder 集成到 Xcode 工程中,在 Podfile
中进行如下配置:
source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '11.0'
use_frameworks!
target 'YourApp' do
# 默认包含 Objective-C 和 Swift
pod 'SCRAttributedStringBuilder'
# 如果只想使用 Objective-C 部分
# pod 'SCRAttributedStringBuilder/OC'
# 如果只想使用 Swift 部分
# pod 'SCRAttributedStringBuilder/Swift'
end
之后运行以下命令:
$ pod install
将 SCRAttributedStringBuilder 目录拖进工程中即可。
Joe Shang, shangchuanren@gmail.com
SCRAttributedStringBuilder 使用 MIT License,更多请查看 LICENSE 文件。