我们要做出以下的效果:
①这里我们要新建一个图层
②得到图层的设备上下文
③在图层中绘制一个大圆,然后渲染到图层
④然后绘制一个小圆,剪切,然后渲染到图层
⑤绘制图片图层中
⑥然后从当前图层中获得图片,显示到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)]; }