技术点:
maskView(maskLayer)基本原理
maskView配合CAGradientLayer的使用
maskView配合带alpha通道图片的使用
设计文本横向渐变消失的控件
maskView(maskLayer)基本原理:
png图片透明像素的原理
maskView(maskLayer)可类比多张png图片的叠加遮罩,原理类似
maskView是iOS8以上才有的方法,如果考虑版本的兼容问题,可以考虑用maskLayer替换
下面我们来编写代码:
1:导入图片
data:image/s3,"s3://crabby-images/18db4/18db4c7a1b1526e1ff0eb575980901e1b34c6c1e" alt=""
带有透明效果的图片:
data:image/s3,"s3://crabby-images/00324/003241fc88e25cc2abeb3f0438519cdd5d9d833c" alt=""
jpg图片是没有这种效果的
下面我们来写代码
1:加载图片
data:image/s3,"s3://crabby-images/8a3e4/8a3e4cd9fdd85b4cd72dac192cd4974078083d16" alt=""
我们把模拟器调成一直呆在最前面,如上图所示。
2:显示第二张图片
data:image/s3,"s3://crabby-images/1b139/1b139eeca14dc5d5f1a913f96b0eb12455b73dbc" alt=""
下面我们来写两张图片叠加的效果
data:image/s3,"s3://crabby-images/91640/9164000e2d8d4631ef87cf7e8a0b0e5a06e50615" alt=""
之所以会产生这种效果,是因为我们利用了png图片透明的特性。
注意:maskView并不能用addSubView来添加
maskView 配合 CAGradientLayer 的使用
1:用CAGradientLayer直接产生带透明像素的layer,这一点和透明像素的图片相似,只不过我们这次用的是代码产生的layer来代替图片
2:用maskView直接加载带CAGradientLayer的View,也就是说我们可以直接把CAGradientLayer直接当Mask来使用
3:可是通过对CAGradientLayer进行动画的操作来实现动画效果
下面我们创建工程来实现
1:导入底图 这次不需要其他图片
2:创建CAGradientLayer
设定值:
data:image/s3,"s3://crabby-images/7eb03/7eb0364da4907288f099f7e3e2f8a31e3b4980fd" alt=""
3:创建容器View并加到基础图片上
data:image/s3,"s3://crabby-images/ac46c/ac46c8b5e5a6dc5076244265b6b7c58321bec072" alt=""
4:添加动画效果(开始值、结束值)
data:image/s3,"s3://crabby-images/faeb8/faeb88573e73854211b75813d71255679ade7ab1" alt=""
运行效果:
data:image/s3,"s3://crabby-images/a66db/a66db7818f508fb4de39d4cd309ec2f6f660d112" alt=""
data:image/s3,"s3://crabby-images/81e83/81e834929665edf013fb67cbeb0060451ee6ccae" alt=""
maskView 配合带 alpha 通道图片的使用
1:直接使用带Alpha通道的图片比使用CAGradientLayer的方式更加高效
2:可以使用一些技巧在maskView上添加多张图片
3:可以在maskView中做简单的动画
代码:
1:添加两张图片,第一张覆盖第二张
data:image/s3,"s3://crabby-images/65a78/65a788f3b21f91ef79f1952f5abe8df1dc583e08" alt=""
2:创建maskView作为容器
data:image/s3,"s3://crabby-images/0ea02/0ea028a9ec25a71439f7f2b023584b9c85aae377" alt=""
3:添加两张带有alpha通道的图片到MaskView上面
第一张的下半部分透明,第二张的上半部分透明
data:image/s3,"s3://crabby-images/70e45/70e45a4ef0b070eb5ef0b9fb01486630c85f59af" alt=""
data:image/s3,"s3://crabby-images/2bae8/2bae8b02c326219efb5aa6f3803c9cb4c317167e" alt=""
data:image/s3,"s3://crabby-images/0658e/0658e9ff96ff91558e1ae50e0b68c52e4f2b1841" alt=""
4:添加动画效果
data:image/s3,"s3://crabby-images/365fd/365fda6dcafe407e73440c85052e634a8e40aeb1" alt=""
运行效果:
data:image/s3,"s3://crabby-images/4dc75/4dc7596a62092d4e5b7ef6083e47d057df4253ad" alt=""
data:image/s3,"s3://crabby-images/5e431/5e431f6b3eba927f32e6049729fe48bf664085bd" alt=""
设计文本横向渐变消失的控件
1:接口设计
2:封装CAGradientLayer用以提供mask遮罩
3:动画样式的分析与设计
1:封装控件
.h 给定文本属性 给定渐变方法
data:image/s3,"s3://crabby-images/612e8/612e85de4ef0705f3e31903aecbb2c1c26e8193e" alt=""
声明label、mask属性并创建
data:image/s3,"s3://crabby-images/23cc2/23cc2ea39c69cb045b5f24342070b7cc4ea68080" alt=""
data:image/s3,"s3://crabby-images/93d23/93d23a48fba6a88207b5fe80fed6f93df1f08375" alt=""
data:image/s3,"s3://crabby-images/286ad/286ad397dc34243443bf7424d74de7d1c51a5df1" alt=""
给text赋值
data:image/s3,"s3://crabby-images/2d102/2d1029e53f0104d9e3a86d02ed1f3a8926aded08" alt=""
实现留给外界的动画方法
data:image/s3,"s3://crabby-images/557c7/557c7c32061160c8bccc0c67f6d2ae81f30d27f5" alt=""
主控制器初始化并调用:
data:image/s3,"s3://crabby-images/85591/855915fa893e3d3ab22813cc6834c6eaea8afa4a" alt=""
运行效果:
data:image/s3,"s3://crabby-images/11813/11813961e034076e8d8fa910a73a6bcd3e56ad0d" alt=""
data:image/s3,"s3://crabby-images/d405d/d405ddbb9d85fe2fed900dc380e2dd646fb23c77" alt=""
总结:
maskView(maskLayer)的基本原理
maskView配个CAGradientLayer的使用(创建渐变的图层)
maskView配合alpha通道图片的使用
设计文本横向渐变消失的控件
网友评论