ios--离屏渲染masksToBounds

最近在看关于离屏渲染,看到网上有很多文章都说只要是设置了圆角加上masksToBounds就会发生离屏渲染,这里纠正一下,首先测试下UIView,我们这里开启了Color Off-screen Rendered,也就是说,这个选项为离屏渲染内容添加一个黄色的叠加层。

介绍下masksToBunds的,是类CALayer的属性,如果设置为yes,则不显示超出父View layer的部分

UIView代码如下

    UIView * view = [[UIView alloc]initWithFrame:CGRectMake(50, 50, 100, 100)];
    
    view.backgroundColor =[UIColor redColor];
    
    view.layer.cornerRadius=50;
    //对于UIView不加下面这句话也是可以做出圆角效果,这里主要是测试网上的说法
    view.layer.masksToBounds=YES;
    
    [self.view addSubview:view];

以及对于UILabel,设置了圆角和masksToBounds


 UILabel * label = [[UILabel alloc]initWithFrame:CGRectMake(50, 50, 100, 100)];
    
    label.text=@"哈哈";
    
    label.backgroundColor =[UIColor redColor];
    
    label.layer.cornerRadius=50;
    
    label.layer.masksToBounds=YES;
   
    [self.view addSubview:label];
可以看到也是没有黄色图层的出现,没有出现离屏渲染


如果是UIButton

UIButton * view = [[UIButton alloc]initWithFrame:CGRectMake(50, 50, 100, 100)];

    //view.backgroundColor =[UIColor redColor];

    [view setImage:[UIImage imageNamed:@"03"] forState:UIControlStateNormal];
    view.layer.cornerRadius=50;

    view.layer.masksToBounds=true;


    [self.view addSubview:view];

设置圆角之后就会显示黄色图层,离屏渲染了

如果是UIImageView

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

    //view.backgroundColor =[UIColor redColor];

    view.image= [UIImage imageNamed:@"03"];
    view.layer.cornerRadius=50;

    view.layer.masksToBounds=true;


    [self.view addSubview:view];

也是没有发生离屏幕渲染的

有资料显示

iOS 9.0 之前UIimageView跟UIButton设置圆角都会触发离屏渲染。

iOS 9.0 之后UIButton设置圆角会触发离屏渲染,而UIImageView里png图片设置圆角不会触发离屏渲染了,如果设置其他阴影效果之类的还是会触发离屏渲染的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值