文字与图片渐变效果(图层CALayer与属性蒙版mask )

首先,我们需要稍微理清一下CAGradientLayer、CALayer,UIView和mask的大概关系。

在iOS中,能看得见摸的着的基本都是UIView,如按钮、图片等。UIView之所以能看得见是因为里面有一个图层(即CALayer对象

对UIView的位置大小的操作,实际上就是对图层(即CALayer对象)的操作。

可以把图层看成是没有事件的UIView,而对应UIView则是这个图层的控制者。所以如果直接在图层上添加(addSublayer)图层,就会直接覆盖在上面。

CAGradientLayer是继承CALayer的,用于画出渐变图层。


图层A有一个属性是mask,mask实际上也是一个图层,该图层设置为图层B。

mask层工作原理是按照透明度裁剪,只保留非透明部分,所以图层B并非覆盖在图层A上,而是根据图层B不透明的部分去显示图层A


若图层B是个蓝色圆环,而图层A是个红色的长方形,那么最终显示的就是红色的圆环。(所以说设置蒙版mask并不会改变原来图层的颜色


   CGFloat startY = 64;

    UILabel *label = [[UILabel alloc]initWithFrame:CGRectMake(64, startY, 200, 15)];

    label.text = @"你好啊";

    [self.view addSubview:label];

    

    //设置渐变层,实际上有这个渐变层就可以显示了。

    CAGradientLayer *gradientLayer = [CAGradientLayer layer];

    gradientLayer.frame = label.frame;

    UIColor *beforeColor = [UIColor blueColor];

    UIColor *afterColor = [UIColor redColor];

    // 设置渐变层的颜色

    gradientLayer.colors = @[(id)beforeColor.CGColor,(id)afterColor.CGColor];

// 疑问:渐变层能不能加在label上
// 不能,如果添加渐变层到label图层上,则会遮盖label的文字图层;如果作为label图层的mask,由于mask是完全不透明渐变层,所以是正常显示,这种情况如果消失了,说明mask的frame.origin没有设置正确。
        
// 添加渐变层到控制器的view图层上
[self.view.layer addSublayer:gradientLayer];

    gradientLayer.mask = label.layer;

    label.layer.frame = gradientLayer.bounds;

    

#####################

    

    首先,将gradientLayer添加到self.view.layer层中。然后设置gradientLayermask,因为mask本质上也是一个layer图层。裁剪的原理是根据透明度来进行裁剪的。

    

    所以说,当label作为mask图层的时候,不透明显示的只是"你好啊"这三个文字。

    同时,裁剪的时候不改变颜色的显示,所以说,你好啊显示的就是渐变的颜色。

##########################

原文如下:


先让我们看看,能实现的最终效果:


1450806559781.png

首先,我们需要稍微理清一下CAGradientLayer、CALayer,UIView和mask的大概关系。
在iOS中,能看得见摸的着的基本都是UIView,如按钮、图片等。UIView之所以能看得见是因为里面有一个图层(即CALayer对象)对UIView的位置大小的操作,实际上就是对图层(即CALayer对象)的操作。可以把图层看成是没有事件的UIView,而对应UIView则是这个图层的控制者。所以如果直接在图层上添加(addSublayer)图层,就会直接覆盖在上面。CAGradientLayer是继承CALayer的,用于画出渐变图层。图层A有一个属性是mask,mask实际上也是一个图层,该图层设置为图层B。mask层工作原理是按照透明度裁剪,只保留非透明部分,所以图层B并非覆盖在图层A上,而是根据图层B不透明的部分去显示图层A。若图层B是个蓝色圆环,而图层A是个红色的长方形,那么最终显示的就是红色的圆环。(所以说设置蒙版mask并不会改变原来图层的颜色

实例一:


1450792777714.png


1450804026188.png

渐变思路(适合文字渐变和图片不透明部分渐变):UILabel本身的图层其实就是文字,所以我们需要创建一个渐变层到UILabel的父视图图层(即superview的layer对象),然后使用UILabel本身的图层作为渐变层的mask即可。

    UILabel *label4 = ({
        UILabel *label = [[UILabel alloc]initWithFrame:CGRectMake(64, 300, 200, 15)];
        label.text = @"你好啊";
        [self.view addSubview:label];
        //设置渐变层,实际上有这个渐变层就可以显示了。
        CAGradientLayer *gradientLayer = [CAGradientLayer layer];
        gradientLayer.frame = label.frame;
        // 设置渐变层的颜色
        gradientLayer.colors = @[(id)beforeColor.CGColor,(id)afterColor.CGColor];
        //水平渐变添加下面两行即可
        //    gradientLayer.startPoint = CGPointMake(0, .5);
        //    gradientLayer.endPoint = CGPointMake(1, .5);
        // 疑问:渐变层能不能加在label上
        // 不能,如果添加渐变层到label图层上,则会遮盖label的文字图层;如果作为label图层的mask,由于mask是完全不透明渐变层,所以是正常显示,这种情况如果消失了,说明mask的frame.origin没有设置正确。
        // 添加渐变层到控制器的view图层上
        [self.view.layer addSublayer:gradientLayer];
        gradientLayer.mask = label.layer;
        //由于label.layer从self.view.layer中移动到渐变层gradientLayer中作为蒙版,所以坐标改变了需要重新调整。
        label.layer.frame = gradientLayer.bounds;
        label;
    });
实例二:


1450804128723.png


1450804110590.png

渐变思路(适合文字背景渐变和图片透明部分渐变):创建渐变图层添加到图标或文字的父视图图层(既superview的layer),然后把图标或文字的图层addSublayer到渐变层即可。

    UIImageView *imageView5 = ({
        UIImageView *imageView = [[UIImageView alloc]initWithFrame:CGRectMake(64, 400, 200, 30)];
        imageView.contentMode = UIViewContentModeScaleAspectFit;
        imageView.image = [UIImage imageNamed:@"abc.png"];
        startY +=35;
        [self.view addSubview:imageView];
        CAGradientLayer *gradientLayer = [CAGradientLayer layer];
        gradientLayer.frame = imageView.frame;
        gradientLayer.colors = @[(id)beforeColor.CGColor,(id)afterColor.CGColor];
        //添加渐变层到view图层上
        [self.view.layer addSublayer:gradientLayer];
        //将原来的图标图层或者文字图层添加到渐变层上
        [gradientLayer addSublayer:imageView.layer];
        //由于imageView.layer从self.view.layer中移动到渐变层gradientLayer中,所以坐标改变了需要重新调整。
        imageView.layer.frame = imageView.layer.bounds;
        imageView;
    });
实例三:

有时候可能还需要制作成这种图片:


1450805634345.png

这时候只需要将UIImageView的宽高设置成相等的,并且在实例二的基础上对渐变层的cornerRadius和masksToBounds处理即可。相信大家对这两个属性都比较熟悉了。
在渐变层做圆角处理,处理成圆:

        gradientLayer.cornerRadius = imageView.frame.size.width/2;
        gradientLayer.masksToBounds = YES;

演示Demo下载:GraduatedColor





  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值