ios Image裁剪成圆形的方法 [转]

本文详细介绍了三种实现方法:通过imageMask、imageView的layer以及自定义代码裁剪图像为圆形,并优化了角落圆润效果。包括代码示例和注意事项。

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

我知道的实现方法有三种。
1、通过image mask来操作,需要添加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); 这条代码 就会引起背景为白色时看不出来任务效果。
这里是椭圆操作

转载于:https://www.cnblogs.com/jinjiantong/archive/2013/04/15/3021361.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值