ios-day18-09(使用CAKeyframeAnimation实现对UIView在多个位置之间平移、沿着某一条路径平移)

源码下载地址:http://download.csdn.net/detail/liu537192/8558383


效果图:


核心代码:

//
//  JLViewController.m
//  09-核心动画
//
//  Created by XinYou on 15-4-2.
//  Copyright (c) 2015年 vxinyou. All rights reserved.
//

#import "JLViewController.h"

@interface JLViewController ()
@property (weak, nonatomic) IBOutlet UIImageView *iconView;

- (IBAction)multiPosition;
- (IBAction)surroundCircle;
- (IBAction)back;
@end

@implementation JLViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    
    
}
/**
 *  平移到多个不同的位置
 */
- (IBAction)multiPosition {
    // 1,创建动画
    CAKeyframeAnimation *anim = [CAKeyframeAnimation animation];
    
    // 2,设置动画对象
    // 设置CALayer要修改的属性
    anim.keyPath = @"position";
    
    NSValue *v1 = [NSValue valueWithCGPoint:CGPointMake(160, 90)];
    NSValue *v2 = [NSValue valueWithCGPoint:CGPointMake(160, 190)];
    NSValue *v3 = [NSValue valueWithCGPoint:CGPointMake(260, 190)];
    NSValue *v4 = [NSValue valueWithCGPoint:CGPointMake(260, 90)];
    
    // 设置position属性的每一帧要改变的值
    anim.values = @[v1, v2, v3, v4];
    
    // 设置动画持续时间
    anim.duration = 2.0;
    
    // 保持动画执行完毕后的状态
    anim.removedOnCompletion = NO;
    anim.fillMode = kCAFillModeForwards;
    
    // 3,添加动画
    [self.iconView.layer addAnimation:anim forKey:nil];
}
/**
 *  绕圆平移
 */
- (IBAction)surroundCircle {
    
    // 1,创建动画
    CAKeyframeAnimation *anim = [CAKeyframeAnimation animation];
    
    // 2,设置动画对象
    anim.keyPath = @"position";
    anim.removedOnCompletion = NO;
    anim.fillMode = kCAFillModeForwards;
    anim.duration = 2.0;
    
    // 创建路径
    CGMutablePathRef path = CGPathCreateMutable();
    CGPathAddEllipseInRect(path, NULL, CGRectMake(90, 90, 100, 100));
    
    // 设置路径
    anim.path = path;
    CGPathRelease(path);
    
    // 3,添加动画
    [self.iconView.layer addAnimation:anim forKey:nil];
}
/**
 *  还原
 */
- (IBAction)back {
    
    [self.iconView.layer removeAllAnimations];
}
@end

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值