iOS开发UI篇—CAlayer层的属性

一、position和anchorPoint

1.简单介绍

CALayer有2个非常重要的属性:position和anchorPoint

@property CGPoint position;

用来设置CALayer在父层中的位置

以父层的左上角为原点(0, 0)

@property CGPoint anchorPoint;

称为“定位点”、“锚点”

决定着CALayer身上的哪个点会在position属性所指的位置

以自己的左上角为原点(0, 0)

它的x、y取值范围都是0~1,默认值为(0.5, 0.5)

2.图示

anchorPoint

它的取值为0~1

红色图层的anchorPoint为(0,0)

红色图层的anchorPoint为(0.5,0.5)

红色图层的anchorPoint为(1,1)

红色图层的anchorPoint为(0.5,0)

position和anchorPoint

添加一个红色图层到绿色图层上,红色图层显示到什么位置,由position属性决定

假设红色图层的position是(100,100)

  到底把红色图层的哪个点移动到(100,100)的坐标位置,锚点。

  红色图层的锚点是(0,0)

红色图层的锚点是(0.5,0.5)

红色图层的锚点是(1,1)

红色图层的锚点是(0.5,0)

3.代码示例

(1)没有设置锚点。默认的锚点位置为(0.5,0.5)

  1. 1 //
  2. 2 // YYViewController.m
  3. 3 // 03-锚点等属性
  4. 4 //
  5. 5 // Created by apple on 14-6-21.
  6. 6 // Copyright (c) 2014年 itcase. All rights reserved.
  7. 7 //
  8. 8
  9. 9 #import "YYViewController.h"
  10. 10
  11. 11 @interface YYViewController ()
  12. 12
  13. 13 @end
  14. 14
  15. 15 @implementation YYViewController
  16. 16
  17. 17 - (void)viewDidLoad
  18. 18 {
  19. 19 [super viewDidLoad];
  20. 20 //创建图层
  21. 21 CALayer *layer=[CALayer layer];
  22. 22 //设置图层的属性
  23. 23 layer.backgroundColor=[UIColor redColor].CGColor;
  24. 24 layer.bounds=CGRectMake(0, 0, 100, 100);
  25. 25 //添加图层
  26. 26 [self.view.layer addSublayer:layer];
  27. 27
  28. 28 }
  29. 29
  30. 30 @end

显示效果:

         

(1)设置锚点位置为(0,0)

  1. 1 - (void)viewDidLoad
  2. 2 {
  3. 3 [super viewDidLoad];
  4. 4 //创建图层
  5. 5 CALayer *layer=[CALayer layer];
  6. 6 //设置图层的属性
  7. 7 layer.backgroundColor=[UIColor redColor].CGColor;
  8. 8 layer.bounds=CGRectMake(0, 0, 100, 100);
  9. 9 //设置锚点为(0,0)
  10. 10 layer.anchorPoint=CGPointZero;
  11. 11 //添加图层
  12. 12 [self.view.layer addSublayer:layer];
  13. 13 }
  14. 14 @end

显示效果:

二、隐式动画

1.简单说明

每一个UIView内部都默认关联着一个CALayer,我们可用称这个Layer为Root Layer(根层)

所有的非Root Layer,也就是手动创建的CALayer对象,都存在着隐式动画

什么是隐式动画?

当对非Root Layer的部分属性进行修改时,默认会自动产生一些动画效果

而这些属性称为Animatable Properties(可动画属性)

列举几个常见的Animatable Properties:

bounds:用于设置CALayer的宽度和高度。修改这个属性会产生缩放动画

backgroundColor:用于设置CALayer的背景色。修改这个属性会产生背景色的渐变动画

position:用于设置CALayer的位置。修改这个属性会产生平移动画

2.代码示例

  1. 1 //
  2. 2 // YYViewController.m
  3. 3 // 04-隐式动画
  4. 4 //
  5. 5 // Created by apple on 14-6-21.
  6. 6 // Copyright (c) 2014年 itcase. All rights reserved.
  7. 7 //
  8. 8
  9. 9 #import "YYViewController.h"
  10. 10
  11. 11 @interface YYViewController ()
  12. 12 @property(nonatomic,strong)CALayer *layer;
  13. 13 @end
  14. 14
  15. 15 @implementation YYViewController
  16. 16
  17. 17 - (void)viewDidLoad
  18. 18 {
  19. 19 [super viewDidLoad];
  20. 20 //创建图层
  21. 21 CALayer *mylayer=[CALayer layer];
  22. 22 //设置图层属性
  23. 23 mylayer.backgroundColor=[UIColor brownColor].CGColor;
  24. 24 mylayer.bounds=CGRectMake(0, 0, 150, 100);
  25. 25 //显示位置
  26. 26 mylayer.position=CGPointMake(100, 100);
  27. 27 mylayer.anchorPoint=CGPointZero;
  28. 28 mylayer.cornerRadius=20;
  29. 29 //添加图层
  30. 30 [self.view.layer addSublayer:mylayer];
  31. 31 self.layer=mylayer;
  32. 32 }
  33. 33
  34. 34 -(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
  35. 35 {
  36. 36 //隐式动画
  37. 37 self.layer.bounds=CGRectMake(0, 0, 200, 60);
  38. 38 self.layer.backgroundColor=[UIColor yellowColor].CGColor;
  39. 39 }
  40. 40 @end

效果:

        

关闭隐式动画:

  1. 1 [CATransaction begin];
  2. 2 [CATransaction setDisableActions:YES];
  3. 3 //隐式动画
  4. 4 self.layer.bounds=CGRectMake(0, 0, 200, 60);
  5. 5 self.layer.backgroundColor=[UIColor yellowColor].CGColor;
  6. 6 [CATransaction commit];

3.如何查看CALayer的某个属性是否支持隐式动画?

  可以查看头文件,看有没有Animatable,如果有则表示支持。

也可以查看官方文档

文档中标明的这些属性都是支持隐式动画的

iOS开发UI篇—CAlayer层的属性的更多相关文章

  1. iOS开发UI 篇—CAlayer层的属性

    一.position和anchorPoint 1.简单介绍 CALayer有2个非常重要的属性:position和anchorPoint @property CGPoint position; 用来设 ...

  2. iOS开发UI篇—CAlayer(自定义layer)

    iOS开发UI篇—CAlayer(自定义layer) 一.第一种方式 1.简单说明 以前想要在view中画东西,需要自定义view,创建一个类与之关联,让这个类继承自UIView,然后重写它的Draw ...

  3. iOS开发UI篇—CAlayer(创建图层)

    iOS开发UI篇—CAlayer(创建图层) 一.添加一个图层 添加图层的步骤: 1.创建layer 2.设置layer的属性(设置了颜色,bounds才能显示出来) 3.将layer添加到界面上(控 ...

  4. iOS开发UI篇—CALayer简介

    iOS开发UI篇—CALayer简介   一.简单介绍 在iOS中,你能看得见摸得着的东西基本上都是UIView,比如一个按钮.一个文本标签.一个文本输入框.一个图标等等,这些都是UIView. 其实 ...

  5. iOS开发UI篇—CALayer

      一.简单介绍 在iOS中,你能看得见摸得着的东西基本上都是UIView,比如一个按钮.一个文本标签.一个文本输入框.一个图标等等,这些都是UIView. 其实UIView之所以能显示在屏幕上,完全 ...

  6. iOS开发UI篇—transframe属性(形变)

    iOS开发UI篇—transframe属性(形变) 1. transform属性 在OC中,通过transform属性可以修改对象的平移.缩放比例和旋转角度 常用的创建transform结构体方法分两 ...

  7. IOS开发UI篇—导航控制器属性和基本使用

    IOS开发UI篇—导航控制器属性和基本使用 一.导航控制器的一些属性和基本使用 1.把子控制器添加到导航控制器中的四种方法 (1) 1.创建一个导航控制器 UINavigationController ...

  8. iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist)

    iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist) 一.ios应用常用的数据存储方式 1.plist(XML属性列表归档) 2.偏好设置 3.NSKeydeArchiver归档(存 ...

  9. iOS开发UI篇—transframe属性(形变)

    iOS开发UI篇—transframe属性(形变) 1. transform属性 在OC中,通过transform属性可以修改对象的平移.缩放比例和旋转角度 常用的创建transform结构体方法分两 ...

随机推荐

  1. Angularjs+node+Mysql实现地图上特定点的定位以及附加信息展示

    注:本博文为博主原创,转载请注明出处. 在上一篇博文中主要讲述了如何利用AngularJs+Node+MySql构建项目,并实现地图上的多点标注,今天在这篇文章中,我们将在上一个项目的基础上,实现特定 ...

  2. UISearchBar控件-让我们来搞定!(转)

    转载自:http://blog.sina.com.cn/s/blog_7b9d64af0101dfg8.html     最近用到搜索功能.于是,经过不断的研究,终于,有点懂了. 那就来总结一下吧,好 ...

  3. ResourceManager里面Trackingui需要手动该ip

    C:\Windows\System32\drivers\etc 这个路径下配置了ip和主机名,不过是大小写,ping不同,不论ping大小写还是全部小写都不行,我看地址栏是小写所以想着把hosts里C ...

  4. poj 3680 Intervals

    给定N个带权的开区间,第i个区间覆盖区间(ai,bi),权值为wi.现在要求挑出一些区间使得总权值最大,并且满足实轴上任意一个点被覆盖不超过K次. 1<=K<=N<=200.1< ...

  5. html5图片异步上传/ 表单提交相关

    1 form 表单 get/post提交时候. action地址(或者啥ajax的url地址) 会涉及到跨域问题 常见跨域问题http://www.cnblogs.com/rainman/archiv ...

  6. MySQL主从同步延迟

    早上接到open-falcon报警,一台mysql从库同步延迟2w多秒,mysql版本比较老,用的5.1.37. 连接从库查找原因: show processlist一下,查看哪些线程在跑. 看到Ti ...

  7. Python Day6

    面向对象 概述 面向过程:根据业务逻辑从上到下写垒代码 函数式:将某功能代码封装到函数中,日后便无需重复编写,仅调用函数即可 面向对象:对函数进行分类和封装,让开发"更快更好更强...&qu ...

  8. Java正则认识

    一.为什么要有正则? 方便的对数据进行匹配 执行复杂的字符串验证.拆分.替换功能 举例:判断一个字符串是否由数字组成.(有以下两种方法对比) 不使用正则 String str = "1234 ...

  9. Spring实现初始化和销毁bean之前进行的操作,三种方式

    关于在spring  容器初始化 bean 和销毁前所做的操作定义方式有三种: 第一种:通过@PostConstruct 和 @PreDestroy 方法 实现初始化和销毁bean之前进行的操作 第二 ...

  10. HMac基本介绍

    基本介绍 HMAC(散列消息身份验证码: Hashed Message Authentication Code) 它不是散列函数,而是采用散列函数(MD5 or 或SHA)与共享密钥一起使用的消息身份 ...