Hibit_iOS/HiBit/Utils/HUD/DGActivityIndicatorView/Animations/DGActivityIndicatorDoubleBounceAnimation.m
2024-06-07 11:41:02 +08:00

51 lines
2.2 KiB
Objective-C
Executable File

//
// DGActivityIndicatorDoubleBounceAnimation.m
// DGActivityIndicatorExample
//
// Created by Danil Gontovnik on 5/23/15.
// Copyright (c) 2015 Danil Gontovnik. All rights reserved.
//
#import "DGActivityIndicatorDoubleBounceAnimation.h"
@implementation DGActivityIndicatorDoubleBounceAnimation
#pragma mark -
#pragma mark DGActivityIndicatorAnimation Protocol
- (void)setupAnimationInLayer:(CALayer *)layer withSize:(CGSize)size tintColor:(UIColor *)tintColor {
NSTimeInterval beginTime = CACurrentMediaTime();
CGFloat oX = (layer.bounds.size.width - size.width) / 2.0f;
CGFloat oY = (layer.bounds.size.height - size.height) / 2.0f;
for (int i = 0; i < 2; i++) {
CALayer *circle = [CALayer layer];
circle.frame = CGRectMake(oX, oY, size.width, size.height);
circle.anchorPoint = CGPointMake(0.5f, 0.5f);
circle.opacity = 0.5f;
circle.cornerRadius = size.height / 2.0f;
circle.transform = CATransform3DMakeScale(0.0f, 0.0f, 0.0f);
circle.backgroundColor = tintColor.CGColor;
CAKeyframeAnimation *transformAnimation = [self createKeyframeAnimationWithKeyPath:@"transform"];
transformAnimation.repeatCount = HUGE_VALF;
transformAnimation.duration = 2.0f;
transformAnimation.beginTime = beginTime - (1.0f * i);
transformAnimation.keyTimes = @[@(0.0f), @(0.5f), @(1.0f)];
transformAnimation.timingFunctions = @[[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut],
[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut],
[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]];
transformAnimation.values = @[[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.0f, 0.0f, 0.0f)],
[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.0f, 1.0f, 0.0f)],
[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.0f, 0.0f, 0.0f)]];
[layer addSublayer:circle];
[circle addAnimation:transformAnimation forKey:@"animation"];
}
}
@end