码迷,mamicode.com
首页 > 移动开发 > 详细

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

时间:2017-06-27 10:06:41      阅读:309      评论:0      收藏:0      [点我收藏+]

标签:vpc   简单   cap   tab   table   三角形   缩放   裁剪   new   

技术分享

技术分享


- (void)drawRect:(CGRect)rect {
    //获得当前上下文
    CGContextRef ctx=UIGraphicsGetCurrentContext();
    
    //把当前上下文状态保存在栈中
    CGContextSaveGState(ctx);
    
    //缩放、移动处理(须要放在画图之前进行设置)
    CGContextScaleCTM(ctx, 0.5, 0.5);
    CGContextTranslateCTM(ctx, 100, 100);
    CGContextRotateCTM(ctx, M_PI_4);
    
    //描点
    CGContextMoveToPoint(ctx, 10, 10);
    CGContextAddLineToPoint(ctx, 100, 100);
    CGContextAddLineToPoint(ctx, 150, 50);
    //下面两种方式均可闭环
    //CGContextAddLineToPoint(ctx, 10, 10);
    CGContextClosePath(ctx);
    //渲染画图,实心和空心
    CGContextStrokePath(ctx);
    //CGContextFillPath(ctx);
    
    //把当前上下文状态保存在栈中
    CGContextSaveGState(ctx);
    
    //画正方形
    CGContextAddRect(ctx, CGRectMake(100, 100, 50, 50));
    //设置线宽(一定要在CGContextStrokePath之前)
    //由于之前有过一次渲染画图,所以这个属性设置不影响上面的那个三角形,下面颜色设置同理
    //所以,假设想分别设置两个或多个图形的属性,就分别渲染画图一次
    CGContextSetLineWidth(ctx, 10);
    //设置颜色(同理。属性设置的代码都要在画图的代码之前)
    CGContextSetRGBStrokeColor(ctx, 1, 0, 0, 1);
    CGContextStrokePath(ctx);
    
    //设置样式
    CGContextMoveToPoint(ctx, 20, 160);
    CGContextAddLineToPoint(ctx, 200, 280);
    CGContextAddLineToPoint(ctx, 250, 200);
    CGContextSetLineWidth(ctx, 20);
    //设置头尾样式
    CGContextSetLineCap(ctx, kCGLineCapRound);
    //设置转角样式
    CGContextSetLineJoin(ctx, kCGLineJoinRound);
    CGContextStrokePath(ctx);
    
    //把保存在栈中的上下文状态取出来,恢复。

上面那段代码设置的样式不会影响其它 CGContextRestoreGState(ctx); //画椭圆 CGContextAddEllipseInRect(ctx, CGRectMake(200, 130, 60, 30)); //下面等价 //CGContextStrokePath(ctx); CGContextDrawPath(ctx, kCGPathStroke); //画圆形 CGContextAddEllipseInRect(ctx, CGRectMake(140, 170, 50, 50)); CGContextSetLineWidth(ctx, 3); CGContextStrokePath(ctx); //画圆弧 CGContextAddArc(ctx, 200, 50, 50, M_PI_4, M_PI, 1); CGContextStrokePath(ctx); //画1/4圆,以及颜色的设置新方法 CGContextMoveToPoint(ctx, 10, 230); CGContextAddLineToPoint(ctx, 10, 280); CGContextAddLineToPoint(ctx, 60, 280); CGContextAddArc(ctx, 10, 280, 50, 0, -M_PI_2, 1); [[UIColor greenColor] setStroke]; CGContextStrokePath(ctx); //画图片和文字(不须要手动取得上下文) NSString *str1=@"辛丑年一空作"; [str1 drawAtPoint:CGPointZero withAttributes:nil]; UIImage *img=[UIImage imageNamed:@"001"]; [img drawAtPoint:CGPointMake(10, 10)]; //在一个框框里重叠图片并署名 CGRect rect1=CGRectMake(50, 50, 100, 100); [img drawAsPatternInRect:rect1]; NSMutableDictionary *attr=[[NSMutableDictionary alloc]init]; attr[NSForegroundColorAttributeName]=[UIColor whiteColor]; attr[NSFontAttributeName]=[UIFont systemFontOfSize:13]; [str1 drawInRect:CGRectMake(50, 140, 100, 100) withAttributes:attr]; //把保存在栈中的上下文状态取出来,恢复。上面那段代码设置的样式不会影响其它 CGContextRestoreGState(ctx); //裁剪圆形头像 CGContextAddEllipseInRect(ctx, CGRectMake(150, 150, 100 , 100)); //依照圆形剪裁出一个上下文区域,以后的内容就填充在这个圆形上下文中 CGContextClip(ctx); UIImage *img1=[UIImage imageNamed:@"me"]; [img1 drawAtPoint:CGPointMake(150, 150)]; }



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

标签:vpc   简单   cap   tab   table   三角形   缩放   裁剪   new   

原文地址:http://www.cnblogs.com/wzzkaifa/p/7083254.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!