#import "PieView.h"

@implementation PieView

- (void)drawRect:(CGRect)rect {
// Drawing code NSArray *dataArray = @[@,@,@];
CGPoint center = CGPointMake(self.bounds.size.width * 0.5, self.bounds.size.height * 0.5);
CGFloat radius = self.bounds.size.width * 0.5 - ;
CGFloat startA = ;
CGFloat angle = ;
CGFloat endA = ; for (NSNumber *num in dataArray) { startA = endA;
angle = num.intValue / 100.0 * M_PI * ;
endA = startA + angle;
UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:center radius:radius startAngle:startA endAngle:endA clockwise:YES];
[[self randomColor] set];
//添加一根线到圆心
[path addLineToPoint:center];
[path fill];
} } -(void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{ //重绘:1:drawRect方法不能手动去调用,否则不会自动生成与view有关的图形上下文 2:手动调用setNeedsDisplay,则系统会自动调用drawRect重绘,只要是系统自动调用的drawRect,都会自动生成与图形相关的上下文,fill,strokn都默认执行了绘图的几个步骤,要想实现绘图,需要自定义view,实现drawRect方法
[self setNeedsDisplay];
} //生成一个随机的颜色
- (UIColor *)randomColor { //arc4random_uniform:生成的随机数,范围为256,则生成的随机数范围是 0 -255
CGFloat r = arc4random_uniform() / 255.0;
CGFloat g = arc4random_uniform() / 255.0;
CGFloat b = arc4random_uniform() / 255.0; return [UIColor colorWithRed:r green:g blue:b alpha:];
} - (void)drawPie{
//画第一个扇形
CGPoint center = CGPointMake(self.bounds.size.width * 0.5, self.bounds.size.height * 0.5);
CGFloat radius = self.bounds.size.width * 0.5 - ;
CGFloat startA = ;
CGFloat angle = / 100.0 * M_PI * ;//当计算除法的时候,若是用浮点数CGFloat修饰,就要除以一个100.0,后面有小数
CGFloat endA = startA + angle; UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:center radius:radius startAngle:startA endAngle:endA clockwise:YES]; [[UIColor redColor] set];
//添加一根线到圆心
[path addLineToPoint:center];
[path fill];//调用的stroken描点或是fill填充都默认开启了图形上下文,绘制路径,把路径添加到图形上下文中,将图形上下文渲染到view上,其中调用fill,会自动添加一条线形成闭环 //画第二个扇形 startA = endA;
angle = / 100.0 * M_PI * ;
endA = startA + angle;
path = [UIBezierPath bezierPathWithArcCenter:center radius:radius startAngle:startA endAngle:endA clockwise:YES];
[[UIColor greenColor] set];
//添加一根线到圆心
[path addLineToPoint:center];
[path fill]; startA = endA;
angle = / 100.0 * M_PI * ;
endA = startA + angle;
path = [UIBezierPath bezierPathWithArcCenter:center radius:radius startAngle:startA endAngle:endA clockwise:YES];
[[UIColor blueColor] set];
//添加一根线到圆心
[path addLineToPoint:center];
[path fill]; } @end

第一步, 获取上下文

第二步,拼接路径 ,绘制第一个扇形

获取上下文

CGContextRef ctx =  UIGraphicsGetCurrentContext();

CGPoint center = CGPointMake(125, 125);

CGFloat radius = 100;

CGFloat startA = 0;

CGFloat endA = 0;

CGFloat angle = 25 / 100.0 * M_PI * 2;

endA = startA + angle;

拼接路径

UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:center

radius:radius

startAngle:startA

endAngle:endA

clockwise:YES];

添加一根线到圆心

[path addLineToPoint:center];

把路径添加到上下文

CGContextAddPath(ctx, path.CGPath);

把上下文渲染到View

CGContextFillPath(ctx);

注意点: CGFloat angle = 25 / 100.0 * M_PI * 2;

100.0一定要加一个.0

绘制第二个扇形

一样的, 把路径描述第二个扇形就好了

直接来个path =

让Path指针重新指向一个新的对象.也就是把指针重复利用了

之前的那个对象已经用完了,已经添加到了上下文当中了.

第二个扇形

startA = endA;

angle = 25 / 100.0 * M_PI * 2;

endA = startA + angle;

path = [UIBezierPath bezierPathWithArcCenter:center

radius:radius

startAngle:startA

endAngle:endA

clockwise:YES];

[path addLineToPoint:center];

把二个路径添加到上下文

CGContextAddPath(ctx, path.CGPath);

把上下文渲染到View

CGContextFillPath(ctx);

添加第二个扇形之后, 发现它们的颜色都一样,想要修改它的颜色

在下面再写一个

[[UIColor greenColor] set];

下面的一个颜色把之前的东西给覆盖了.

解决办法, 让它渲染两次

第三个扇形,把第二个拷贝一下就好了

总结:

有没有发现在画三个扇形用太多代码了,

里面有很多代码相似.

是不是可以把代码给抽一下

可以用便利数组的的方式

发现就两个地方变了, 一个数字变了, 一个颜色变了.

抽取代码:

假设他给一组数据

NSArray datas =  @[@25,@25,@50];

把数组便利出来

NSArray *datas =  @[@25,@25,@50];

CGPoint center = CGPointMake(125, 125);

CGFloat radius = 100;

CGFloat startA = 0;

CGFloat angle = 0;

CGFloat endA = 0;

for (NSNumber *number in datas) {

startA = endA;

angle = number.intValue / 100.0 * M_PI * 2;

endA = startA + angle;

描述路径

UIBezierPath *path = [UIBezierPath bezierPathWithArcCenter:center

radius:radius

startAngle:startA

endAngle:endA

clockwise:YES];

[path addLineToPoint:center];

[[self randomColor] set];

[path fill];

}

- (UIColor *)randomColor{

CGFloat r = arc4random_uniform(256)/ 255.0;

CGFloat g = arc4random_uniform(256)/ 255.0;

CGFloat b = arc4random_uniform(256)/ 255.0;

return [UIColor colorWithRed:r green:g blue:b alpha:1];

}

随机颜色:alpha通道它的取值范围是0-255;

OC里面的取值范围只能是0到1,把它 / 255.0就让它到这个范围了,

arc4random_uniform(256)随机产生 0 - 255的数.

颜色通道它的取值范围是0 到 255.

所以说要把0 到 255转换成0 到 1

直接是  0 ~ 255 / 255.0就可以了.

刚好是255就是255 / 255.0 就是1,

刚才是0 就是 0 / 255.0 就是0.

ios开发之Quartz2D 四:画饼图的更多相关文章

  1. iOS开发之Quartz2D 五:UIKIT 绘图演练,画文字,画图片

    #import "DrawView.h" @implementation DrawView -(void)awakeFromNib { // //画图片 // UIImage *i ...

  2. iOS开发之Quartz2D详解

    1. 什么是Quartz2D? Quartz 2D是一个二维绘图引擎,同时支持iOS和Mac系统 Quartz 2D能完成的工作 绘制图形 : 线条\三角形\矩形\圆\弧等 绘制文字 绘制\生成图片( ...

  3. iOS开发之Quartz2D

    1.         Quartz2D概述及作用 Quartz2D的API是纯C语言的,Quartz2D的API来自于Core Graphics框架. 数据类型和函数基本都以CG作为前缀,比如: CG ...

  4. iOS开发之Quartz2D 六 绘制UIImageView

    #import <UIKit/UIKit.h> @interface XMGImageView : UIView /** <#注释#> */ @property (nonato ...

  5. iOS开发之Quartz2D 二:绘制直线,曲线,圆弧,矩形,椭圆,圆

    #import "DrawView.h" @implementation DrawView /** * 作用:专门用来绘图 * 什么时候调用:当View显示的时候调用 * @par ...

  6. iOS开发之Socket通信实战--Request请求数据包编码模块

    实际上在iOS很多应用开发中,大部分用的网络通信都是http/https协议,除非有特殊的需求会用到Socket网络协议进行网络数 据传输,这时候在iOS客户端就需要很好的第三方CocoaAsyncS ...

  7. iOS开发之loadView、viewDidLoad及viewDidUnload的关系

    iOS开发之loadView.viewDidLoad及viewDidUnload的关系 iOS开发之loadView.viewDidLoad及viewDidUnload的关系    标题中所说的3个方 ...

  8. iOS开发之Xcode常用调试技巧总结

    转载自:iOS开发之Xcode常用调试技巧总结 最近在面试,面试过程中问到了一些Xcode常用的调试技巧问题.平常开发过程中用的还挺顺手的,但你要突然让我说,确实一脸懵逼.Debug的技巧很多,比如最 ...

  9. iOS 开发之 GCD 基础

    header{font-size:1em;padding-top:1.5em;padding-bottom:1.5em} .markdown-body{overflow:hidden} .markdo ...

随机推荐

  1. java byte中存大于0x7E的十六进制数

    在做一个Android app和arm板子交互的程序中,遇到一个问题,Java byte中无法直接存储大于0x7E的十六进制,但是C语言却可以. 出现这个状况的原因是:Java中是byte存储的是有符 ...

  2. Python学习(三) 八大排序算法的实现(下)

    本文Python实现了插入排序.基数排序.希尔排序.冒泡排序.高速排序.直接选择排序.堆排序.归并排序的后面四种. 上篇:Python学习(三) 八大排序算法的实现(上) 1.高速排序 描写叙述 通过 ...

  3. 76.CGI编码

    CGI编码 "%D6%DC%C8%F0%B8%A3"; 转换到字符串中: //CGI编码转到char类型的tmpstr中中 char* change(char *str) { // ...

  4. 开发板Ping不通虚拟机和主机

    Ubuntu 16.04      win7 笔记本连接学校的无线网 开发板S3c2440与笔记本仅通过COM连接 问题描述: 设置了桥接,主机与虚拟机IP在同一网段后,主机与虚拟机可以Ping,但是 ...

  5. map按value查找相应元素

    find_if算法用来在map中查找value符合条件的pair元素,返回指向该符合条件元素的迭代器,如果找到,那么返回最后一个元素的后一个元素end(); 1.首先要定义头文件 #include & ...

  6. mycat基本概念及读写分离一

    mycat基本概念及读写分离一 目录(?)[+] 安装与启动 mycat目录介绍 mycat三个最重要配置文件 验证读写分离 安装与启动 linux下可以下载Mycat-server-xxxxx.li ...

  7. 第二十八天 月出惊山鸟 —Spring的AOP

    6月13日,阴转细雨."人闲桂花落.夜静春山空. 月出惊山鸟.时鸣春涧中." 无论在面向过程还是在面向对象里,奇妙的"纯"字,似乎永远都充满了无限的可能性.除了 ...

  8. ORACLE11g R2【单实例 FS→单实例FS】

    ORACLE11g R2[单实例 FS→单实例FS] 本演示案例所用环境:   primary standby OS Hostname pry std OS Version RHEL6.5 RHEL6 ...

  9. 关于python中数组的问题,序列格式转换

    https://blog.csdn.net/sinat_34474705/article/details/74458605?utm_source=blogxgwz1 https://www.cnblo ...

  10. 【习题 6-8 UVA - 806】Spatial Structures

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 写两个dfs模拟就好. 注意每12个数字输出一个换行.. [代码] /* 1.Shoud it use long long ? 2. ...