富文本的链式编程

针对于富文本的封装,想了一些如果是正常封装,扩展类然后增加一个个方法,很多时候会不全或者方法属性冗余设置起来也是比较繁杂。
最后就是参考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)方法为一个区间设置结束点,作者想了想如果不以区间作为结束不清楚富文本的设置区间只能是全部的长度了,但是对于富文本来说太不灵活了...这也是作者自己造轮子的原由。

有想法或者觉得不好的可以留言,作者会虚心改进的...

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335