美文网首页
富文本 AtrributedString的部分属性效果

富文本 AtrributedString的部分属性效果

作者: 群星盛宴 | 来源:发表于2017-05-15 10:53 被阅读24次

iOS中UILabel是我们很常用的一个控件,通过这个控件,我们可以展示诸如价格、电话、提示等内容。除了最基本的用法外,我们可以通过设置它的attributedText的各种属性来实现某一截内容加粗、变色或是被一条线贯穿的效果,就像商品原价那样。

首先在创建一个普通的UILabel控件,显示如图1:

图1

这个就很普通的一个效果,更好的效果还得用attributedText实现。

label有一个attributedText属性,相信有人和我一样第一次看到attributed这个单词还是感到有些怕怕的,不过熟悉了就没啥了。

首先,创建NSMutableAttributedString对象,如图2:

图2

往字典中加入AttributeName键值对便可实现相关富文本设置。图2中是对字符串range范围为(2,4)进行设置,即从3开始到6结束。

1,设置大字体,往字典加入NSFontAttributeName:[UIFont systemFontOfSize:50]键值对:

图3

2,设置前景色为橙色,属性字典加入NSForegroundColorAttributeName:[UIColor orangeColor]

图4

3,设置文字描边,这里需要结合NSStrokeWidthAttributeName(设置描边宽度)一起实现,不然没有效果,属性字典加入NSStrokeColorAttributeName:[UIColor magentaColor]NSStrokeWidthAttributeName:@3两个键值对:

图5

NSStrokeWidthAttributeName设置后,可以看到前景色就没有了。NSStrokeWidthAttributeName所对应的value是一个 NSNumber 对象(小数)。该值改变描边宽度(相对于字体size 的百分比)。默认为 0,即不改变。正数只改变描边宽度。负数同时改变文字的描边和填充宽度。例如将NSStrokeWidthAttributeName的值改为-3后,效果如下:

图6

4,设置倾斜字体,属性字典加入NSObliquenessAttributeName:@0.3键值对:

图7

5,文字中间添加删除线,属性字典加入NSStrikethroughStyleAttributeName:@(NSUnderlineStyleSingle)

图8

这里横线的颜色是文本的前景色,即刚才的橙色,横线样式是一个枚举值,其他值效果可以自行试试。

6,文字添加阴影,这里需要提前创建阴影对象shadow,然后将此对象作为NSShadowAttributeName的值插入字典:

图9

7,添加下划线,属性字典加入

NSUnderlineStyleAttributeName:@(NSUnderlineStyleSingle)键值对:

图10

8,设置段落样式,提前创建NSMutableParagraphStyle对象,作为NSParagraphStyleAttributeName的value插入字典:

图11

因为这是设置段落样式的,这里只有一句话效果看不出来。

9,设置扁平化字体,属性字典插入NSExpansionAttributeName:@0.3键值对:

图12

这里可以把0.3改为其他数字看看效果,比较夸张。

10,设置字间距,属性字典插入NSKernAttributeName:@5键值对:

图13

NSKernAttributeName的值若为正值则间距加宽,负值间则距变窄。

还有其他的一些AttributeName,按住command点击上面任意一个AttributeName就可以进入相关的官方定义,可以看到还有很多属性,大家可以自行研究一下,如图14:

图14

相关文章

网友评论

      本文标题:富文本 AtrributedString的部分属性效果

      本文链接:https://www.haomeiwen.com/subject/tbqtxxtx.html