IOS Quartz 各种绘制图形用法---实现画图片、写文字、画线、椭圆、矩形、棱形等

本文主要是介绍IOS Quartz 各种绘制图形用法---实现画图片、写文字、画线、椭圆、矩形、棱形等,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  1. - (void)drawRect:(CGRect)rect  
  2. {  
  3.     CGContextRef context = UIGraphicsGetCurrentContext();  
  4.        
  5.    
  6.        
  7.     /*NO.1画一条线 
  8.        
  9.      CGContextSetRGBStrokeColor(context, 0.5, 0.5, 0.5, 0.5);//线条颜色 
  10.      CGContextMoveToPoint(context, 20, 20); 
  11.      CGContextAddLineToPoint(context, 200,20); 
  12.      CGContextStrokePath(context); 
  13.     */  
  14.    
  15.        
  16.        
  17.     /*NO.2写文字 
  18.        
  19.     CGContextSetLineWidth(context, 1.0); 
  20.     CGContextSetRGBFillColor (context, 0.5, 0.5, 0.5, 0.5); 
  21.     UIFont  *font = [UIFont boldSystemFontOfSize:18.0]; 
  22.     [@"公司:北京中软科技股份有限公司\n部门:ERP事业部\n姓名:McLiang" drawInRect:CGRectMake(20, 40, 280, 300) withFont:font]; 
  23.     */  
  24.    
  25.        
  26.     /*NO.3画一个正方形图形 没有边框 
  27.   
  28.     CGContextSetRGBFillColor(context, 0, 0.25, 0, 0.5); 
  29.     CGContextFillRect(context, CGRectMake(2, 2, 270, 270)); 
  30.     CGContextStrokePath(context); 
  31.     */  
  32.     
  33.        
  34.     /*NO.4画正方形边框 
  35.       
  36.     CGContextSetRGBStrokeColor(context, 0.5, 0.5, 0.5, 0.5);//线条颜色 
  37.     CGContextSetLineWidth(context, 2.0); 
  38.     CGContextAddRect(context, CGRectMake(2, 2, 270, 270)); 
  39.     CGContextStrokePath(context); 
  40.     */  
  41.    
  42.        
  43.     /*NO.5画方形背景颜色 
  44.        
  45.     CGContextTranslateCTM(context, 0.0f, self.bounds.size.height); 
  46.     CGContextScaleCTM(context, 1.0f, -1.0f); 
  47.     UIGraphicsPushContext(context); 
  48.     CGContextSetLineWidth(context,320); 
  49.     CGContextSetRGBStrokeColor(context, 250.0/255, 250.0/255, 210.0/255, 1.0); 
  50.     CGContextStrokeRect(context, CGRectMake(0, 0, 320, 460)); 
  51.     UIGraphicsPopContext(); 
  52.     */  
  53.    
  54.     /*NO.6椭圆 
  55.        
  56.      CGRect aRect= CGRectMake(80, 80, 160, 100); 
  57.      CGContextSetRGBStrokeColor(context, 0.6, 0.9, 0, 1.0); 
  58.      CGContextSetLineWidth(context, 3.0); 
  59.      CGContextAddEllipseInRect(context, aRect); //椭圆 
  60.      CGContextDrawPath(context, kCGPathStroke); 
  61.     */  
  62.    
  63.     /*NO.7 
  64.     CGContextBeginPath(context); 
  65.     CGContextSetRGBStrokeColor(context, 0, 0, 1, 1); 
  66.     CGContextMoveToPoint(context, 100, 100); 
  67.     CGContextAddArcToPoint(context, 50, 100, 50, 150, 50); 
  68.     CGContextStrokePath(context); 
  69.     */  
  70.    
  71.     /*NO.8渐变 
  72.     CGContextClip(context); 
  73.     CGColorSpaceRef rgb = CGColorSpaceCreateDeviceRGB(); 
  74.     CGFloat colors[] = 
  75.     { 
  76.         204.0 / 255.0, 224.0 / 255.0, 244.0 / 255.0, 1.00, 
  77.         29.0 / 255.0, 156.0 / 255.0, 215.0 / 255.0, 1.00, 
  78.         0.0 / 255.0,  50.0 / 255.0, 126.0 / 255.0, 1.00, 
  79.     }; 
  80.     CGGradientRef gradient = CGGradientCreateWithColorComponents 
  81.     (rgb, colors, NULL, sizeof(colors)/(sizeof(colors[0])*4)); 
  82.     CGColorSpaceRelease(rgb); 
  83.     CGContextDrawLinearGradient(context, gradient,CGPointMake 
  84.                                 (0.0,0.0) ,CGPointMake(0.0,self.frame.size.height), 
  85.                                 kCGGradientDrawsBeforeStartLocation); 
  86.      */  
  87.        
  88.       
  89.     /* NO.9四条线画一个正方形 
  90.     //画线 
  91.         UIColor *aColor = [UIColor colorWithRed:0 green:1.0 blue:0 alpha:0]; 
  92.     CGContextSetRGBStrokeColor(context, 1.0, 0, 0, 1.0); 
  93.        CGContextSetFillColorWithColor(context, aColor.CGColor); 
  94.     CGContextSetLineWidth(context, 4.0); 
  95.     CGPoint aPoints[5]; 
  96.     aPoints[0] =CGPointMake(60, 60); 
  97.     aPoints[1] =CGPointMake(260, 60); 
  98.     aPoints[2] =CGPointMake(260, 300); 
  99.     aPoints[3] =CGPointMake(60, 300); 
  100.     aPoints[4] =CGPointMake(60, 60); 
  101.     CGContextAddLines(context, aPoints, 5); 
  102.     CGContextDrawPath(context, kCGPathStroke); //开始画线 
  103.      */  
  104.        
  105.        
  106.        
  107.     /*  NO.10 
  108.     UIColor *aColor = [UIColor colorWithRed:0 green:1.0 blue:0 alpha:0]; 
  109.     CGContextSetRGBStrokeColor(context, 1.0, 0, 0, 1.0); 
  110.     CGContextSetFillColorWithColor(context, aColor.CGColor); 
  111.     //椭圆 
  112.     CGRect aRect= CGRectMake(80, 80, 160, 100); 
  113.     CGContextSetRGBStrokeColor(context, 0.6, 0.9, 0, 1.0); 
  114.     CGContextSetLineWidth(context, 3.0); 
  115.       CGContextSetFillColorWithColor(context, aColor.CGColor); 
  116.        CGContextAddRect(context, rect); //矩形 
  117.     CGContextAddEllipseInRect(context, aRect); //椭圆 
  118.     CGContextDrawPath(context, kCGPathStroke); 
  119.      */  
  120.    
  121.        
  122.        
  123.     /*  NO.11 
  124.      画一个实心的圆 
  125.    
  126.      CGContextFillEllipseInRect(context, CGRectMake(95, 95, 100.0, 100)); 
  127.     */  
  128.        
  129.        
  130.        
  131.     /*NO.12 
  132.      画一个菱形 
  133.     CGContextSetLineWidth(context, 2.0); 
  134.     CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  135.     CGContextMoveToPoint(context, 100, 100); 
  136.     CGContextAddLineToPoint(context, 150, 150); 
  137.     CGContextAddLineToPoint(context, 100, 200); 
  138.     CGContextAddLineToPoint(context, 50, 150); 
  139.     CGContextAddLineToPoint(context, 100, 100); 
  140.     CGContextStrokePath(context); 
  141.      */  
  142.    
  143.     /*NO.13 画矩形 
  144.     CGContextSetLineWidth(context, 2.0); 
  145.   
  146.     CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  147.   
  148.     CGRect rectangle = CGRectMake(60,170,200,80); 
  149.   
  150.     CGContextAddRect(context, rectangle); 
  151.       
  152.     CGContextStrokePath(context); 
  153.      */  
  154.        
  155.       
  156.     /*椭圆 
  157.     CGContextSetLineWidth(context, 2.0); 
  158.   
  159.     CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  160.   
  161.     CGRect rectangle = CGRectMake(60,170,200,80); 
  162.   
  163.     CGContextAddEllipseInRect(context, rectangle); 
  164.       
  165.     CGContextStrokePath(context); 
  166.      */  
  167.        
  168.     /*用红色填充了一段路径: 
  169.       
  170.     CGContextMoveToPoint(context, 100, 100); 
  171.     CGContextAddLineToPoint(context, 150, 150); 
  172.     CGContextAddLineToPoint(context, 100, 200); 
  173.     CGContextAddLineToPoint(context, 50, 150); 
  174.     CGContextAddLineToPoint(context, 100, 100); 
  175.     CGContextSetFillColorWithColor(context, [UIColor redColor].CGColor); 
  176.     CGContextFillPath(context); 
  177.     */  
  178.        
  179.     /*填充一个蓝色边的红色矩形 
  180.     CGContextSetLineWidth(context, 2.0); 
  181.     CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  182.     CGRect rectangle = CGRectMake(60,170,200,80); 
  183.     CGContextAddRect(context, rectangle); 
  184.     CGContextStrokePath(context); 
  185.     CGContextSetFillColorWithColor(context, [UIColor redColor].CGColor); 
  186.     CGContextFillRect(context, rectangle); 
  187.     */  
  188.        
  189.     /*画弧 
  190.      //弧线的是通过指定两个切点,还有角度,调用CGContextAddArcToPoint()绘制 
  191.     CGContextSetLineWidth(context, 2.0); 
  192.     CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  193.     CGContextMoveToPoint(context, 100, 100); 
  194.     CGContextAddArcToPoint(context, 100,200, 300,200, 100); 
  195.     CGContextStrokePath(context); 
  196.     */  
  197.       
  198.        
  199.     /* 
  200.     绘制贝兹曲线 
  201.     //贝兹曲线是通过移动一个起始点,然后通过两个控制点,还有一个中止点,调用CGContextAddCurveToPoint() 函数绘制 
  202.     CGContextSetLineWidth(context, 2.0); 
  203.   
  204.     CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  205.   
  206.     CGContextMoveToPoint(context, 10, 10); 
  207.   
  208.     CGContextAddCurveToPoint(context, 0, 50, 300, 250, 300, 400); 
  209.       
  210.     CGContextStrokePath(context); 
  211.      */  
  212.        
  213.     /*绘制二次贝兹曲线 
  214.       
  215.       CGContextSetLineWidth(context, 2.0); 
  216.   
  217.       CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  218.   
  219.       CGContextMoveToPoint(context, 10, 200); 
  220.   
  221.       CGContextAddQuadCurveToPoint(context, 150, 10, 300, 200); 
  222.       
  223.       CGContextStrokePath(context); 
  224.      */  
  225.        
  226.     /*绘制虚线 
  227.     CGContextSetLineWidth(context, 5.0); 
  228.   
  229.     CGContextSetStrokeColorWithColor(context, [UIColor blueColor].CGColor); 
  230.   
  231.     CGFloat dashArray[] = {2,6,4,2}; 
  232.   
  233.     CGContextSetLineDash(context, 3, dashArray, 4);//跳过3个再画虚线,所以刚开始有6-(3-2)=5个虚点 
  234.       
  235.     CGContextMoveToPoint(context, 10, 200); 
  236.       
  237.     CGContextAddQuadCurveToPoint(context, 150, 10, 300, 200); 
  238.       
  239.     CGContextStrokePath(context); 
  240.     */  
  241. /*绘制图片 
  242.     NSString* imagePath = [[NSBundle mainBundle] pathForResource:@"dog" ofType:@"png"]; 
  243.     UIImage* myImageObj = [[UIImage alloc] initWithContentsOfFile:imagePath]; 
  244.     //[myImageObj drawAtPoint:CGPointMake(0, 0)]; 
  245.     [myImageObj drawInRect:CGRectMake(0, 0, 320, 480)]; 
  246.   
  247.     NSString *s = @"我的小狗"; 
  248.   
  249.     [s drawAtPoint:CGPointMake(100, 0) withFont:[UIFont systemFontOfSize:34.0]]; 
  250. */  
  251.        
  252.   /* 
  253.     NSString *path = [[NSBundle mainBundle] pathForResource:@"dog" ofType:@"png"]; 
  254.     UIImage *img = [UIImage imageWithContentsOfFile:path]; 
  255.     CGImageRef image = img.CGImage; 
  256.     CGContextSaveGState(context); 
  257.     CGRect touchRect = CGRectMake(0, 0, img.size.width, img.size.height); 
  258.     CGContextDrawImage(context, touchRect, image); 
  259.     CGContextRestoreGState(context); 
  260.    */  
  261.      
  262.        
  263.     /*NSString *path = [[NSBundle mainBundle] pathForResource:@"dog" ofType:@"png"]; 
  264.     UIImage *img = [UIImage imageWithContentsOfFile:path]; 
  265.     CGImageRef image = img.CGImage; 
  266.     CGContextSaveGState(context); 
  267.   
  268.     CGContextRotateCTM(context, M_PI); 
  269.     CGContextTranslateCTM(context, -img.size.width, -img.size.height); 
  270.   
  271.     CGRect touchRect = CGRectMake(0, 0, img.size.width, img.size.height); 
  272.     CGContextDrawImage(context, touchRect, image); 
  273.     CGContextRestoreGState(context);*/  
  274.    
  275. /* 
  276.     NSString *path = [[NSBundle mainBundle] pathForResource:@"dog" ofType:@"png"]; 
  277.     UIImage *img = [UIImage imageWithContentsOfFile:path]; 
  278.     CGImageRef image = img.CGImage; 
  279.       
  280.     CGContextSaveGState(context); 
  281.   
  282.     CGAffineTransform myAffine = CGAffineTransformMakeRotation(M_PI); 
  283.     myAffine = CGAffineTransformTranslate(myAffine, -img.size.width, -img.size.height); 
  284.     CGContextConcatCTM(context, myAffine); 
  285.   
  286.     CGContextRotateCTM(context, M_PI); 
  287.     CGContextTranslateCTM(context, -img.size.width, -img.size.height); 
  288.   
  289.     CGRect touchRect = CGRectMake(0, 0, img.size.width, img.size.height); 
  290.     CGContextDrawImage(context, touchRect, image); 
  291.     CGContextRestoreGState(context); 
  292. */  
  293. }  

这篇关于IOS Quartz 各种绘制图形用法---实现画图片、写文字、画线、椭圆、矩形、棱形等的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

Spring StateMachine实现状态机使用示例详解

《SpringStateMachine实现状态机使用示例详解》本文介绍SpringStateMachine实现状态机的步骤,包括依赖导入、枚举定义、状态转移规则配置、上下文管理及服务调用示例,重点解... 目录什么是状态机使用示例什么是状态机状态机是计算机科学中的​​核心建模工具​​,用于描述对象在其生命

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

IntelliJ IDEA2025创建SpringBoot项目的实现步骤

《IntelliJIDEA2025创建SpringBoot项目的实现步骤》本文主要介绍了IntelliJIDEA2025创建SpringBoot项目的实现步骤,文中通过示例代码介绍的非常详细,对大家... 目录一、创建 Spring Boot 项目1. 新建项目2. 基础配置3. 选择依赖4. 生成项目5.

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

Linux下删除乱码文件和目录的实现方式

《Linux下删除乱码文件和目录的实现方式》:本文主要介绍Linux下删除乱码文件和目录的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux下删除乱码文件和目录方法1方法2总结Linux下删除乱码文件和目录方法1使用ls -i命令找到文件或目录

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控