ios Image裁剪成圆形的方法

本文介绍了在iOS开发中将图片裁剪为圆形的三种方法:1) 使用图片mask进行裁剪,需要调整图片大小并设置mask;2) 通过UIImageView的layer属性,设置cornerRadius和masksToBounds;3) 利用代码创建图形上下文,绘制圆形路径,再绘制原图并裁剪。每种方法都有其适用场景和技术细节。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、通过image mask来操作,需要添加mask目标图片。

mask方法

 
  1. + (UIImage*) maskImage:(UIImage*)image withMask:(UIImage*)mask {  
  2.  
  3.  CGImageRef imgRef = [image CGImage];CGImageRef maskRef = [mask CGImage];
  4. CGImageRef actualMask = CGImageMaskCreate(CGImageGetWidth(maskRef),CGImageGetHeight(maskRef),
  5. CGImageGetBitsPerComponent(maskRef),CGImageGetBitsPerPixel(maskRef),
  6. CGImageGetBytesPerRow(maskRef),CGImageGetDataProvider(maskRef), 
  7. NULL, false);CGImageRef masked = CGImageCreateWithMask(imgRef, 
  8. actualMask);return [UIImage imageWithCGImage:masked];   

调整图片大小

 
  1. + (UIImage *) resizeImage:(UIImage *)image size:(CGSize)newSize {UIGraphicsBeginImageContext(newSize);  
  2. [image drawInRect:CGRectMake(0, 0, newSize.width, newSize.height)];  
  3. UIImage *newImage = UIGraphicsGetImageFromCurrentImageContext();UIGraphicsEndImageContext();  
  4. return newImage;   

方法调用/:將原始圖片縮成120x120,這一步視原始圖片大小而定,不一定要做

 
  1. UIImage *newImg = [Utils resizeImage:orgImg size:CGSizeMake(120, 120)];  
  2. UIImage *maskImg = [UIImage imageNamed:@"mask.png"];   
  3. // 取得mask的圖片物件
  4. newImg = [ImageUtils maskImage:newImg withMask:maskImg];   
  5. // 開始做裁切(Clip)圖片 

小结:详解iPhone开发应用中Mask用法的内容介绍完了


2、通过imageview的layer来操作
如下代码

  1. UIImageView imageView [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"oiuyfdsa.png"]];  
  2.    imageView.frame CGRectMake(20.f, 20.f, 100.f, 100.f);  
  3.    imageView.layer.masksToBounds YES;  
  4.    imageView.layer.cornerRadius 50;  

a.这种方法需要添加QuarztCore框架才能操作
b.cornerradus的确定问题

3、能过代码对画布裁剪成圆形–》然后再将原始图像画出来–》

  1. -(UIImage*) circleImage:(UIImage*) image withParam:(CGFloat) inset  
  2.     UIGraphicsBeginImageContext(image.size);  
  3.     CGContextRef context UIGraphicsGetCurrentContext();  
  4.     CGContextSetLineWidth(context, 2);  
  5.     CGContextSetStrokeColorWithColor(context, [UIColor redColor].CGColor);  
  6.     CGRect rect CGRectMake(inset, inset, image.size.width inset 2.0f, image.size.height inset 2.0f);  
  7.     CGContextAddEllipseInRect(context, rect);  
  8.     CGContextClip(context);  
  9.       
  10.     [image drawInRect:rect];  
  11.     CGContextAddEllipseInRect(context, rect);  
  12.     CGContextStrokePath(context);  
  13.     UIImage *newimg UIGraphicsGetImageFromCurrentImageContext();  
  14.     UIGraphicsEndImageContext();  
  15.     return newimg;  
  16.  

上面代码注意 如果裁剪后没有使用 CGContextAddEllipseInRect(context, rect);
CGContextStrokePath(context); 这条代码 就会引起背景为白色时看不出来任务效果。
这里是椭圆操作
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值