Additive属性动画
参考
http://ronnqvi.st/multiple-animations/
效果
源码
https://github.com/YouXianMing/Animations
//
// AdditiveAnimationController.m
// Animations
//
// Created by YouXianMing on 16/1/21.
// Copyright © 2016年 YouXianMing. All rights reserved.
//
#import "AdditiveAnimationController.h"
#import "UIView+SetRect.h"
@interface AdditiveAnimationController ()
@property (nonatomic, strong) CALayer *layer;
@end
@implementation AdditiveAnimationController
- (void)setup {
[super setup];
// http://ronnqvi.st/multiple-animations/
self.layer = [CALayer layer];
self.layer.frame = CGRectMake(0, 0, 30, 30);
self.layer.backgroundColor = [UIColor redColor].CGColor;
self.layer.cornerRadius = 15.f;
self.layer.position = self.contentView.middlePoint;
[self.contentView.layer addSublayer:self.layer];
UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(tapEvent:)];
[self.contentView addGestureRecognizer:tap];
}
- (void)tapEvent:(UITapGestureRecognizer *)tapGesture {
CGPoint touchPoint = [tapGesture locationInView:tapGesture.view];
CGPoint differencePoint = CGPointMake(self.layer.position.x - touchPoint.x,
self.layer.position.y - touchPoint.y);
CALayer *presentationLayer = self.layer.presentationLayer;
NSLog(@"%@", presentationLayer);
CABasicAnimation *animation = [CABasicAnimation animationWithKeyPath:@"position"];
animation.duration = 1.f;
animation.timingFunction = [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
animation.additive = true;
animation.fromValue = [NSValue valueWithCGPoint:differencePoint];
animation.toValue = [NSValue valueWithCGPoint:CGPointZero];
[CATransaction begin];
[CATransaction setDisableActions:YES];
self.layer.position = touchPoint;
[CATransaction commit];
[self.layer addAnimation:animation forKey:nil];
}
@end
细节