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

相关文章

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo