CATransform3D
2016-04-01 15:59
776 查看
iOS开发CoreAnimation解读——CATransform3D变换的应用
一、引言
CATransform3D定义了一个变化矩阵,通过对矩阵参数的设置,我们可以改变layer的一些属性,这个属性的改变,可以产生动画的效果。首先,CATransform3D定义了一个4*4的矩阵,如下:?
m11:x轴方向进行缩放
m12:和m21一起决定z轴的旋转
m13:和m31一起决定y轴的旋转
m14:
m21:和m12一起决定z轴的旋转
m22:y轴方向进行缩放
m23:和m32一起决定x轴的旋转
m24:
m31:和m13一起决定y轴的旋转
m32:和m23一起决定x轴的旋转
m33:z轴方向进行缩放
m34:透视效果m34= -1/D,D越小,透视效果越明显,必须在有旋转效果的前提下,才会看到透视效果
m41:x轴方向进行平移
m42:y轴方向进行平移
m43:z轴方向进行平移
m44:初始为1
二、CATransform3D中的属性和方法
?
1、平移变换
??
2、缩放变换
??
3、旋转变换
??
另外,当我们有垂直于z轴的旋转分量时,设置m34的值可以增加透视效果,也可以理解为景深效果,例如:
?
4、旋转翻转变换
??
5、CATransform3D与CGAffineTransform的转换
CGAffineTransform是UIKit框架中一个用于变换的矩阵,其作用与CATransform类似,只是其可以直接作用于View,而不用作用于layer,这两个矩阵也可以进行转换,方法如下:?
相关文章推荐
- kvc nil的问题
- 码农注册CSDN博客...成功!
- ExtJs设置文本框隐藏时label不隐藏的解决办法
- 【解题报告】Codeforces Round #301 (Div. 2)
- 白话经典算法系列之二 直接插入排序的三种实现
- AndroidStudio导入项目到VisualSVN Server并忽略(ignore)相关文件详细步骤
- 【转】ORACLE制作表时的“小计”和“合计” (ROLLUP)
- 所有文章都迁移到我自己的博客了:http://blog.neazor.com
- JavaScript —— Date() 函数方法
- jvm(7)-虚拟机类加载机制
- WireShark使用lua接口截获网络数据
- The request sent by the client was syntactically incorrect
- 取消windows下文件的默认打开方式
- West Wind Toolkit
- 基于Node.js的微服务后台
- [编码] 无BOM的UTF8
- 使用 Python 操作 Evernote API
- “分布式机器学习的故事”系列分享
- 随记(八)--图片排版UIViewContentMode
- android小知识理解