在开发过程中我们要尽量避免离屏渲染,虽说现在对 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];