本文转载至 http://blog.csdn.net/weisubao/article/details/41282457

  1. - (void)drawRect:(CGRect)rect {
  2. //获得当前上下文
  3. CGContextRef ctx=UIGraphicsGetCurrentContext();
  4. //把当前上下文状态保存在栈中
  5. CGContextSaveGState(ctx);
  6. //缩放、移动处理(需要放在画图之前进行设置)
  7. CGContextScaleCTM(ctx, 0.5, 0.5);
  8. CGContextTranslateCTM(ctx, 100, 100);
  9. CGContextRotateCTM(ctx, M_PI_4);
  10. //描点
  11. CGContextMoveToPoint(ctx, 10, 10);
  12. CGContextAddLineToPoint(ctx, 100, 100);
  13. CGContextAddLineToPoint(ctx, 150, 50);
  14. //以下两种方式均可闭环
  15. //CGContextAddLineToPoint(ctx, 10, 10);
  16. CGContextClosePath(ctx);
  17. //渲染绘图,实心和空心
  18. CGContextStrokePath(ctx);
  19. //CGContextFillPath(ctx);
  20. //把当前上下文状态保存在栈中
  21. CGContextSaveGState(ctx);
  22. //画正方形
  23. CGContextAddRect(ctx, CGRectMake(100, 100, 50, 50));
  24. //设置线宽(一定要在CGContextStrokePath之前)
  25. //因为之前有过一次渲染绘图,所以这个属性设置不影响上面的那个三角形,以下颜色设置同理
  26. //所以,如果想分别设置两个或多个图形的属性,就分别渲染绘图一次
  27. CGContextSetLineWidth(ctx, 10);
  28. //设置颜色(同理,属性设置的代码都要在绘图的代码之前)
  29. CGContextSetRGBStrokeColor(ctx, 1, 0, 0, 1);
  30. CGContextStrokePath(ctx);
  31. //设置样式
  32. CGContextMoveToPoint(ctx, 20, 160);
  33. CGContextAddLineToPoint(ctx, 200, 280);
  34. CGContextAddLineToPoint(ctx, 250, 200);
  35. CGContextSetLineWidth(ctx, 20);
  36. //设置头尾样式
  37. CGContextSetLineCap(ctx, kCGLineCapRound);
  38. //设置转角样式
  39. CGContextSetLineJoin(ctx, kCGLineJoinRound);
  40. CGContextStrokePath(ctx);
  41. //把保存在栈中的上下文状态取出来,恢复。上面那段代码设置的样式不会影响其他
  42. CGContextRestoreGState(ctx);
  43. //画椭圆
  44. CGContextAddEllipseInRect(ctx, CGRectMake(200, 130, 60, 30));
  45. //以下等价
  46. //CGContextStrokePath(ctx);
  47. CGContextDrawPath(ctx, kCGPathStroke);
  48. //画圆形
  49. CGContextAddEllipseInRect(ctx, CGRectMake(140, 170, 50, 50));
  50. CGContextSetLineWidth(ctx, 3);
  51. CGContextStrokePath(ctx);
  52. //画圆弧
  53. CGContextAddArc(ctx, 200, 50, 50, M_PI_4, M_PI, 1);
  54. CGContextStrokePath(ctx);
  55. //画1/4圆,以及颜色的设置新方法
  56. CGContextMoveToPoint(ctx, 10, 230);
  57. CGContextAddLineToPoint(ctx, 10, 280);
  58. CGContextAddLineToPoint(ctx, 60, 280);
  59. CGContextAddArc(ctx, 10, 280, 50, 0, -M_PI_2, 1);
  60. [[UIColor greenColor] setStroke];
  61. CGContextStrokePath(ctx);
  62. //画图片和文字(不需要手动取得上下文)
  63. NSString *str1=@"辛丑年一空作";
  64. [str1 drawAtPoint:CGPointZero withAttributes:nil];
  65. UIImage *img=[UIImage imageNamed:@"001"];
  66. [img drawAtPoint:CGPointMake(10, 10)];
  67. //在一个框框里重叠图片并署名
  68. CGRect rect1=CGRectMake(50, 50, 100, 100);
  69. [img drawAsPatternInRect:rect1];
  70. NSMutableDictionary *attr=[[NSMutableDictionary alloc]init];
  71. attr[NSForegroundColorAttributeName]=[UIColor whiteColor];
  72. attr[NSFontAttributeName]=[UIFont systemFontOfSize:13];
  73. [str1 drawInRect:CGRectMake(50, 140, 100, 100) withAttributes:attr];
  74. //把保存在栈中的上下文状态取出来,恢复。上面那段代码设置的样式不会影响其他
  75. CGContextRestoreGState(ctx);
  76. //裁剪圆形头像
  77. CGContextAddEllipseInRect(ctx, CGRectMake(150, 150, 100 , 100));
  78. //按照圆形剪裁出一个上下文区域,以后的内容就填充在这个圆形上下文中
  79. CGContextClip(ctx);
  80. UIImage *img1=[UIImage imageNamed:@"me"];
  81. [img1 drawAtPoint:CGPointMake(150, 150)];
  82. }

【iOS开发-80】Quartz2D绘图简介:直线/圆形/椭圆/方形以及上下文栈管理CGContextSaveGState/CGContextRestoreGState的更多相关文章

  1. 【iOS开发-80】Quartz2D画图简单介绍:直线/圆形/椭圆/方形以及上下文栈管理CGContextSaveGState/CGContextRestoreGState

    watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2Vpc3ViYW8=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA ...

  2. iOS开发UI篇—CALayer简介

    iOS开发UI篇—CALayer简介   一.简单介绍 在iOS中,你能看得见摸得着的东西基本上都是UIView,比如一个按钮.一个文本标签.一个文本输入框.一个图标等等,这些都是UIView. 其实 ...

  3. iOS开发多线程篇—多线程简介

    iOS开发多线程篇-多线程简介 一.进程和线程 1.什么是进程 进程是指在系统中正在执行的一个应用程序 每一个进程之间是独立的.每一个进程均执行在其专用且受保护的内存空间内 比方同一时候打开QQ.Xc ...

  4. iOS开发进阶--1.多线程简介

    学习是由已知的知识模型推理未知的知识模型的的过程. 本文适合学习完objective-c基础,想进一步提高做iOS开发的同学阅读. 在说线程的时候,我们先看看进程. 1.进程 每一个运行在系统中的应用 ...

  5. iOS开发多线程篇—GCD简介

    iOS开发多线程篇—GCD介绍 一.简单介绍 1.什么是GCD? 全称是Grand Central Dispatch,可译为“牛逼的中枢调度器” 纯C语言,提供了非常多强大的函数 2.GCD的优势 G ...

  6. 在iOS开发的Quartz2D使用中实现图片剪切和截屏功能

    原文  http://www.jb51.net/article/75671.htm 图片剪切一.使用Quartz2D完成图片剪切1.把图片显示在自定义的view中先把图片绘制到view上.按照原始大小 ...

  7. iOS开发Drag and Drop简介

    1.Drag and Drop简介 Drag and Drop是iOS11的新特性,可以将文本.图片进行拖拽到不同app中,实现数据的传递.只不过只能在iPad上使用,iPhone上只能app内部拖拽 ...

  8. iOS开发--CoreGraphics简单绘图

    一.导入coreGraphics.framework 二.绘制图形 1.绘制矩形 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 // 绘制矩形 - (v ...

  9. iOS开发UITouch触摸API简介

    1.UITouch简介 当用户触摸屏幕时,会创建一个UITouch对象: UITouch的作用保存着触摸相关的信息,比如触摸的位置.时间.阶段等: 当从开始到结束,系统会更新UITouch对象,结束时 ...

随机推荐

  1. [置顶] kubernetes资源类型--pod和job

    pod Pod是K8S的最小操作单元,一个Pod可以由一个或多个容器组成:整个K8S系统都是围绕着Pod展开的,比如如何部署运行Pod.如何保证Pod的数量.如何访问Pod等. 特点 Pod是能够被创 ...

  2. iOS:自定义模态动画 --UIPresentationController

    UIPresentationController :展示控制器,是iOS8的一个新特性,用来展示模态窗口的.它是所有模态控制器的管理者. 即: 1> 管理所有Modal出来的控制器 2>  ...

  3. 前端JS利用canvas的drawImage()对图片进行压缩

    对于大尺寸图片的上传,在前端进行压缩除了省流量外,最大的意义是极大的提高了用户体验. 这种体验包括两方面: 1.由于上传图片尺寸比较小,因此上传速度会比较快,交互会更加流畅,同时大大降低了网络异常导致 ...

  4. linux bash 入门

    #!/bin/bash #shell使用的熟练成都反映用户对Unix/Linux使用的熟练程度 #shell 有两种执行命令的方式:交互式和批处理 #常见的shell脚本解释器有bash,sh,csh ...

  5. 用于快速排查Java的CPU性能问题(top us值过高)

    转载于GIT路径 https://github.com/oldratlee/useful-scripts/blob/master/docs/java.md#beer-show-busy-java-th ...

  6. 2017.7.31 ELK+logback+redis的使用

    参考来自:spring mvc+ELK从头开始搭建日志平台 0 前提 ELK安装成功 redis安装成功 使用logback的项目运行成功 1 配置文件 1.1 pom.xml 为了使用logback ...

  7. oc 之中的 汉字字符串转化成为拼音 汉字字符串的排序

    在oc 之中的字符串为汉字的时候,我们经常要进行字符串比較,可是汉字不能比較,所以就要将汉字转化成为拼音,详细步骤例如以下: //可变字符串 必须是可变字符串.     NSMutableString ...

  8. 倍福TwinCAT(贝福Beckhoff)基础教程 松下伺服驱动器报错 88怎么办

    请确认在TWINCAT在线模式下,把Drive的Modes of operation改为8       更多教学视频和资料下载,欢迎关注以下信息: 我的优酷空间: http://i.youku.com ...

  9. 使用C++11封装线程池ThreadPool

    读本文之前,请务必阅读: 使用C++11的function/bind组件封装Thread以及回调函数的使用 Linux组件封装(五)一个生产者消费者问题示例   线程池本质上是一个生产者消费者模型,所 ...

  10. POJ2536 Gopher II【二分图最大匹配】

    题目链接: http://poj.org/problem? id=2536 题目大意: 有N仅仅鼹鼠和M个洞穴,假设鼹鼠在S秒内不可以跑到洞穴,就会被老鹰捉住吃掉. 鼹鼠跑的速度为V米/秒. 已知一个 ...