如何给 UILable 添加横线

类似淘宝上的原价现价,原价上一般都会有一条横线,这种效果怎么实现呢?其实相当的简单,我们只需要重写自定义的lable的 - (void)drawRect:(CGRect)rect 方法就行了。

具体实现方法如下:

1.  调用super的方法就可以拿到值  

     [super drawRect:rect]; 

2.  获取到lable字体的尺寸  

     CGSize size = [self.text sizeWithAttributes:[NSDictionary dictionaryWithObjectsAndKeys:self.font,NSFontAttributeName,nil]];   

注:- (CGSize)sizeWithAttributes:(NSDictionary*)attrs; 这个方法是iOS7 之后的方法 代替了iOS6中过时了的 - (CGSize)sizeWithFont:(UIFont*)font  

3.画线

   UIRectFill(CGRectMake(0, size.height*0.5, size.width,1));

到这里就完成了,很简单吧,想当初第一次做项目就想实现这种效果可惜太水一直实现不了就放弃了,希望这个能对你们有所帮助。

如果你想设置线的颜色 可以  [[UIColor redColor] set];  不过需要注意的是 要在画线之前设置。下面是效果图:


效果图
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Quartz2D以及drawRect的重绘机制字数1487 阅读21 评论1 喜欢1一、什么是Quartz2D Q...
    PurpleWind阅读 828评论 0 3
  • --绘图与滤镜全面解析 概述 在iOS中可以很容易的开发出绚丽的界面效果,一方面得益于成功系统的设计,另一方面得益...
    韩七夏阅读 2,821评论 2 10
  • CoreText是iOS/OSX中文本显示的一个底层框架,它是用C语言写成的,有快速简单的优势。iOS中的Text...
    小猫仔阅读 5,044评论 2 9
  • 简介 日常开发过程中积累的小经验,分享给大家! 1. 四舍五入用法 float numToRound;int re...
    有人叫我乔帮主阅读 835评论 0 0
  • 易戈 (一)今天你投了吗?不管你投不投,反正我是投了。 久不联系的一美女同学突然发来柔情问候:“Hi,在吗?”我一...
    易戈阅读 1,213评论 0 1