【学习】CALayer实现,界限、透明度、位置、旋转、缩放组合动画

转载 2015年07月08日 17:46:45

首先引入框架:QuartzCore.framework

在头文件声明:CALayer *logoLayer

{

//界限

CABasicAnimation *boundsAnimation = [CABasicAnimation animationWithKeyPath:@"bounds"];

boundsAnimation.fromValue = [NSValue valueWithCGRect: logoLayer.bounds];

boundsAnimation.toValue = [NSValue valueWithCGRect:CGRectZero];


//透明度变化

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

opacityAnimation.fromValue = [NSNumber numberWithFloat:1.0];

opacityAnimation.toValue = [NSNumber numberWithFloat:0.5];


//位置移动

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

animation.fromValue =  [NSValue valueWithCGPoint: logoLayer.position];

CGPoint toPoint = logoLayer.position;

toPoint.x += 180;

animation.toValue = [NSValue valueWithCGPoint:toPoint];


//旋转动画

CABasicAnimation* rotationAnimation =

       [CABasicAnimation animationWithKeyPath:@"transform.rotation.z"];//"z"还可以是“x”“y”,表示沿z轴旋转

rotationAnimation.toValue = [NSNumber numberWithFloat:(2 * M_PI) * 3]; 

    // 3 is the number of 360 degree rotations

    // Make the rotation animation duration slightly less than the other animations to give it the feel

    // that it pauses at its largest scale value

rotationAnimation.duration = 2.0f;

rotationAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]; //缓入缓出


//缩放动画

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

scaleAnimation.fromValue = [NSNumber numberWithFloat:0.0];

scaleAnimation.toValue = [NSNumber numberWithFloat:1.0];

scaleAnimation.duration = 2.0f;

scaleAnimation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];


CAAnimationGroup *animationGroup = [CAAnimationGroup animation];

animationGroup.duration = 2.0f;

animationGroup.autoreverses = YES;   //是否重播,原动画的倒播

animationGroup.repeatCount = NSNotFound;//HUGE_VALF;     //HUGE_VALF,源自math.h

[animationGroup setAnimations:[NSArray arrayWithObjects:rotationAnimation, scaleAnimation, nil]];


//将上述两个动画编组

[logoLayer addAnimation:animationGroup forKey:@"animationGroup"];

}


//去掉所有动画

[logoLayer removeAllAnimations];

 //去掉key动画

[logoLayer removeAnimationForKey:@"animationGroup"];

CALayer实现,界限、透明度、位置、旋转、缩放组合动画

首先引入框架:QuartzCore.framework 在头文件声明:CALayer *logoLayer { //界限 CABasicAnimation *boundsAni...
  • SHTLoveXX
  • SHTLoveXX
  • 2016年11月11日 14:46
  • 1585

IOS--CALayer实现,界限、透明度、位置、旋转、缩放组合动画

首先引入框架:QuartzCore.framework 在头文件声明:CALayer *logoLayer { //界限 CABasicAnimation *boundsAnima...
  • gxp1032901
  • gxp1032901
  • 2014年12月17日 11:25
  • 298

IOS--CALayer实现,界限、透明度、位置、旋转、缩放组合动画(转)

首先引入框架:QuartzCore.framework 在头文件声明:CALayer *logoLayer { //界限 CABasicAnimation *boundsAnimation...
  • u011715727
  • u011715727
  • 2014年06月14日 15:02
  • 701

【iOS学习笔记】CALayer实现,界限、透明度、位置、旋转、缩放组合动画(转)

首先引入框架:QuartzCore.framework 在头文件声明:CALayer *logoLayer { //界限 CABasicAnimation *boundsAnimation = [C...
  • u013883974
  • u013883974
  • 2015年05月08日 10:00
  • 325

android之动画(透明度,位移,旋转,缩放)

简介Android 平台提供了两类动画。 一类是Tween动画,就是对场景里的对象不断的进行图像变化来产生动画效果(旋转、平移、放缩和渐变)。 第二类就是 Frame动画,即顺序的播放事先做好的图像...
  • mr_lihaimeng
  • mr_lihaimeng
  • 2015年09月19日 19:19
  • 2433

android动画的透明度渐变、旋转动画、缩放动画、评议动画

在android中实现图片的旋转、平移、缩放、透明度的渐变原代码直接复制即可运行...
  • blueZhangFun
  • blueZhangFun
  • 2015年07月10日 21:28
  • 773

[CAAnimation核心动画练习一]普通的平移,旋转,缩放

[CAAnimation核心动画练习一]普通的平移,旋转,缩放
  • liyanq528
  • liyanq528
  • 2016年03月02日 13:01
  • 1883

android动画基础--旋转移动平移缩放

package com.imooc.viewanim;import android.app.Activity; import android.os.Bundle; import android.vie...
  • DTJ_74
  • DTJ_74
  • 2016年07月13日 14:41
  • 1386

彻底理解CALayer的position与anchorPoint

引言 相信初接触到CALayer的人都会遇到以下几个问题:   为什么修改anchorPoint会移动layer的位置?  CALayer的position点是哪一点呢?  anchorPoint与...
  • openglnewbee
  • openglnewbee
  • 2015年12月22日 10:21
  • 2912

Android Studio去掉标题栏和旋转、渐变、缩放动画

在清单文件的activity的节点下 写theme 配置等于@android:style/Theme.Black.NoTitleBar.Fullscreen 在activity的节点下加这个是去...
  • wangchaojie__
  • wangchaojie__
  • 2016年11月30日 16:41
  • 348
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【学习】CALayer实现,界限、透明度、位置、旋转、缩放组合动画
举报原因:
原因补充:

(最多只允许输入30个字)