Iphone画饼图工具类

2023-10-08 03:18
文章标签 工具 iphone 画饼

本文主要是介绍Iphone画饼图工具类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目中需要画饼图,在此将工具类添出来:

h文件:

#import <UIKit/UIKit.h>
#import <QuartzCore/QuartzCore.h>@interface CLMView : UIView 
{float spaceHeight; //高度float scaleY ; NSArray *titleArr ; //文字NSArray *valueArr; //值NSArray	*colorArr; //颜色
}@property(nonatomic, assign)  float spaceHeight;
@property(nonatomic, assign) float scaleY;
@property(nonatomic, retain) NSArray *titleArr;
@property(nonatomic, retain) NSArray *valueArr;
@property(nonatomic, retain) NSArray *colorArr;@end

m文件:

#import "CLMView.h"#define K_PI 3.1415
#define KDGREED(x) ((x)  * K_PI * 2)@implementation CLMView
@synthesize spaceHeight, scaleY;
@synthesize titleArr, valueArr, colorArr;- (id)initWithFrame:(CGRect)frame {self = [super initWithFrame:frame];if (self) {// Initialization codeself.backgroundColor = [UIColor colorWithRed:240.0f/255.0f green:1 blue:1 alpha:1.0];spaceHeight = 40;scaleY = 0.4;}return self;
}- (void)drawRect:(CGRect)rect 
{CGContextRef context = UIGraphicsGetCurrentContext();//cgcontextsets//抗锯齿CGContextSetAllowsAntialiasing(context, TRUE);//	int arr[5] = {20, 15, 35, 85 ,60};float sum = 0;for(int j=0;j< [valueArr count]; j++){sum	 += [[valueArr objectAtIndex:j] floatValue];}CGContextMoveToPoint(context, 160, 230);float currentangel = 0;//饼图CGContextSaveGState(context);CGContextScaleCTM(context, 1.0, scaleY);currentangel = 0;for(int i = 0; i< [valueArr count]; i++){float startAngle = KDGREED(currentangel);currentangel += [[valueArr objectAtIndex:i] floatValue] / sum;float endAngle = KDGREED(currentangel);//绘制上面的扇形CGContextMoveToPoint(context, 160, 230);[[colorArr objectAtIndex:i %  [valueArr count]] setFill];[[UIColor colorWithWhite:1.0 alpha:0.8] setStroke];CGContextAddArc(context, 160, 230, 150, startAngle, endAngle, 0);CGContextClosePath(context);CGContextDrawPath(context, kCGPathFill);//绘制侧面float starx = cos(startAngle) * 150  +160;float stary = sin(startAngle) * 150 + 230;float endx = cos(endAngle) * 150 + 160;float endy = sin(endAngle) * 150 + 230;//float starty1 = stary + spaceHeight;float endy1 = endy + spaceHeight;if(endAngle < K_PI){//绘制厚度CGMutablePathRef path = CGPathCreateMutable();CGPathMoveToPoint(path, nil, starx, stary);CGPathAddArc(path, nil, 160, 230, 150, startAngle, endAngle, 0);CGPathAddLineToPoint(path, nil, endx, endy1);CGPathAddArc(path, nil, 160, 230 + spaceHeight, 150, endAngle, startAngle, 1);CGContextAddPath(context, path);[[colorArr objectAtIndex:i %  [valueArr count]] setFill];[[UIColor colorWithWhite:0.9 alpha:1.0] setStroke];CGContextDrawPath(context, kCGPathFill);[[UIColor colorWithWhite:0.1 alpha:0.4] setFill];CGContextAddPath(context, path);CGContextDrawPath(context, kCGPathFill);}//只有弧度《 3.14 的才会画前面的厚度else if(startAngle < K_PI){endAngle = K_PI;endx = 10;endy1 = 230+spaceHeight;//绘制厚度CGMutablePathRef path = CGPathCreateMutable();CGPathMoveToPoint(path, nil, starx, stary);CGPathAddArc(path, nil, 160, 230, 150, startAngle, endAngle, 0);CGPathAddLineToPoint(path, nil, endx, endy1);CGPathAddArc(path, nil, 160, 230 + spaceHeight, 150, endAngle, startAngle, 1);CGContextAddPath(context, path);[[colorArr objectAtIndex:i %  [valueArr count]] setFill];[[UIColor colorWithWhite:0.9 alpha:1.0] setStroke];CGContextDrawPath(context, kCGPathFill);[[UIColor colorWithWhite:0.1 alpha:0.4] setFill];CGContextAddPath(context, path);CGContextDrawPath(context, kCGPathFill);}else//break;//CGContextSetBlendMode(context, kCGBlendModeMultiply);}//整体渐变CGFloat componets [] = {0.0, 0.0, 0.0, 0.5,0.0,0.0,0.0,0.1};CGColorSpaceRef colorspace = CGColorSpaceCreateDeviceRGB();CGGradientRef gradient = CGGradientCreateWithColorComponents(colorspace, componets, nil, 2);CGContextDrawRadialGradient(context, gradient, CGPointMake(160,230), 0, CGPointMake(160,230), 150, 0 );CFRelease(colorspace);CGGradientRelease(gradient);CGContextRestoreGState(context);//绘制文字for(int i = 0; i< [valueArr count]; i++){float origionx = 50 ;float origiony = i * 30 + 200;[[colorArr objectAtIndex:i %  [valueArr count]] setFill];CGContextFillRect(context, CGRectMake(origionx, origiony, 20, 20));CGContextDrawPath(context, kCGPathFill);if(i< [titleArr count]){NSString *title = [ titleArr objectAtIndex:i];[title drawAtPoint:CGPointMake(origionx + 50, origiony) withFont:[UIFont systemFontOfSize:16]];}}}- (void)dealloc {[titleArr release];[valueArr release];[colorArr release];[super dealloc];
}@end

调用:(主要是设置cv的titleArr,valueArr,colorArr)

NSMutableArray *title = [[NSMutableArray alloc]init];NSMutableArray *value = [[NSMutableArray alloc]init];NSMutableArray *color = [[NSMutableArray alloc]init];NSArray *Allcolor = [NSArray arrayWithObjects:[UIColor yellowColor], [UIColor blueColor],[UIColor redColor], [UIColor brownColor], [UIColor purpleColor] , [UIColor orangeColor],[UIColor greenColor],[UIColor grayColor],[UIColor colorWithRed:135.0f/255.0f green:206.0f/255.0f blue:235.0f/255.0f alpha:1],[UIColor colorWithRed:240.0f/255.0f green:1 blue:1 alpha:1],[UIColor colorWithRed:1 green:0 blue:1 alpha:1],[UIColor colorWithRed:0 green:199.0f/255.0f blue:140.0f/255.0f alpha:1],[UIColor colorWithRed:160.0f/255.0f green:32.0f/255.0f blue:240.0f/255.0f alpha:1],[UIColor colorWithRed:124.0f/255.0f green:252.0f/255.0f blue:0 alpha:1],nil];for(int i = 0;i<[self.onetableDatacostchat count];i++){float bilv = [[self.onetableDatacostchat objectAtIndex:i] floatValue]/[self.zongcost floatValue];float lastbilv = bilv*100;[title addObject:[NSString stringWithFormat:@"%@     %f%@",[self.onetableDatawenzichat objectAtIndex:i],lastbilv,@"%"]];[value addObject:[NSNumber numberWithInt:lastbilv]];[color addObject:[Allcolor objectAtIndex:i]];}CLMView *cv = [[CLMView alloc] initWithFrame:CGRectMake(0, 0, 320, 440)];cv.titleArr = title;cv.valueArr = value;cv.colorArr = color;[self.view addSubview: cv];[cv release];[title release];[value release];[color release];

这篇关于Iphone画饼图工具类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/162327

相关文章

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

基于Python打造一个全能文本处理工具

《基于Python打造一个全能文本处理工具》:本文主要介绍一个基于Python+Tkinter开发的全功能本地化文本处理工具,它不仅具备基础的格式转换功能,更集成了中文特色处理等实用功能,有需要的... 目录1. 概述:当文本处理遇上python图形界面2. 功能全景图:六大核心模块解析3.运行效果4. 相

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

基于Python实现高效PPT转图片工具

《基于Python实现高效PPT转图片工具》在日常工作中,PPT是我们常用的演示工具,但有时候我们需要将PPT的内容提取为图片格式以便于展示或保存,所以本文将用Python实现PPT转PNG工具,希望... 目录1. 概述2. 功能使用2.1 安装依赖2.2 使用步骤2.3 代码实现2.4 GUI界面3.效

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

使用Python自建轻量级的HTTP调试工具

《使用Python自建轻量级的HTTP调试工具》这篇文章主要为大家详细介绍了如何使用Python自建一个轻量级的HTTP调试工具,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录一、为什么需要自建工具二、核心功能设计三、技术选型四、分步实现五、进阶优化技巧六、使用示例七、性能对比八、扩展方向建

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件