这些例子都是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例子(简单动画实现)的更多相关文章

  1. [iOS Animation]-CALayer 隐式动画

    隐式动画 按照我的意思去做,而不是我说的. -- 埃德娜,辛普森 我们在第一部分讨论了Core Animation除了动画之外可以做到的任何事情.但是动画是Core Animation库一个非常显著的 ...

  2. iOS Animation 主流炫酷动画框架(特效)收集整理 #91

    https://github.com/sxyx2008/DevArticles/issues/91

  3. ios之CABasicAnimation

    博主:最近iOS开发中用到CoreAnimation的framework来做动画效果,虽然以前也用过,但一直没有系统学习过,今天看到一篇非常详细的博文(虽然是日语,但真的写的很好),在此翻译出来供大家 ...

  4. [iOS Animation]-CALayer 显示动画

    显式动画 如果想让事情变得顺利,只有靠自己 -- 夏尔·纪尧姆 上一章介绍了隐式动画的概念.隐式动画是在iOS平台创建动态用户界面的一种直接方式,也是UIKit动画机制的基础,不过它并不能涵盖所有的动 ...

  5. Swift 实现iOS Animation动画教程

    这是一篇翻译文章.原文出处:http://www.raywenderlich.com/95910/uiview-animation-swift-tutorial 动画( animation)是iOS用 ...

  6. iOS CAReplicatorLayer 简单动画

    代码地址如下:http://www.demodashi.com/demo/11601.html 写在最前面,最近在看学习的时候,偶然间发现一个没有用过的Layer,于是抽空研究了下,本来应该能提前记录 ...

  7. iOS开发CABasicAnimation动画理解

    1.CALayer简介 CALayer是个与UIView很类似的概念,同样有backgroundColor.frame等相似的属性,我们可以将UIView看做一种特殊的CALayer.但实际上UIVi ...

  8. iOS Core Animation学习总结(3)--动画的基本类型

    一. CABasicAnimation (基础动画) 移位: CABasicAnimation *animation = [CABasicAnimation animation]; //keyPath ...

  9. ios animation 动画效果实现

    1.过渡动画 CATransition CATransition *animation = [CATransition animation]; [animation setDuration:1.0]; ...

随机推荐

  1. javascript鸭式辩型法实现接口

    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  2. viewpage滑动查看图片并再有缩略图预览

    首先看下效果图, 主要功能分为3大块 一是滑动查看,通过viewpage来实现,方法见 http://www.cnblogs.com/lovemo1314/p/6109312.html 二.点击放大 ...

  3. npm下载速度太慢

    因为墙的原因导致下载速度过慢,解决方式就是使用国内镜像 使用淘宝的镜像 npm config set registry="http://registry.npm.taobao.org/&qu ...

  4. SVN修改用户名与密码

    由于在svn的界面中并没有为我们提供直接更换用户名密码的地方,所以一旦我们需要更换用户名的就需要自己想一些办法. 解决方案如下: 在Eclipse使用SVN的过程中大多数人往往习惯把访问SVN的用户名 ...

  5. Android中处理OnClick和OnTouch方法冲突的解决方案

    目前想到的最好的解决方法,大家有更好的欢迎告知. 问题:在一个view中有一个按钮,要求可以通过点按移动这个按钮,同时单纯的点击而不移动这个按钮的话可以跳转到新的Activity. 遇到的困难:按钮的 ...

  6. ServiceMix in daemon mode

    For development simplicity, we can start Karaf in daemon mode by executing 'bin\admin.bat start root ...

  7. webapi版本升级管理

    由于近期公司人员流动,本人临时客串webapi开发,针对开发过程中碰到一些问题做一些改进 1.当前做法 项目webapi项目是居于asp.net框架开发的,每个功能模块新建一个api控制器,比如Use ...

  8. ElasticSearch学习笔记-02集群相关操作_cat参数

    _cat参数允许你查看集群的一些相关信息,如集群是否健康,有哪些节点,以及索引的情况等的. 检测集群是否健康 curl localhost:9200/_cat/health?v 说明: curl 是一 ...

  9. iOS进阶_动画的多种实现方式

    一.UIView动画 //UIView动画有开始beginAnimation,有结束commitAnimation    //第一步:开始UIView动画    [UIView beginAnimat ...

  10. 修改Eclipse的 workspace目录

    1.进入 Window > Preferences > General > Startup and Shutdown 选中 Prompt for workspace on start ...