【深入浅出IOS开发】图片剪切
2015-03-31 09:12
204 查看
我们常常需要将一个方形图片剪切成圆形,或者从某个大图里面获得一部分,这些时候我们通常用剪切。
裁剪相当于一种属性,减掉前面绘制的图形以外的区域。所以我们裁剪过之后通常要恢复以前的绘图状态
此时我们一般分以下三步:
①保存当前的上下文状态
CGContextSaveGState(ctr);
②在绘制好一些区域以后,进行裁剪
CGContextClip(ctr);
③恢复裁剪之前的上下文状态
CGContextRestoreGState(ctr);
[objc] view
plaincopy
//剪成圆形图片
void drawClipImage(CGRect rect,CGContextRef ctr)
{
//裁剪之前我们通常要保存一下当前的状态
CGContextSaveGState(ctr);
CGContextAddEllipseInRect(ctr, CGRectMake(rect.size.width/3, 0, rect.size.width/3, rect.size.height/4));
CGContextAddRect(ctr, CGRectMake(100, 200, 100, 200));
//裁剪相当于一种属性,减掉前面绘制的图形以外的区域
CGContextClip(ctr);
CGContextStrokePath(ctr);
UIImage *image = [UIImage imageNamed:@"1"];
[image drawInRect:CGRectMake(0, 0, rect.size.width, rect.size.height)];
//恢复之前的上下文状态
CGContextRestoreGState(ctr);
}
裁剪相当于一种属性,减掉前面绘制的图形以外的区域。所以我们裁剪过之后通常要恢复以前的绘图状态
此时我们一般分以下三步:
①保存当前的上下文状态
CGContextSaveGState(ctr);
②在绘制好一些区域以后,进行裁剪
CGContextClip(ctr);
③恢复裁剪之前的上下文状态
CGContextRestoreGState(ctr);
[objc] view
plaincopy
//剪成圆形图片
void drawClipImage(CGRect rect,CGContextRef ctr)
{
//裁剪之前我们通常要保存一下当前的状态
CGContextSaveGState(ctr);
CGContextAddEllipseInRect(ctr, CGRectMake(rect.size.width/3, 0, rect.size.width/3, rect.size.height/4));
CGContextAddRect(ctr, CGRectMake(100, 200, 100, 200));
//裁剪相当于一种属性,减掉前面绘制的图形以外的区域
CGContextClip(ctr);
CGContextStrokePath(ctr);
UIImage *image = [UIImage imageNamed:@"1"];
[image drawInRect:CGRectMake(0, 0, rect.size.width, rect.size.height)];
//恢复之前的上下文状态
CGContextRestoreGState(ctr);
}
相关文章推荐
- 【深入浅出IOS开发】图片剪切
- 【深入浅出IOS开发】设置图片水印
- 【深入浅出IOS开发】彩票-按钮中图片的拉伸
- 【深入浅出IOS开发】彩票-按钮中图片的拉伸
- iOS陆哥开发笔记(十九) (Quartz2D图片剪切)
- iOS开发UI篇—Quartz2D使用(图片剪切)
- 【深入浅出IOS开发】绘制图片
- 在iOS开发的Quartz2D使用中实现图片剪切和截屏功能
- iOS开发UI篇—Quartz2D使用(图片剪切)
- 【深入浅出IOS开发】绘制图片
- 【深入浅出IOS开发】设置图片水印
- iOS开发UI篇—Quartz2D使用(图片剪切)
- iOS开发UI篇—Quartz2D使用(图片剪切)
- iOS开发UI篇—Quartz2D使用(图片剪切)
- iOS开发UI高级—23Quartz2D使用(图片剪切)
- 【深入浅出IOS开发】绘制图片
- iOS开发UI篇—Quartz2D使用(图片剪切)
- 在iOS开发的Quartz2D使用中实现图片剪切和截屏功能
- iOS开发UI篇—Quartz2D使用(图片剪切)
- iOS小明开发笔记(十六) (Quartz2D图片剪切)