iOS 圆形头像如何实现

http://blog.sina.com.cn/s/blog_693de6100101lfdc.html

思路:view有一个属性layer,通过设置cornerRadius来设置圆角的半径,view是正方形的才能保证通过调整圆角半径来形成圆形头像

 


 [view.layer setCornerRadius:CGRectGetHeight([view bounds])/ 2];

 view.layer.masksToBounds =YES;

然后再给图层添加一个有色的边框,类似qq空间头像那样

view.layer.borderWidth =5;

view.layer.borderColor = [[UIColorwhiteColor] CGColor];

view.layer.contents = (id)[[UIImageimageNamed:@"backgroundImage.png"] CGImage];


这样就可以制作成圆形头像了,很实用的




http://blog.csdn.net/x32sky/article/details/8283433

我知道的实现方法有三种。
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); 这条代码 就会引起背景为白色时看不出来任务效果。
这里是椭圆操作
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值