针对于富文本的封装,想了一些如果是正常封装,扩展类然后增加一个个方法,很多时候会不全或者方法属性冗余设置起来也是比较繁杂。
最后就是参考masonry
的链式编程来实现封装,可以自由组合搭配使用,能达到自己想要的效果。本文就不讲封装的过程,就讲怎么使用我封装好的库YGRichText。
如果对于封装过程感兴趣的可以直接下载 OC 源码/Swift 源码。
导入
支持pod 导入
# OC
pod 'YGRichText'
# Swift
pod 'YGRichText_Swift'
或者手动导入YGRichText
文件夹内的类即可。
使用
导入头文件
#import "YGRichText.h"
代码中调用:
textView.attributedText = [@"hello world, this is rich text test~" yg_makeAttributed:^(YGAttributedMaker *make) {
make.font([UIFont systemFontOfSize:17]).allRange();
make.foregroundColor(UIColor.redColor).allRange();
make.strikethroughStyle(4).allRange();
make.underlineStyle(4).underlineColor(UIColor.blueColor).allRange();
make.strokeWidth(4).strokeColor(UIColor.blackColor).allRange();
make.textAlignment(NSTextAlignmentCenter).kern(10).lineSpacing(10).lineBreakMode(NSLineBreakByCharWrapping).allRange();
make.appendString(self.string);
}];
注意:每一个属性设置结束后请以allRange()
或者inRange()
结束,方可生效!!!
插入图片
label.attributedText = [@" 会员" yg_makeAttributed:^(YGAttributedMaker *make) {
make.insertImage([UIImage imageNamed:@"image_name"], CGRectMake(0, -1, 12, 10), 0);
}];
因为图文的富文本,是直接调用insertAttributedString:atIndex:
的形式,可归纳为富文本拼接,无需调用allRange()
或者inRange()
即可生效。
说明
可能存在的问题,同个range分开设置lineSpacing、textAlignment、lineBreakMode
,如下:
make.textAlignment(NSTextAlignmentCenter).allRange();
make.lineSpacing(10).allRange();
最后将只有写在最后的代码生效,例如上面的只有lineSpacing
生效,覆盖了上方textAlignment
的效果,如果需要同时设置lineSpacing、textAlignment、lineBreakMode
,需要在同一个range中调用:
make.textAlignment(NSTextAlignmentCenter).lineSpacing(10).lineBreakMode(NSLineBreakByCharWrapping).allRange();
结语
YGRichText
大部分是基于现有的富文本源码实现的,很早的时候就有用链式编程的方式来封装富文本,但是忙一下,... 直到今天又刚好有看到别人整理好的富文本效果。
关于YGRichText
的链式,其实作者是考虑过要不要将字体与颜色绑定,相当于对应关联的才能用点语法点出来,但是想想富文本还是自由组合比较好,就放弃了绑定的设想。所以这边的不足就是可能随意组合会导致效果被覆盖的问题,这个只能是在开发中开发者自己多多注意了...
另外关于YGRichText
必须以区间(allRange/inRange/yg_inRange)方法为一个区间设置结束点,作者想了想如果不以区间作为结束不清楚富文本的设置区间只能是全部的长度了,但是对于富文本来说太不灵活了...这也是作者自己造轮子的原由。
有想法或者觉得不好的可以留言,作者会虚心改进的...