CALayer是UIView可以响应事件。一般来说,layer可以有两种用途:一是对view相关属性的设置,包括圆角、阴影、边框等参数;二是实现对view的动画操控。

因此对一个view进行core animation动画,本质上是对该view的.layer进行动画操纵。

1.CALayer常见属性

新建图层

CALayer * layer = [CALayer layer];

图层颜色

layer.backgroundColor = [UIColor redColor].CGColor;

图层大小

layer.bounds = CGRectMake(0, 0, 100, 100);

图层锚点

layer.anchorPoint = CGPointMake(0, 0);

图层位置

layer.position = self.view.center;

圆角半径

layer.cornerRadius = 50;

边框宽度

layer.borderWidth = 2;

边框颜色

layer.borderColor = [UIColor blackColor].CGColor;

添加图层

[self.view.layer addSublayer:layer];

2.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)

layer.anchorPoint = CGPointMake(0, 0);

layer.anchorPoint = CGPointMake(0.5, 0.5);

layer.anchorPoint = CGPointMake(1, 1);

3.改变transform的动画

旋转

layer.transform = CATransform3DRotate(_layer.transform, 10/180.0*M_PI, 1, 1, 1);

放大缩小

layer.transform = CATransform3DScale(_layer.transform, 2, 2, 2);

平移

layer.transform = CATransform3DTranslate(_layer.transform, 10, 10, 0);

4.CABasicAnimation

     CALayer *Layer = [[CALayer alloc] init];

    Layer.backgroundColor = [UIColor blueColor].CGColor;

    Layer.frame = CGRectMake(100, 100, 50, 50);

    Layer.cornerRadius = 10;

    [self.view.layer addSublayer:scaleLayer];

    

    CABasicAnimation *scaleAnimation = [CABasicAnimation animationWithKeyPath:@"transform.scale"];

    scaleAnimation.fromValue = [NSNumber numberWithFloat:1.0];

    scaleAnimation.toValue = [NSNumber numberWithFloat:1.5];

    scaleAnimation.fillMode = kCAFillModeForwards;最后以什么填充

    scaleAnimation.repeatCount = MAXFLOAT;重复次数

    scaleAnimation.duration = 1;

 

    [Layer addAnimation:scaleAnimation forKey:nil];

常用的属性有

  transform

  transform.ratation.z

  opacity

  position

5.CAAnimationGroup

CALayer *Layer = [[CALayer alloc] init];

Layer.backgroundColor = [UIColor blueColor].CGColor;

Layer.frame = CGRectMake(100, 100, 50, 50);

Layer.cornerRadius = 10;

[self.view.layer addSublayer:Layer];

放大

CABasicAnimation *scaleAnimation = [CABasicAnimation animationWithKeyPath:@"transform.scale"];

scaleAnimation.fromValue = [NSNumber numberWithFloat:1.0];

scaleAnimation.toValue = [NSNumber numberWithFloat:1.5];

渐变

CABasicAnimation * opacityAnimation = [CABasicAnimation animationWithKeyPath:@"opacity"];

opacityAnimation.fromValue = @1;

opacityAnimation.toValue = @0;

移动

CABasicAnimation *moveAnimation = [CABasicAnimation animationWithKeyPath:@"position"];

moveAnimation.toValue = [NSValue valueWithCGPoint:CGPointMake(200, 200)];

旋转

CABasicAnimation *rotateANimation = [CABasicAnimation animationWithKeyPath:@"transform"];

rotateANimation.fromValue = [NSValue valueWithCATransform3D:CATransform3DIdentity];

rotateANimation.toValue = [NSValue valueWithCATransform3D:CATransform3DRotate(Layer.transform, M_PI, 0, 0, 1)];

CAAnimationGroup * group = [CAAnimationGroup animation];

group.removedOnCompletion = NO;

group.fillMode = kCAFillModeForwards;

group.repeatCount = MAXFLOAT;

group.duration = 1;

group.animations =@[scaleAnimation,opacityAnimation,moveAnimation,rotateANimation];

[Layer addAnimation:group forKey:nil];

6.补充

再旋转中,上边的写法转换成弧度之后不能转多圈,下面实现转多圈

CABasicAnimation *zrotateANimation = [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];

zrotateANimation.fromValue = [NSNumber numberWithFloat:0];

zrotateANimation.toValue = [NSNumber numberWithFloat:M_PI * 4.0];

CALayer CABasicAnimation的更多相关文章

  1. iOS开发笔记10:圆点缩放动画、强制更新、远程推送加语音提醒及UIView截屏

    1.使用CAReplicatorLayer制作等待动画 CALayer+CABasicAnimation可以制作很多简单的动画效果,之前的博客中介绍的“两个动画”,一个是利用一张渐变色图片+CABas ...

  2. ios 关于动画用法的总结

      #import "FirstVC.h" @implementation FirstVC /*     创建xib过程     1 创建xib(名字和类名相同)     2 文件 ...

  3. iOS Animation具体解释

    iOS Animation具体解释 本篇仅仅要解说iOS中动画的使用. Animtion主要分为两类:UIView动画和CoreAnimation动画. UIView动画有UIView属性动画,UIV ...

  4. CALayer, CoreGraphics与CABasicAnimation介绍

    今天我们来看一下CALayer.CoreGraphics和CABasicAnimation.这些东西在处理界面绘制.动画效果上非常有用. 本篇博文就讲介绍CALayer的基本概念,使用CoreGrap ...

  5. 之一:CABasicAnimation - 基本动画

    嗷呜嗷呜嗷呜 // 将视图作为属性方便后面执行多个不同动画 _myView = [[UIView alloc] init]; _myView.layer.position = CGPointMake( ...

  6. Quartz2D复习(四) --- 图层CALayer和动画CAAnimation

    1.CALayer 1).在ios中,能看得见摸得着的东西基本上都是UIView, 比如按钮.文本标签.文本输入框.图标等,这些都是UIView 2).UIView之所以能显示在屏幕上,完全是因为它内 ...

  7. iOS - CABasicAnimation

    代码实例: [1] - (void)pulseClick { //!> 宽和高等比例转换 CABasicAnimation * pulse = [CABasicAnimation animati ...

  8. iOS开发——UI进阶篇(十七)CALayer,核心动画基本使用

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

  9. CABasicAnimation animationWithKeyPath 一些规定的值

    CABasicAnimation animationWithKeyPath Types When using the ‘CABasicAnimation’ from the QuartzCore Fr ...

随机推荐

  1. PHP session 跨子域问题总结

    Session主要分两部分: 一个是Session数据,该数据默认情况下是存放在服务器的tmp文件下的,是以文件形式存在 另一个是标志着Session数据的Session Id,Session ID, ...

  2. C# 让textbox 只能输入数字的方法

    使用textBox控件的KeyPress事件 private void textBox_KeyPress(object sender, KeyPressEventArgs e) { if (e.Key ...

  3. ASP.NET 导出Excel文档

    System.IO.TextWriter writer = new System.IO.StreamWriter(Server.MapPath("/provprice.xls"), ...

  4. Android 使用monkey自动测试

    很简单的一个monkey使用流程: 首先创建一个monkey脚本test.txt,例如一个简单的反复测试拍照功能的脚本: # Start of Script type= user count= 49 ...

  5. Android中使用shape来定义控件

    本文章转接于:http://kofi1122.blog.51cto.com/2815761/521605 Android中常常使用shape来定义控件的一些显示属性,今天看了一些shape的使用,对s ...

  6. C++服务器设计(七):聊天系统服务端实现

    在之前的章节中,我们对服务端系统的设计实现原理进行了剖析,在这一章中,我们将对服务端框架进行实际运用,实现一款运行于内网环境的聊天系统.该聊天系统由客户端与服务器两部分组成,同时服务端通过数据库维护用 ...

  7. (原)使用mkl计算特征值和特征向量

    转载请注明出处: http://www.cnblogs.com/darkknightzh/p/5585271.html 参考文档:mkl官方文档 lapack_int LAPACKE_sgeev(in ...

  8. 用H5实现微信的四个界面

    代码更新中

  9. 第二章——第二节 IPC机制的概述和使用

    一.Serialiable与Paracle ①.作用    ②.使用 二.Binder与AIDL ①.各自的作用 三.如何使用IPC机制 举例 四.IPC机制的原理 ①.流程图  ②.自己编译自动生成 ...

  10. Effective Java设定游戏 - 就是爱Java

    首先,我们先设定游戏,一个网页游戏的基本场景,主角拥有各种能力,但一开始数值都只有系统初始,随着故事的发展,会接触到各种不同的场景,获得提升角色的道具与装备,来参与更高难度的任务. 阅读全文>& ...