文字与图片渐变效果(图层CALayer与属性蒙版mask )
来源:互联网 发布:java http文件上传下载 编辑:程序博客网 时间:2024/06/06 01:45
首先,我们需要稍微理清一下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 = [[UILabelalloc]initWithFrame:CGRectMake(64, startY,200, 15)];
label.text =@"你好啊";
[self.viewaddSubview:label];
//设置渐变层,实际上有这个渐变层就可以显示了。
CAGradientLayer *gradientLayer = [CAGradientLayerlayer];
gradientLayer.frame = label.frame;
UIColor *beforeColor = [UIColorblueColor];
UIColor *afterColor = [UIColorredColor];
// 设置渐变层的颜色
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图层的时候,不透明显示的只是"你好啊"这三个文字。
同时,裁剪的时候不改变颜色的显示,所以说,”你好啊“显示的就是渐变的颜色。
##########################
原文如下:先让我们看看,能实现的最终效果:
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即可。
实例二:
1450804128723.png
1450804110590.png
渐变思路(适合文字背景渐变和图片透明部分渐变):创建渐变图层添加到图标或文字的父视图图层(既superview的layer),然后把图标或文字的图层addSublayer到渐变层即可。
实例三:
有时候可能还需要制作成这种图片:
1450805634345.png
这时候只需要将UIImageView的宽高设置成相等的,并且在实例二的基础上对渐变层的cornerRadius和masksToBounds处理即可。相信大家对这两个属性都比较熟悉了。
在渐变层做圆角处理,处理成圆:
演示Demo下载:GraduatedColor
- 文字与图片渐变效果(图层CALayer与属性蒙版mask )
- 文字渐变效果:图层中的mask属性
- 文字渐变效果:图层中的mask属性
- 文字渐变效果:图层中的mask属性
- CALayer mask属性实现蒙板效果
- 图片折叠效果:Layer的contentsRect属性和渐变层
- iOS CALayer mask 属性
- 使用CALayer的mask属性来设置图片圆角
- CATextLayer与CAGradientLayer实现文字渐变的动画效果
- CALayer的mask属性简介
- CALayer的mask属性简介
- Core Animation实例-图片折叠效果(CAGradientLayer渐变层)
- 文字与图片互相切换js效果
- 图层(CALayer)
- CALayer之CAGranientLayer渐变效果
- iOS效果 :(1) CALayer 图层阴影,边框,圆角,圆型图片的阴影
- CALayer的anchorPoint属性与transform属性
- CALayer -- 层的属性
- 欢迎使用CSDN-markdown编辑器
- 配置SSH证书登录验证
- 时间管理的思考
- Print Numbers by Recursion
- [译]使用注解处理器生成代码-2 注解处理器
- 文字与图片渐变效果(图层CALayer与属性蒙版mask )
- android简单实例--------普通菜单optionMenu,上下文菜单ContextMenu,弹出式菜单的使用PopuMenu(一)
- Sqrt(x)
- web小游戏 2048制作(一):网页布局
- 《Java JDK8学习笔记》读书笔记(3)
- Java程序员应该掌握哪些东西?
- JS一定要放在Body的最底部么?聊聊浏览器的渲染机制
- hadoop无法打印日志
- Java实现配置加载机制