【学习】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"];

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

首先引入框架:QuartzCore.framework 在头文件声明:CALayer *logoLayer { //界限 CABasicAnimation *boundsAnimation = [C...

动画效果:位置移动、画面旋转、渐变透明度、渐变尺寸缩放

alpha xmlns:android="http://schemas.android.com/apk/res/android" android:duration="5000" and...
  • aptx14
  • aptx14
  • 2017年10月18日 21:15
  • 60

Android 通过Animate硬编码实现简单的平移、旋转、缩放及透明度动画过程

以下只列出主要代码: private ImageView scanLight; @Override public void onCreate(Bundle savedInstan...

Android 补间动画,具体介绍了透明度、平移,旋转,缩放4种动画效果的实现,简单易懂

Android 补间动画 具体介绍了 1、透明度、 2、平移, 3、旋转, 4、缩放 4种动画效果的实现, 简单易学易懂...

安卓中为View添加动画效果(尺寸缩放、透明度渐变、旋转、移动)

安卓中为View添加动画效果(尺寸缩放、透明度渐变、旋转、移动)

android游戏开发5-10 补间动画 透明度渐变 旋转 缩放 平移

首先在res文件下新建anim文件夹 新建anim_alpha.xml代码如下:

为控件添加动画的方法(Alpha透明度,rotate旋转,scale缩放,translate位移)

说明: 在xml文件中静态定义使用 1.在res文件夹下面新建anim文件夹 2.在anim文件夹下面新建资源xxx.xml...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:【学习】CALayer实现,界限、透明度、位置、旋转、缩放组合动画
举报原因:
原因补充:

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