文字与图片渐变效果(图层CALayer与属性蒙版mask )
2016-02-25 06:40
627 查看
首先,我们需要稍微理清一下CAGradientLayer、CALayer,UIView和mask的大概关系。
在iOS中,能看得见摸的着的基本都是UIView,如按钮、图片等。UIView之所以能看得见是因为里面有一个图层(即
对UIView的位置大小的操作,实际上就是对图层(即
可以把图层看成是没有事件的UIView,而对应UIView则是这个图层的控制者。所以如果直接在图层上添加(
CAGradientLayer是继承CALayer的,用于画出渐变图层。
图层A有一个属性是mask,mask实际上也是一个图层,该图层设置为图层B。
mask层工作原理是按照透明度裁剪,只保留非透明部分,所以图层B并非覆盖在图层A上,而是根据图层B不透明的部分去显示图层A。
若图层B是个蓝色圆环,而图层A是个红色的长方形,那么最终显示的就是红色的圆环。(
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];
gradientLayer.mask = label.layer;
label.layer.frame = gradientLayer.bounds;
#####################
首先,将gradientLayer添加到self.view.layer层中。然后设置gradientLayer的mask,因为mask本质上也是一个layer图层。裁剪的原理是根据透明度来进行裁剪的。
所以说,当label作为mask图层的时候,不透明显示的只是"你好啊"这三个文字。
同时,裁剪的时候不改变颜色的显示,所以说,”你好啊“显示的就是渐变的颜色。
##########################
原文如下:
先让我们看看,能实现的最终效果:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020281.png)
1450806559781.png
首先,我们需要稍微理清一下CAGradientLayer、CALayer,UIView和mask的大概关系。
在iOS中,能看得见摸的着的基本都是UIView,如按钮、图片等。UIView之所以能看得见是因为里面有一个图层(即
实例一:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020282.png)
1450792777714.png
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020283.png)
1450804026188.png
渐变思路(适合文字渐变和图片不透明部分渐变):UILabel本身的图层其实就是文字,所以我们需要创建一个渐变层到UILabel的父视图图层(即superview的layer对象),然后使用UILabel本身的图层作为渐变层的mask即可。
实例二:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020284.png)
1450804128723.png
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020285.png)
1450804110590.png
渐变思路(适合文字背景渐变和图片透明部分渐变):创建渐变图层添加到图标或文字的父视图图层(既superview的layer),然后把图标或文字的图层addSublayer到渐变层即可。
实例三:
有时候可能还需要制作成这种图片:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020286.png)
1450805634345.png
这时候只需要将UIImageView的宽高设置成相等的,并且在实例二的基础上对渐变层的cornerRadius和masksToBounds处理即可。相信大家对这两个属性都比较熟悉了。
在渐变层做圆角处理,处理成圆:
演示Demo下载:GraduatedColor
在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层中。然后设置gradientLayer的mask,因为mask本质上也是一个layer图层。裁剪的原理是根据透明度来进行裁剪的。
所以说,当label作为mask图层的时候,不透明显示的只是"你好啊"这三个文字。
同时,裁剪的时候不改变颜色的显示,所以说,”你好啊“显示的就是渐变的颜色。
##########################
原文如下:
先让我们看看,能实现的最终效果:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020281.png)
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并不会改变原来图层的颜色)
实例一:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020282.png)
1450792777714.png
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020283.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;
});
实例二:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020284.png)
1450804128723.png
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020285.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; });
实例三:
有时候可能还需要制作成这种图片:
![](http://img0.itdadao.com/tech/2015/12/23/js175884231020286.png)
1450805634345.png
这时候只需要将UIImageView的宽高设置成相等的,并且在实例二的基础上对渐变层的cornerRadius和masksToBounds处理即可。相信大家对这两个属性都比较熟悉了。
在渐变层做圆角处理,处理成圆:
gradientLayer.cornerRadius = imageView.frame.size.width/2; gradientLayer.masksToBounds = YES;
演示Demo下载:GraduatedColor
相关文章推荐
- 单点登录cas常见问题(十一) - 怎么搭建oauth服务器?
- setContentView R can not be resovled
- leetcode@ [30/76] Substring with Concatenation of All Words & Minimum Window Substring (Hashtable, Two Pointers)
- 处理解决方案中网站名称为副本名称的方法
- Hbase 基本操作
- Android 文件的读写(内置存储卡)
- Connection refused Will not attempt to authenticate using SASL
- table column sum
- DE24 Introduction to First-order Systems of ODEs
- DE23 Use with Impulse Inputs
- DE22 Using Laplace Transform to Solve ODEs with Discontinuous Inputs
- DE21 Convolution Formula
- 搭建 AngularJS+Ionic+Cordova 开发环境并运行一个demo
- 【CSS3】伸缩布局
- foreach 是传入参数是 Set<Long[]>时,数据循环都是同样数据的问题
- eclipse 连接 habse 问题汇总
- [leetcode] 273. Integer to English Words 解题报告
- 文章标题
- 论clone深层复制和浅层复制
- 【CSS3】盒子模型