iOS设置圆角的三种方式

转载:https://www.cnblogs.com/mafeng/p/5672528.html

这三种方法中第三种最好,对内存的消耗最少啊,而且渲染快速。

第一种方法:通过设置layer的属性转最简单的一种,但是很影响性能,一般在正常的开发中使用很少.

UIImageView *imageView = [[UIImageView alloc]initWithFrame:CGRectMake(100, 100, 100, 100)];

//只需要设置layer层的两个属性

//设置圆角

imageView.layer.cornerRadius = imageView.frame.size.width / 2;//将多余的部分切掉imageView.layer.masksToBounds = YES;

[self.view addSubview:imageView];

第二种方法:使用贝塞尔曲线UIBezierPath和Core Graphics框架画出一个圆角

UIImageView *imageView = [[UIImageView alloc]initWithFrame:CGRectMake(100, 100, 100, 100)];imageView.image = [UIImage imageNamed:@"1"];

//开始对imageView进行画图

UIGraphicsBeginImageContextWithOptions(imageView.bounds.size, NO, 1.0);

//使用贝塞尔曲线画出一个圆形图

[[UIBezierPath bezierPathWithRoundedRect:imageView.bounds cornerRadius:imageView.frame.size.width] addClip];

[imageView drawRect:imageView.bounds];

imageView.image = UIGraphicsGetImageFromCurrentImageContext();//结束画图

UIGraphicsEndImageContext();

[self.view addSubview:imageView];

第三种方法:使用CAShapeLayer和UIBezierPath设置圆角首先需要导入

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

UIImageView *imageView = [[UIImageView alloc]initWithFrame:CGRectMake(100, 100, 100, 100)];

imageView.image = [UIImage imageNamed:@"1"];

UIBezierPath *maskPath = [UIBezierPath bezierPathWithRoundedRect:imageView.bounds byRoundingCorners:UIRectCornerAllCorners cornerRadii:imageView.bounds.size];

CAShapeLayer *maskLayer = [[CAShapeLayer alloc]init];

//设置大小

maskLayer.frame = imageView.bounds;

//设置图形样子

maskLayer.path = maskPath.CGPath;

imageView.layer.mask = maskLayer;

[self.view addSubview:imageView];

}

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1:通过设置layer属性:最简单的一种,但是很影响性能,会造成离屏渲染,一般在开发中很少使用。 UIImageV...
    花椒不麻牙阅读 4,908评论 0 0
  • 第一种方法:通过设置layer的属性最简单的一种,但是很影响性能,一般在正常的开发中使用很少. 或者在xib中设置...
    mengyingguo阅读 3,474评论 0 0
  • 之前面试的时候被问道设置圆角除了layer还有什么方法?因为大家都知道layer会影响app性能,也是大家最常用、...
    Big_Zheng阅读 5,102评论 0 3
  • 在iOS中随处都可以看到绚丽的动画效果,实现这些动画的过程并不复杂,今天将带大家一窥ios动画全貌。在这里你可以看...
    每天刷两次牙阅读 12,727评论 6 30
  • 轻轻地我走了,正如我悄悄的来,没有朋友陪伴,不带走他乡的云彩。 很荣幸,由东向西的列车竟然还是最后一节车厢。车尾是...
    天涯草阅读 1,621评论 0 1

友情链接更多精彩内容