iOSQuartz2D-02-绘制炫酷的下载进度条
2015-08-17 12:07
471 查看
效果图
实现思路
要实现绘图,通常需要自定义一个UIView的子类,重写父类的- (void)drawRect:(CGRect)rect方法,在该方法中实现绘图操作若想显示下载进度,只需要实例化自定义子类的对象(若是storyboard中控件,只需修改控件的class属性为自定义子类的类名即可)
效果图所示的效果其实是绘制一个圆弧,动态的改变终点的位置,最终达到一个封闭的圆
中间的文字是一个UILabel控件,根据进度动态改变文字的现实
实现步骤
自定义一个UIView的子类//提供一个成员属性,接收下载进度值 @property (nonatomic, assign) CGFloat progress;
重写成员属性progress的setter
//每次改变成员属性progress的值,就会调用它的setter - (void)setProgress:(CGFloat)progress { _progress = progress; //当下载进度改变时,手动调用重绘方法 [self setNeedsDisplay]; }
重写- (void)drawRect:(CGRect)rect(
核心)
- (void)drawRect:(CGRect)rect { //设置圆弧的半径 CGFloat radius = rect.size.width * 0.5; //设置圆弧的圆心 CGPoint center = CGPointMake(radius, radius); //设置圆弧的开始的角度(弧度制) CGFloat startAngle = - M_PI_2; //设置圆弧的终止角度 CGFloat endAngle = - M_PI_2 + 2 * M_PI * self.progress; //使用UIBezierPath类绘制圆弧 UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:center radius:radius - 5 startAngle:startAngle endAngle:endAngle clockwise:YES]; //将绘制的圆弧渲染到图层上(即显示出来) [path stroke]; }
相关文章推荐
- IOS git
- iOS8后台定位
- ios多线程的几种创建方式
- iOS 项目中使用CocoaPod管理项目初试
- iOS学习笔记(二.iOS程序执行流程)
- iOS CGRectInset、CGRectOffset详解
- iOS7坐标问题
- iOS学习笔记(一)
- iOS开发之学前了解
- 关于IOS中的self关键字
- iOS学习路线图
- IOS开发之tableView的刷新以及property属性的用法
- 用HTML5/CSS3/JS开发Android/IOS应用
- Windows Server 2016预览版10512中文ios镜像泄露
- iOS 9对比iOS 8 用户界面究竟新在哪?
- iOS获取当前网页的页面元素
- iOS学习之NSBundle介绍和使用
- ios报错--pie can only be used when targeting iOS 4.2 or later clang: error: linker command failed with
- IOS 开发 打电话,发短信,调用系统组件
- iOS 9之WatchKit for WatchOS 2