简介


  • 每个UI控件,默认自动创建一个图层(根图层),即每个UI控件对应于至少一个图层
  • 每一个UIView内部都默认关联着一个CALayer,我们可用称这个Layer为Root Layer(根层)
  •  
    所有的非Root Layer,也就是手动创建的CALayer对象,都存在着隐式动画
     
    什么是隐式动画?
  •  
    当对非Root Layer的部分属性进行修改时,默认会自动产生一些动画效果
     
  • 而这些属性称为Animatable Properties(可动画属性)
  • 常见的可执行隐式动画的属性

    • 位置与尺寸

      • anchorPoint,锚点
      • position,位置
      • bounds, 尺寸
      • frame,位置与尺寸
      • transform,形变
    • appearance

      • backgroundColor,背景色
      • hidden,是否隐藏
      • opacity,透明度
      • maskToBounds,是否剪切超出图层区域的的内容
      • cornerRadius,圆角半径
    • 边框

      • borderWidth,边框宽度
      • borderColor,边框颜色
    • 阴影

      • shadowColor,背景颜色
      • shadowOffset,背景偏移量
      • shadowOpacity,背景透明度
      • shadowPath,背景边框的路径,即背景显示什么形状的图形
      • shadowRaduis,背景的圆角半径

示例


  • 通过storyboard创建一个UIView对象,并拥有该对象

    @property (weak, nonatomic) IBOutlet UIView *blueView;
  • 点击屏幕,动态修改图层的可动画属性

    - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
    {
    //通过随机数产生随机的旋转角度
    CGFloat angle = angleToRadion(arc4random_uniform(360) + 1);
    //旋转
    self.blueView.layer.transform = CATransform3DMakeRotation(angle, 0, 0, 1);
    //移动到随机位置(50~249, 50~449)
    self.blueView.layer.position = CGPointMake(arc4random_uniform(200) + 50, arc4random_uniform(400) + 50);
    //设置随机的圆角半径
    self.blueView.layer.cornerRadius = arc4random_uniform(50);
    //设置随机的背景颜色
    self.blueView.layer.backgroundColor = [self randomColor].CGColor;
    //设置随机的边框宽度
    self.blueView.layer.borderWidth = arc4random_uniform(10);
    //设置随机的边框颜色
    self.blueView.layer.borderColor = [self randomColor].CGColor;
    }
  • 产生随机颜色的方法

    - (UIColor *)randomColor
    {
    return [UIColor colorWithRed:arc4random_uniform(256) / 255.0 green:arc4random_uniform(256) / 255.0 blue:arc4random_uniform(256) / 255.0 alpha:1];
    }
  • 实现效果

 
 

OC - 22.隐式动画的更多相关文章

  1. 非RootLayer的隐式动画

    非RootLayer都有隐式动画,默认0.25秒. // 1.开启 [CATransaction begin]; // 2.设置关闭 YES-关闭:NO-开启 [CATransaction setDi ...

  2. 利用UICollectionViewFlowLayout的隐式动画实现UICollectionView的layout的动画调整(外加放大指定cell效果)

    前几天在gitHub看到个不错的效果,就是DaiExpandCollectionView,效果如图:   所以赶紧下下来源码看看他怎么实现的,打开源码看了半天,发现他没写什么关于动画的代码啊... 经 ...

  3. IOS第18天(3,CALayer隐式动画)

    ******隐式动画(手指拖拽Layer) #import "HMViewController.h" @interface HMViewController () @propert ...

  4. iOS:CALayer的隐式动画的详解

    CALayer的隐式动画属性: •每一个UIView内部都默认关联着一个CALayer,称这个Layer为Root Layer.所有的非Root Layer都存在着隐式动画,隐式动画的默认时长为1/4 ...

  5. iOS中的隐式动画

    隐式动画就是指  在 非 人为在代码中 定义动画  而系统却默认  自带   的动画  叫做隐式动画. 比如  改变 图层  的颜色  位置  和   透明度  的时候    都会  产生附带的渐变的 ...

  6. CALayer的隐式动画和显式动画

    隐式事务 任何对于CALayer属性的修改,都是隐式事务,都会有动画效果.这样的事务会在run-loop中被提交. - (void)viewDidLoad { //初始化一个layer,添加到主视图 ...

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

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

  8. iOS动画学习 -隐式动画

    事务 Core Animation基于一个假设,说屏幕上的任何东西都可以(或者可能)做动画.你并不需要在Core Animation中手动打开动画,但是你需要明确地关闭它,否则它会一直存在. 当你改变 ...

  9. iOS边练边学--CALayer,非根层隐式动画,钟表练习

    一.CALayer UIView之所以能显示在屏幕上,完全是因为他内部的一个图层 在创建UIView对象时,UIView内部会自动创建一个图层(即CALayer对象),通过UIView的layer属性 ...

随机推荐

  1. android实现json数据的解析和把数据转换成json格式的字符串

    利用android sdk里面的 JSONObject和JSONArray把集合或者普通数据,转换成json格式的字符串 JSONObject和JSONArray解析json格式的字符串为集合或者一般 ...

  2. Robotium solo.goBack();不起作用,解决方案

    今天碰到用solo.goBack();点击手机的返回按键五次有四次起总用.查了半天后发现以下一种替代方法: solo.sendKey(KeyEvent.KEYCODE_BACK); robotium下 ...

  3. ubuntu 安装配置JDK

    总的原则:将压缩包解压至/usr/lib/jdk,设置jdk环境变量并将其修改为系统默认的jdk 1.将jdk-7u5-linux-x64.tar.gz拷贝到/usr/lib/jdk/目录下面,这里如 ...

  4. 新型Web劫持技术

    该类新型Web劫持是利用script脚本实现的.在已知的案例中,黑客入侵了某地方门户网站,篡改了该网站的新闻页面,并向这些页面植入自己的广告.新闻及恶意代码.一旦用户从搜索结果页面点击进入被篡改过的新 ...

  5. Mac下搭建Eclipse Android开发环境

    之前一直是用windows搞android开发,但windows这个性能也真是让人醉了,终于一狠心,砸锅卖铁买了Mac.然后就开始在Mac上搭建android开发环境, 其实也不麻烦,关键是找准下载地 ...

  6. vijosP1014 旅行商简化版

    vijosP1014 旅行商简化版 链接:https://vijos.org/p/1014 [思路] 双线DP. 设ab,ab同时走.用d[i][j]表示ab所处结点i.j,且定义i>j,则有转 ...

  7. 在MacOSX下使用Github管理Xcode代码

    版本控制应该算是每个程序员所必备的技能,这个重要性,我就不多说了哈.现在版本控制基本上就是两种途径:SVN和Git.对于SVN我并不是非常了解,只知道在Windows下非常实用,但是在MacOSX下, ...

  8. JavaScript高级程序设计16.pdf

    第8章 BOM BOM的核心对象就是window,它表示浏览器的一个实例,在浏览器中window对象有双重角色,它既是JavaScript访问浏览器的一个接口,又是规定的Global对象,因此所有在全 ...

  9. Eclipse Maven Project

    http://www.cnblogs.com/candle806/p/3439469.html

  10. iScroll使用

    新公司比较喜欢用iScroll,而我对此一无所知,特此调研iScroll用法,写在这里方便查看 IScroll是移动页面上被使用的一款仿系统滚动插件. myScroll = new IScroll(& ...