在开发过程中我们要尽量避免离屏渲染,虽说现在对 UIImageView.layer 进行圆角设置和遮罩不会触发离屏渲染,但是在 UIButton 设置背景图的情况下 如果对 UIButton.layer 进行上述处理,则会触发离屏渲染。
所以我们可以利用 CoreGraphics 将图片画成圆形而不对UIButton进行设置。
我们创建一个UIImage的分类 UIImage+Circle,声明一个方法 circle 并实现
//.h
#import <UIKit/UIKit.h>
NS_ASSUME_NONNULL_BEGIN
@interface UIImage (Circle)
- (UIImage *)circle;
@end
NS_ASSUME_NONNULL_END
//.m
#import "UIImage+Circle.h"
@implementation UIImage (Circle)
//将图片裁剪成圆形
- (UIImage *)circle
{
// NO代表透明
UIGraphicsBeginImageContextWithOptions(self.size, NO, 1);
// 获得上下文
CGContextRef ctx = UIGraphicsGetCurrentContext();
// 添加一个圆
CGRect rect = CGRectMake(0, 0, self.size.width, self.size.height);
// 方形变圆形
CGContextAddEllipseInRect(ctx, rect);
// 裁剪
CGContextClip(ctx);
// 将图片画上去
[self drawInRect:rect];
UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return image;
}
@end
然后我们在创建UIImage时,可以直接使用这个方法得到一个圆形图片
UIImage *image=[[UIImage imageNamed:@"image1"] circleImage];