iOS中UILabel是我们很常用的一个控件,通过这个控件,我们可以展示诸如价格、电话、提示等内容。除了最基本的用法外,我们可以通过设置它的attributedText的各种属性来实现某一截内容加粗、变色或是被一条线贯穿的效果,就像商品原价那样。
首先在创建一个普通的UILabel控件,显示如图1:
data:image/s3,"s3://crabby-images/56524/56524d6f28a28ea030e317c685aa98866e07611d" alt=""
这个就很普通的一个效果,更好的效果还得用attributedText实现。
label有一个attributedText属性,相信有人和我一样第一次看到attributed这个单词还是感到有些怕怕的,不过熟悉了就没啥了。
首先,创建NSMutableAttributedString对象,如图2:
data:image/s3,"s3://crabby-images/b8b68/b8b68c10d9cc624b6fb82f401ae1a0d874e4696f" alt=""
往字典中加入AttributeName键值对便可实现相关富文本设置。图2中是对字符串range范围为(2,4)进行设置,即从3开始到6结束。
1,设置大字体,往字典加入NSFontAttributeName:[UIFont systemFontOfSize:50]键值对:
data:image/s3,"s3://crabby-images/4589a/4589a27a4bbdf8493d4ea73fed6299ea25e02738" alt=""
2,设置前景色为橙色,属性字典加入NSForegroundColorAttributeName:[UIColor orangeColor]:
data:image/s3,"s3://crabby-images/0f50d/0f50df5cf82acd8ea58947cf05f2fa3a3329d2d6" alt=""
3,设置文字描边,这里需要结合NSStrokeWidthAttributeName(设置描边宽度)一起实现,不然没有效果,属性字典加入NSStrokeColorAttributeName:[UIColor magentaColor]和NSStrokeWidthAttributeName:@3两个键值对:
data:image/s3,"s3://crabby-images/447dd/447ddf31a4035954504e73898248d9188ac0df2c" alt=""
NSStrokeWidthAttributeName设置后,可以看到前景色就没有了。NSStrokeWidthAttributeName所对应的value是一个 NSNumber 对象(小数)。该值改变描边宽度(相对于字体size 的百分比)。默认为 0,即不改变。正数只改变描边宽度。负数同时改变文字的描边和填充宽度。例如将NSStrokeWidthAttributeName的值改为-3后,效果如下:
data:image/s3,"s3://crabby-images/94500/94500f493266feb317c8120a993277e9fdb80881" alt=""
4,设置倾斜字体,属性字典加入NSObliquenessAttributeName:@0.3键值对:
data:image/s3,"s3://crabby-images/d7211/d7211791fb55fb82665f56c593303afb635b30d4" alt=""
5,文字中间添加删除线,属性字典加入NSStrikethroughStyleAttributeName:@(NSUnderlineStyleSingle)
data:image/s3,"s3://crabby-images/b3547/b35473912a3813d096cda1f2b7d9c20a222a0d0a" alt=""
这里横线的颜色是文本的前景色,即刚才的橙色,横线样式是一个枚举值,其他值效果可以自行试试。
6,文字添加阴影,这里需要提前创建阴影对象shadow,然后将此对象作为NSShadowAttributeName的值插入字典:
data:image/s3,"s3://crabby-images/4d748/4d748876594b74df60735a3cfa7ef547e47b06d5" alt=""
7,添加下划线,属性字典加入
NSUnderlineStyleAttributeName:@(NSUnderlineStyleSingle)键值对:
data:image/s3,"s3://crabby-images/151ea/151ea2b4dd4fcd96c99f7400023640f0336c8594" alt=""
8,设置段落样式,提前创建NSMutableParagraphStyle对象,作为NSParagraphStyleAttributeName的value插入字典:
data:image/s3,"s3://crabby-images/d6935/d6935db9c5c852d5b88f6a3d0857cc23519d25e3" alt=""
因为这是设置段落样式的,这里只有一句话效果看不出来。
9,设置扁平化字体,属性字典插入NSExpansionAttributeName:@0.3键值对:
data:image/s3,"s3://crabby-images/74ece/74ece345cbef43a1fb4f7adeb022278786365e06" alt=""
这里可以把0.3改为其他数字看看效果,比较夸张。
10,设置字间距,属性字典插入NSKernAttributeName:@5键值对:
data:image/s3,"s3://crabby-images/c1b11/c1b11e017d6466f2b0ab42942021986911a30033" alt=""
NSKernAttributeName的值若为正值则间距加宽,负值间则距变窄。
还有其他的一些AttributeName,按住command点击上面任意一个AttributeName就可以进入相关的官方定义,可以看到还有很多属性,大家可以自行研究一下,如图14:
data:image/s3,"s3://crabby-images/7ce70/7ce70dc3958b158aff208a62b9233571a9955c7b" alt=""
网友评论