IOS图形的裁剪

我们要做出以下的效果:

①这里我们要新建一个图层

②得到图层的设备上下文

③在图层中绘制一个大圆,然后渲染到图层

④然后绘制一个小圆,剪切,然后渲染到图层

⑤绘制图片图层中

⑥然后从当前图层中获得图片,显示到View中

    - (void)drawRect:(CGRect)rect  
    {  
        UIImage *imageBackground = [UIImage imageNamed:@"01"];  
          
        //1.创建图层,此图大一些作为外框  
        CGFloat margin = 5;  
        CGFloat imageNewWidth = imageBackground.size.width + margin;  
        CGFloat imageNewHeight = imageBackground.size.width+ margin;  
        UIGraphicsBeginImageContextWithOptions(CGSizeMake(imageNewWidth, imageNewHeight), NO, 0.0);  
      
        //2.创建设备上下文,此时得到的上下文是图层的上下文。原因是上面创建了图层  
        CGContextRef ctr = UIGraphicsGetCurrentContext();  
        //3.在图层中绘制一个大圆,作为外框  
        CGContextAddEllipseInRect(ctr, CGRectMake(0, 0, imageNewWidth, imageNewHeight));  
        [[UIColor redColor]set];  
        CGContextFillPath(ctr);  
          
        //3.绘制小圆作为剪切图片的用  
        [[UIColor blueColor]set];  
        CGContextAddEllipseInRect(ctr, CGRectMake(margin, margin, imageNewWidth - 2*margin, imageNewHeight - 2*margin));  
        //4.按照当前的模式裁剪,裁剪只对后面绘制的图层有效 对已经绘制的图层无效  
       CGContextClip(ctr);  
        CGContextStrokePath(ctr);  
      
        //5.绘制图片  
        [imageBackground drawAtPoint:CGPointMake(0, 0)];  
        //6.从当前图层中获得Image  
        UIImage *imageNew = UIGraphicsGetImageFromCurrentImageContext();  
        //7.结束图层  
        UIGraphicsEndImageContext();  
          
        //8.绘制上文得到的Image到View中  
        [imageNew drawAtPoint:CGPointMake(0, 0)];  
    }  

编程技巧