http://blog.sina.com.cn/s/blog_693de6100101lfdc.html
上面代码注意 如果裁剪后没有使用 CGContextAddEllipseInRect(context, rect);
CGContextStrokePath(context); 这条代码 就会引起背景为白色时看不出来任务效果。
这里是椭圆操作
思路:view有一个属性layer,通过设置cornerRadius来设置圆角的半径,view是正方形的才能保证通过调整圆角半径来形成圆形头像
然后再给图层添加一个有色的边框,类似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来操作
如下代码
- UIImageView * imageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"oiuyfdsa.png"]];
- imageView.frame = CGRectMake(20.f, 20.f, 100.f, 100.f);
- imageView.layer.masksToBounds = YES;
- imageView.layer.cornerRadius = 50;
a.这种方法需要添加QuarztCore框架才能操作
b.cornerradus的确定问题
3、能过代码对画布裁剪成圆形–》然后再将原始图像画出来–》
- -(UIImage*) circleImage:(UIImage*) image withParam:(CGFloat) inset {
- UIGraphicsBeginImageContext(image.size);
- CGContextRef context = UIGraphicsGetCurrentContext();
- CGContextSetLineWidth(context, 2);
- CGContextSetStrokeColorWithColor(context, [UIColor redColor].CGColor);
- CGRect rect = CGRectMake(inset, inset, image.size.width - inset * 2.0f, image.size.height - inset * 2.0f);
- CGContextAddEllipseInRect(context, rect);
- CGContextClip(context);
- [image drawInRect:rect];
- CGContextAddEllipseInRect(context, rect);
- CGContextStrokePath(context);
- UIImage *newimg = UIGraphicsGetImageFromCurrentImageContext();
- UIGraphicsEndImageContext();
- return newimg;
- }
上面代码注意 如果裁剪后没有使用 CGContextAddEllipseInRect(context, rect);
CGContextStrokePath(context); 这条代码 就会引起背景为白色时看不出来任务效果。
这里是椭圆操作