标签:切成 self iOS 圆形 UIButton UIImage Circle size
在开发过程中我们要尽量避免离屏渲染,虽说现在对 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];
标签:切成,self,iOS,圆形,UIButton,UIImage,Circle,size 来源: https://blog.csdn.net/XXJcanbethebest/article/details/122611733
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。