IOS Animation-CABasicAnimation例子(简单动画实现)
这些例子都是CABasicAnimation的一些简单实现的动画,例如移动、透明度、翻转等等。方法里面传入一个CALayer类或者子类就可以了。
下面是用swift实现的,这些方法我们也可以用作公共类来调用:
//移动动画position
func addLayerAnimationPosition(layer: CALayer) {
let animation = CABasicAnimation(keyPath: "position")
//开始的位置
animation.fromValue = NSValue(CGPoint: layer.position)
//移动到的位置
animation.toValue = NSValue(CGPoint: CGPointMake(, ))
//持续时间
animation.duration =
//运动后的位置保持不变(layer的最后位置是toValue)
animation.removedOnCompletion = false
animation.fillMode = kCAFillModeForwards //添加动画
layer.addAnimation(animation, forKey: "addLayerAnimationPosition")
} //透明度 opacity
func addLayerAnimationOpacity(layer: CALayer) {
let animation = CABasicAnimation(keyPath: "opacity")
animation.fromValue =
animation.toValue =
animation.duration = layer.addAnimation(animation, forKey: "addLayerAnimationOpacity") } //变大与位置 bounds
func addLayerAnimationBounds(layer:CALayer) {
let animation = CABasicAnimation(keyPath: "bounds")
animation.toValue = NSValue(CGRect:CGRectMake(, , , ))
animation.duration =
animation.repeatCount = layer.addAnimation(animation, forKey: "addLayerAnimationBounds")
} //由小变大 bounds.size
func addLayerAnimationBoundsSize(layer:CALayer) {
let animation = CABasicAnimation(keyPath: "bounds.size")
animation.fromValue = NSValue(CGSize: layer.bounds.size)
animation.toValue = NSValue(CGSize:CGSizeMake(layer.bounds.size.width+, layer.bounds.size.height+))
animation.duration =
animation.repeatCount = layer.addAnimation(animation, forKey: "addLayerAnimationBoundsSize")
} //改变颜色 backgroundColor
func addLayerAnimationBackgroundColor(layer:CALayer) {
let animation = CABasicAnimation(keyPath: "backgroundColor")
animation.toValue = UIColor.blueColor().CGColor
animation.duration =
animation.repeatCount = layer.addAnimation(animation, forKey: "addLayerAnimationMargin")
} //渐变圆角 cornerRadius
func addLayerAnimationCornerRadius(layer:CALayer) {
let animation = CABasicAnimation(keyPath: "cornerRadius")
animation.toValue =
animation.duration =
animation.repeatCount = layer.addAnimation(animation, forKey: "addLayerAnimationCornerRadius")
} //改变边框border的大小(图形周围边框,border默认为黑色), borderWidth
func addLayerAnimationBorderWidth(layer:CALayer) {
let animation = CABasicAnimation(keyPath: "borderWidth")
animation.toValue =
animation.duration =
animation.repeatCount = layer.addAnimation(animation, forKey: "addLayerAnimationBorderWidth")
} //改变layer内容(图片),注意如果想要达到改变内容的动画效果,首先在运行动画之前定义好layer的contents contents
func addLayerAnimationContents(layer:CALayer) {
let animation = CABasicAnimation(keyPath: "contents")
let toImage = UIImage.init(named: "通车辆设计矢量素材-06.png")?.CGImage
animation.toValue = toImage
animation.duration =
animation.repeatCount = layer.addAnimation(animation, forKey: "addLayerAnimationBounds")
} //缩放、放大 transform.scale
func addLayerAnimationTransformScale(layer:CALayer) {
let animation = CABasicAnimation(keyPath: "transform.scale")
//开始时的倍率
animation.fromValue = 1.0
//结束时的倍率
animation.toValue = 0.5
animation.duration =
animation.repeatCount =
animation.autoreverses = true layer.addAnimation(animation, forKey: "addLayerAnimationScale")
} //旋转动画(翻转,沿着X轴) transform.rotation.x
func addLayerAnimationTranformRotationX(layer: CALayer) {
let animation = CABasicAnimation(keyPath: "transform.rotation.x")
//旋转180度 = PI
animation.toValue = M_PI
animation.duration =
animation.repeatCount =
//这里我们可以添加可以不添加,添加一个缓慢进出的动画效果(int/out)。当不添加时,匀速运动,会使用kCAMediaTimingFunctionLinear;当添加时,layer会在开始和结束时比较缓慢
animation.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut) layer.addAnimation(animation, forKey: "addLayerAnimationTranformRotationX")
} //旋转动画(翻转,沿着Y轴) transform.rotation.y
func addLayerAnimationTranformRotationY(layer: CALayer) {
let animation = CABasicAnimation(keyPath: "transform.rotation.y")
//旋转180度 = PI
animation.toValue = M_PI
animation.duration =
animation.repeatCount =
//这里我们可以添加可以不添加,添加一个缓慢进出的动画效果(int/out)。当不添加时,匀速运动,会使用kCAMediaTimingFunctionLinear;当添加时,layer会在开始和结束时比较缓慢
animation.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut) layer.addAnimation(animation, forKey: "addLayerAnimationTranformRotationY")
} //旋转动画(沿着Z轴) transform.rotation.z
func addLayerAnimationTranformRotationZ(layer: CALayer) {
let animation = CABasicAnimation(keyPath: "transform.rotation.z")
//旋转360度 = PI*2
animation.toValue = M_PI*
animation.duration =
animation.repeatCount =
//这里我们可以添加可以不添加,添加一个缓慢进出的动画效果(int/out)。当不添加时,匀速运动,会使用kCAMediaTimingFunctionLinear;当添加时,layer会在开始和结束时比较缓慢
animation.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut) layer.addAnimation(animation, forKey: "addLayerAnimationTranformRotationZ")
} //横向移动(沿着X轴) transform.translation.x
func addLayerAnimationTranformTranslationX(layer: CALayer) {
let animation = CABasicAnimation(keyPath: "transform.translation.x")
animation.toValue =
animation.duration =
animation.repeatCount =
//这里我们可以添加可以不添加,添加一个缓慢进出的动画效果(int/out)。当不添加时,匀速运动,会使用kCAMediaTimingFunctionLinear;当添加时,layer会在开始和结束时比较缓慢
animation.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut) layer.addAnimation(animation, forKey: "addLayerAnimationTranformTranslationX")
} //纵向移动(沿着Y轴) transform.translation.y
func addLayerAnimationTranformTranslationY(layer: CALayer) {
let animation = CABasicAnimation(keyPath: "transform.translation.y")
animation.toValue =
animation.duration =
animation.repeatCount =
//这里我们可以添加可以不添加,添加一个缓慢进出的动画效果(int/out)。当不添加时,匀速运动,会使用kCAMediaTimingFunctionLinear;当添加时,layer会在开始和结束时比较缓慢
animation.timingFunction = CAMediaTimingFunction(name: kCAMediaTimingFunctionEaseInEaseOut) layer.addAnimation(animation, forKey: "addLayerAnimationTranformTranslationY")
}
如果我们只要看keypath的值,我们可以看到下面文章
http://www.cnblogs.com/alunchen/p/5300075.html
可以关注本人的公众号,多年经验的原创文章共享给大家。

IOS Animation-CABasicAnimation例子(简单动画实现)的更多相关文章
- [iOS Animation]-CALayer 隐式动画
隐式动画 按照我的意思去做,而不是我说的. -- 埃德娜,辛普森 我们在第一部分讨论了Core Animation除了动画之外可以做到的任何事情.但是动画是Core Animation库一个非常显著的 ...
- iOS Animation 主流炫酷动画框架(特效)收集整理 #91
https://github.com/sxyx2008/DevArticles/issues/91
- ios之CABasicAnimation
博主:最近iOS开发中用到CoreAnimation的framework来做动画效果,虽然以前也用过,但一直没有系统学习过,今天看到一篇非常详细的博文(虽然是日语,但真的写的很好),在此翻译出来供大家 ...
- [iOS Animation]-CALayer 显示动画
显式动画 如果想让事情变得顺利,只有靠自己 -- 夏尔·纪尧姆 上一章介绍了隐式动画的概念.隐式动画是在iOS平台创建动态用户界面的一种直接方式,也是UIKit动画机制的基础,不过它并不能涵盖所有的动 ...
- Swift 实现iOS Animation动画教程
这是一篇翻译文章.原文出处:http://www.raywenderlich.com/95910/uiview-animation-swift-tutorial 动画( animation)是iOS用 ...
- iOS CAReplicatorLayer 简单动画
代码地址如下:http://www.demodashi.com/demo/11601.html 写在最前面,最近在看学习的时候,偶然间发现一个没有用过的Layer,于是抽空研究了下,本来应该能提前记录 ...
- iOS开发CABasicAnimation动画理解
1.CALayer简介 CALayer是个与UIView很类似的概念,同样有backgroundColor.frame等相似的属性,我们可以将UIView看做一种特殊的CALayer.但实际上UIVi ...
- iOS Core Animation学习总结(3)--动画的基本类型
一. CABasicAnimation (基础动画) 移位: CABasicAnimation *animation = [CABasicAnimation animation]; //keyPath ...
- ios animation 动画效果实现
1.过渡动画 CATransition CATransition *animation = [CATransition animation]; [animation setDuration:1.0]; ...
随机推荐
- 模拟n个人参加选举的过程,并输出选举结果:假设候选人有四人,分别用A,B,C,D表示,当选某候选人时,直接输入其编号(编号由计算机随机产生,若输入的不是A,B,C,D则视为无效票,选举结束后按得票数从高到底输出候选人编号和所得票数.
模拟n个人参加选举的过程,并输出选举结果:假设候选人有四人,分别用A,B,C,D表示,当选某候选人时,直接输入其编号(编号由计算机随机产生,若输入的不是A,B,C,D则视为无效票,选举结束后按得票数从 ...
- C# 基础(7)--线程
进程与线程 一个程序就是一个进程,进程包含线程,多个线程之间可以“并发”执行(确切的说是不停地切换),CPU是跟线程打交道的. 线程是程序的一个执行流,每个线程都有之间专有的寄存器(栈指针.程序计数器 ...
- 使用nginx为ArcGIS Server做反向代理
1.下载nginx软件:官网地址http://nginx.org/ 2.修改conf文件夹下nginx.conf配置信息, 配置文件中以下内容: server { listen 80; s ...
- Java打jar包详细教学
如果我们需要将写好并测试OK的公共接口供多个项目使用,我们可以不用拷贝源代码,可以编译后打包成jar文件,这样会很方便许多,修改的话也方便,直接修改源代码打一个新jar包替换即可,下面是打包的详细教程 ...
- 【jquery】flexiGrid新增功能的方式
到目前为止,我用过的jquery表格插件只有jqGrid和flexiGrid.今天,只说后者. 关于参数配置,使用方法,博客园文章很多. 原生的flexiGrid架包不大,内容可以扩展,比如在每行数据 ...
- 用SYS_CONNECT_BY_PATH进行层级查询时的排序问题
用SYS_CONNECT_BY_PATH进行层级查询时, 对同一级别的节点进行排序,可以加order SIBLINGS by 子句实现 WITH N2 AS( SELECT n.ID, org.&qu ...
- Debian系统vim中文显示乱码问题
网上查的一堆东西好像都不灵,试了半天! 先安装中文字体:sudo aptitude install fonts-arphic-uming fonts-wqy-zenhei 然后:sudo locale ...
- 浅谈城市规划在移动GIS方面的应用发展
1.概述 城市建设进程加快,城市规划管理工作日趋繁重,各种来源的数据产生各种层出不穷的问题,严重影响城市规划时的准确性,为此全面合理的掌握好各方面的城市规划资料才能做出更加科学的决策.移动端的兴起为规 ...
- (转)为什么用ls和du显示出来的文件大小有差别?
曾经有几次,我用ls和du查看一个文件的大小,发现二者显示出来的大小并不一致,例如: bl@d3:~/test/sparse_file$ ls -l fs.img-rw-r--r-- 1 bl bl ...
- 分析Linux内核创建一个新进程的过程
一.原理分析 1.进程的描述 进程控制块PCB——task_struct,为了管理进程,内核必须对每个进程进行清晰的描述,进程描述符提供了内核所需了解的进程信息. struct task_struct ...