关键帧动画

/*
CAKeyframeAnimation 也属于 CAPropertyAnimation 
 关键帧动画  可以让我们精准是控制动画效果 它的原理是把动画序列里面比较关键的帧提取出来 设置他的动画效果
 
 path属性 执行动画轨迹的路径
 values 执行动画轨迹是数组
 
*/


#import "ViewController.h"

@interface ViewController ()
{
//    UIImage *image;
    CALayer *heartLayer;
//    CALayer *myLayer;
}
@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    [self addHeart];
}

- (void)addHeart{
    
    UIImage *image = [UIImage imageNamed:@"桃心"];
    
    heartLayer = [[CALayer alloc]init];
    heartLayer.position = CGPointMake(self.view.center.x, 200);
    heartLayer.bounds = CGRectMake(0, 0, image.size.width/5, image.size.height/5);
    heartLayer.contents = (id)image.CGImage;
    
    [self.view.layer addSublayer:heartLayer];
}

- (void)addAnimation{
//    CAKeyframeAnimation 关键帧动画的类
    CAKeyframeAnimation *drow = [CAKeyframeAnimation animationWithKeyPath:@"position"];
    drow.duration = 0.001;
    drow.repeatCount = HUGE;
    drow.values = @[[self getPointWithX:0 andY:0],[self getPointWithX:50 andY:-50],[self getPointWithX:100 andY:-65],[self getPointWithX:120 andY:-50],[self getPointWithX:160 andY:0],[self getPointWithX:120 andY:100],[self getPointWithX:50 andY:150],[self getPointWithX:0 andY:200],[self getPointWithX:-50 andY:150],[self getPointWithX:-120 andY:100],[self getPointWithX:-160 andY:0],[self getPointWithX:-120 andY:-50],[self getPointWithX:-100 andY:-65],[self getPointWithX:-50 andY:-50],[self getPointWithX:0 andY:0]];
    
    [heartLayer addAnimation:drow forKey:@"move"];
    
}
#pragma mark-----把CGPoint 转换成NSValue--------
- (NSValue *)getPointWithX:(CGFloat)x andY:(CGFloat)y{
    
    return [NSValue valueWithCGPoint:CGPointMake(x+heartLayer.position.x, y+heartLayer.position.y)];
}

- (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{
    [self addAnimation];
}

 

转载于:https://www.cnblogs.com/liYongJun0526/p/4874142.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值