iOS - Quartz 2D 下载进度按钮绘制
1、绘制下载进度按钮
具体实现代码见 GitHub 源码 QExtension
QProgressButton.h
@interface QProgressButton : UIButton /// 进度值,范围 0 ~ 1
@property (nonatomic, assign) CGFloat progress; /// 进度终止状态标题,一旦设置了此标题进度条就会停止
@property (nonatomic, strong) NSString *stopTitle; /**
* 创建带进度条的按钮
*
* @param frame 按钮的 frame 值
* @param title 进按钮的标题
* @param lineWidth 进度条的线宽,default is 2
* @param lineColor 进度条线的颜色,default is greenColor
* @param textColor 进度值的颜色,default is blackColor
* @param backColor 按钮的背景颜色,default is clearColor
* @param isRound 按钮是否显示为圆形,default is YES
*
* @return 带进度条的按钮
*/
+ (instancetype)q_progressButtonWithFrame:(CGRect)frame
title:(NSString *)title
lineWidth:(CGFloat)lineWidth
lineColor:(nullable UIColor *)lineColor
textColor:(nullable UIColor *)textColor
backColor:(nullable UIColor *)backColor
isRound:(BOOL)isRound; @end
QProgressButton.m
@interface QProgressButton () /// 进度条的线宽
@property (nonatomic, assign) CGFloat lineWidth; /// 进度条线的颜色
@property (nonatomic, strong) UIColor *lineColor; /// 按钮的背景颜色
@property (nonatomic, strong) UIColor *backColor; /// 按钮是否显示为圆形
@property (nonatomic, assign, getter=isRound) BOOL round; @end @implementation QProgressButton /// 创建带进度条的按钮
+ (instancetype)q_progressButtonWithFrame:(CGRect)frame
title:(NSString *)title
lineWidth:(CGFloat)lineWidth
lineColor:(nullable UIColor *)lineColor
textColor:(nullable UIColor *)textColor
backColor:(nullable UIColor *)backColor
isRound:(BOOL)isRound { QProgressButton *progressButton = [[self alloc] init]; progressButton.lineWidth = lineWidth ? : 2;
progressButton.lineColor = lineColor ? : [UIColor colorWithRed:76/255.0 green:217/255.0 blue:100/255.0 alpha:1.0];
progressButton.backColor = backColor ? : [UIColor clearColor];
progressButton.round = isRound; // 设置按钮的实际 frame
if (isRound) {
CGRect tmpFrame = frame;
tmpFrame.origin.y = frame.origin.y - (frame.size.width - frame.size.height) * 0.5;
tmpFrame.size.height = frame.size.width;
progressButton.frame = tmpFrame;
} else {
progressButton.frame = frame;
} // 设置显示的标题和颜色
[progressButton setTitle:title forState:UIControlStateNormal];
[progressButton setTitleColor:(textColor ? : [UIColor blackColor]) forState:UIControlStateNormal]; return progressButton;
} /// 绘制进度条
- (void)drawRect:(CGRect)rect { // 设置按钮圆角
self.layer.masksToBounds = YES;
self.layer.cornerRadius = rect.size.height * 0.5; // 绘制按钮的背景颜色
UIBezierPath *path = [UIBezierPath bezierPathWithRect:rect];
[self.backColor set];
[path fill]; // 设置进度终止时显示的内容
if (self.stopTitle) { // 设置下载完成后的标题
[self setTitle:self.stopTitle forState:UIControlStateNormal];
return;
} if (self.progress <= 0) {
return;
} // 清除按钮背景图片
[self setBackgroundImage:nil forState:UIControlStateNormal]; // 设置进度值
[self setTitle:[NSString stringWithFormat:@"%.2f%%", self.progress * 100] forState:UIControlStateNormal]; if (self.isRound) { CGPoint center = CGPointMake(rect.size.height * 0.5, rect.size.height * 0.5);
CGFloat radius = (rect.size.height - self.lineWidth) * 0.5;
CGFloat startA = - M_PI_2;
CGFloat endA = startA + self.progress * 2 * M_PI; // 绘制进度条背景
path = [UIBezierPath bezierPathWithArcCenter:center
radius:radius
startAngle:0
endAngle:2 * M_PI
clockwise:YES];
[[[UIColor lightGrayColor] colorWithAlphaComponent:0.5] set];
path.lineWidth = self.lineWidth;
[path stroke]; // 绘制进度条
path = [UIBezierPath bezierPathWithArcCenter:center
radius:radius
startAngle:startA
endAngle:endA
clockwise:YES];
path.lineWidth = self.lineWidth;
path.lineCapStyle = kCGLineCapRound;
[self.lineColor set];
[path stroke]; } else { CGFloat w = self.progress * rect.size.width;
CGFloat h = rect.size.height; // 绘制进度条背景
path = [UIBezierPath bezierPathWithRect:CGRectMake(0, 0, rect.size.width, rect.size.height)];
[[[UIColor lightGrayColor] colorWithAlphaComponent:0.5] set];
[path fill]; // 绘制进度条
path = [UIBezierPath bezierPathWithRect:CGRectMake(0, 0, w, h)];
[self.lineColor set];
[path fill];
}
} /// 设置进度值
- (void)setProgress:(CGFloat)progress { _progress = progress; [self setNeedsDisplay];
} /// 设置进度终止状态标题
- (void)setStopTitle:(NSString *)stopTitle { _stopTitle = stopTitle; [self setNeedsDisplay];
} @end
ViewController.m
// 创建进度按钮
QProgressButton *progressButton = [QProgressButton q_progressButtonWithFrame:CGRectMake(100, 100, 100, 50)
title:@"开始下载"
lineWidth:10
lineColor:[UIColor blueColor]
textColor:[UIColor redColor]
backColor:[UIColor yellowColor]
isRound:YES]; // 设置按钮点击事件
[progressButton addTarget:self action:@selector(progressUpdate:) forControlEvents:UIControlEventTouchUpInside]; // 将按钮添加到当前控件显示
[self.view addSubview:progressButton]; // 设置按钮的进度值
self.progressButton.progress = progress; // 设置按钮的进度终止标题,一旦设置了此标题进度条就会停止
self.progressButton.stopTitle = @"下载完成";
效果


iOS - Quartz 2D 下载进度按钮绘制的更多相关文章
- iOS - Quartz 2D 第三方框架 Charts 绘制图表
1.Charts 简介 使用第三方框架 Charts 绘制 iOS 图表.GitHub 源码 Charts Charts 是一款用于绘制图表的框架,可以绘制柱状图.折线图.K线图.饼状图等.Chart ...
- iOS - Quartz 2D 手势截屏绘制
1.绘制手势截屏 具体实现代码见 GitHub 源码 QExtension QTouchClipView.h @interface QTouchClipView : UIView /** * 创建手势 ...
- iOS - Quartz 2D 二维绘图
1.Quartz 2D 简介 Quartz 2D 属于 Core Graphics(所以大多数相关方法的都是以 CG 开头),是 iOS/Mac OSX 提供的在内核之上的强大的 2D 绘图引擎,并且 ...
- iOS - Quartz 2D 贝塞尔曲线
1.贝塞尔曲线 贝塞尔曲线(Bézier curve),又称贝兹曲线或贝济埃曲线,是应用于二维图形应用程序的数学曲线.一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支 ...
- iOS空心圆下载进度指示器控件
self.layer = [CAShapeLayer layer]; self.layer.frame = CGRectMake(, , , ); self.layer.position = self ...
- iOS - Quartz 2D 画板绘制
1.绘制画板 1.1 绘制简单画板 PaintBoardView.h @interface PaintBoardView : UIView @end PaintBoardView.m @interfa ...
- IOS Quartz 2D 学习(1)
IOS提供两种创建图形的途径: 1.OpenGL. 2.Quartz.Core Animation.UIKit图形支持. UIKit的图形系统 1.视图绘画周期: DrawRect方法,在任何时候,当 ...
- iOS开发——图层OC篇&Quartz 2D各种绘制实例
Quartz 2D各种绘制实例 首先说一下,本篇文章只是介绍怎么使用Quartz 2D绘制一些常用的图像效果,关于Quartz和其他相关技术请查看笔者之前写的完整版(Quartz 2D详解) 一:画线 ...
- iOS 2D绘图 (Quartz 2D) 概述
本篇博客原文地址:http://blog.csdn.net/hello_hwc?viewmode=list 由于自己的项目需要,从网络上下载了许多关于绘制图形的demo,只是用在自己的项目中,很多地方 ...
随机推荐
- 洛谷 [P251] 餐巾计划问题
有上下界的最小费用最大流 可以联想到供求平衡问题,所以我们要拆点做这道题 把每天分为二分图两个集合中的顶点Xi,Yi,建立附加源S汇T. 1.从S向每个Xi连一条容量为ri,费用为0的有向边. 2.从 ...
- document.activeElement 过滤选择文件弹窗导致的页面失焦
在线考试页面,常常需要检测用户是否作弊. 一般是监听页面是否失焦的方式,而失焦的方式有很多种,比如QQ弹窗,切换页面,切换程序,input文件上传选择文件等 选择文件是正常情况,这种情况下需要过滤 本 ...
- 对JavaScript中的静态属性和原型属性的理解
首先是在访问上的区别,当访问实例对象的某个属性但它本身没有时,它就会到原型中去查找,但不会去查找静态属性. // 实例对象不会去查找静态属性 function Foo(){} Foo.a = 1; v ...
- Angular20 nginx安装,angular项目部署
1 nginx安装(Windows版本) 1.1 下载安装包 到官网下载Windows版本的nginx安装包 技巧01:下载好的压缩包解压即可,无需安装 1.2 启动nginx 进入到解压目录,点击 ...
- 常用VI操作命令
# ------------------- VI basic ------------------------------- # file name: VI_basic # author : # da ...
- C控制语句:循环
#include<stdio.h>int main(void){long num;long sum = 0L;int status; printf("Please enter a ...
- CentOS7关闭/开启防火墙出现 Unit iptables.service failed to load
在vm中安装好tomcat,而且在liunx中使用nc命令可以返回成功,但是更换到window中访问不到tomcat的情况,是由于linux防火墙的问题造成的,传统的解决方式有2中 第一种解决方案: ...
- Python 判断闰年,判断日期是当前年的第几天
http://www.cnblogs.com/vamei/archive/2012/07/19/2600135.html Python小题目 针对快速教程 作业答案 写一个程序,判断2008年是否是闰 ...
- Shell 编程入门
首先创建一个文件: 在终端中输入如下命令: vi helloworld.sh 然后按i进行命令编写 下面这句话是必须写的 #!/bin/sh这句话是必须写的 #!/bin/sh a="hel ...
- filter-api文档
git地址:https://github.com/jiqianqin/filters 不断优化中,欢迎加入讨论- filter-tags 效果图: 参数 说明 格式 备注 data 展示的数据 [{ ...