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

相关文章

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问