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 下载进度按钮绘制的更多相关文章

  1. iOS - Quartz 2D 第三方框架 Charts 绘制图表

    1.Charts 简介 使用第三方框架 Charts 绘制 iOS 图表.GitHub 源码 Charts Charts 是一款用于绘制图表的框架,可以绘制柱状图.折线图.K线图.饼状图等.Chart ...

  2. iOS - Quartz 2D 手势截屏绘制

    1.绘制手势截屏 具体实现代码见 GitHub 源码 QExtension QTouchClipView.h @interface QTouchClipView : UIView /** * 创建手势 ...

  3. iOS - Quartz 2D 二维绘图

    1.Quartz 2D 简介 Quartz 2D 属于 Core Graphics(所以大多数相关方法的都是以 CG 开头),是 iOS/Mac OSX 提供的在内核之上的强大的 2D 绘图引擎,并且 ...

  4. iOS - Quartz 2D 贝塞尔曲线

    1.贝塞尔曲线 贝塞尔曲线(Bézier curve),又称贝兹曲线或贝济埃曲线,是应用于二维图形应用程序的数学曲线.一般的矢量图形软件通过它来精确画出曲线,贝兹曲线由线段与节点组成,节点是可拖动的支 ...

  5. iOS空心圆下载进度指示器控件

    self.layer = [CAShapeLayer layer]; self.layer.frame = CGRectMake(, , , ); self.layer.position = self ...

  6. iOS - Quartz 2D 画板绘制

    1.绘制画板 1.1 绘制简单画板 PaintBoardView.h @interface PaintBoardView : UIView @end PaintBoardView.m @interfa ...

  7. IOS Quartz 2D 学习(1)

    IOS提供两种创建图形的途径: 1.OpenGL. 2.Quartz.Core Animation.UIKit图形支持. UIKit的图形系统 1.视图绘画周期: DrawRect方法,在任何时候,当 ...

  8. iOS开发——图层OC篇&Quartz 2D各种绘制实例

    Quartz 2D各种绘制实例 首先说一下,本篇文章只是介绍怎么使用Quartz 2D绘制一些常用的图像效果,关于Quartz和其他相关技术请查看笔者之前写的完整版(Quartz 2D详解) 一:画线 ...

  9. iOS 2D绘图 (Quartz 2D) 概述

    本篇博客原文地址:http://blog.csdn.net/hello_hwc?viewmode=list 由于自己的项目需要,从网络上下载了许多关于绘制图形的demo,只是用在自己的项目中,很多地方 ...

随机推荐

  1. 洛谷 [P1113] 杂务

    图论的做法是topsort 一看见有序我们就想到了DAG图,于是用topsort做,对于每一个加入队列的顶点,都用它的时间去更新它所指向的点的时间,本质上仍是DP的思想,dp[i]=max{dp[j] ...

  2. 在Android上编写模块化项目(翻译)

    来源博客:Wang Jie's Blog 本文链接:http://blog.wangjiegulu.com/2018/02/13/writing_a_modular_project_on_androi ...

  3. Git教程:

    使用前配置: git init git config --global user.name "yanpeng1314" git config --global user.email ...

  4. Lua内存分析工具

    最近给公司写了一个lua内存分析工具,可以非常方便的分析出Lua内存泄露问题,有图形化界面操作,方便手机端上传快照等功能 内存分析我是在c语言端写的,也有人写过lua端的分析工具,也蛮好用的,不过lu ...

  5. ie 浏览器文本输入框和密码输入框的默认样式

    登录页在ie浏览器上的默认样式 输入框后面的X    密码框后面的眼睛 如下图 解决方案 /*ie文本框背景色*/ input::-ms-clear { display: none; } /*ie文本 ...

  6. JavaScript命名整理

    .container { width: 720px; background: #fafafa; border: 2px dashed #999; padding: 10px; float: left ...

  7. Linux 每日命令行

    uptime 用于查看系统的负载信息. 它依次显示 当前系统时间.系统已运行时间.启用终端数量及平均负载值等信息.平均负载指的是系统在最近1分钟.5分钟.15分钟内的压力情况:负载值越低越好,尽量不要 ...

  8. 标准Http协议的六种请求方法详解

    标准Http协议支持六种请求方法,即: 1.GET 2.POST 3.PUT 4.Delete 5.HEAD 6.Options 但其实我们大部分情况下只用到了GET和POST.如果想设计一个符合RE ...

  9. STL源码剖析之序列式容器

    最近由于找工作需要,准备深入学习一下STL源码,我看的是侯捷所著的<STL源码剖析>.之所以看这本书主要是由于我过去曾经接触过一些台湾人,我一直觉得台湾人非常不错(这里不涉及任何政治,仅限 ...

  10. BZOJ2820 - 巧克力王国

    原题链接 Description 给出个二维平面上的点,第个点为,权值为.接下来次询问,给出,求所有满足的点的权值和. Solution 对于这个点建一棵k-d树,子树维护一个子树和. 如果子树所代表 ...