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

55 lines
2.5 KiB
Objective-C
Executable File

//
// DGActivityIndicatorTripleRingsPulseAnimation.m
// DGActivityIndicatorExample
//
// Created by tripleCC on 15/6/28.
// Copyright (c) 2015年 Danil Gontovnik. All rights reserved.
//
#import "DGActivityIndicatorTripleRingsAnimation.h"
@implementation DGActivityIndicatorTripleRingsAnimation
#pragma mark -
#pragma mark DGActivityIndicatorAnimation Protocol
- (void)setupAnimationInLayer:(CALayer *)layer withSize:(CGSize)size tintColor:(UIColor *)tintColor {
NSTimeInterval beginTime = CACurrentMediaTime();
UIBezierPath *path = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(0.0f, 0.0f, size.width, size.width)];
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 < 3; i++) {
CAShapeLayer *circle = [CAShapeLayer layer];
circle.path = path.CGPath;
circle.fillColor = [UIColor clearColor].CGColor;
circle.strokeColor = tintColor.CGColor;
circle.frame = CGRectMake(oX, oY, size.width, size.height);
circle.anchorPoint = CGPointMake(0.5f, 0.5f);
circle.opacity = 1.0f;
circle.transform = CATransform3DMakeScale(0.0f, 0.0f, 0.0f);
CABasicAnimation *transformAnimation = [self createBasicAnimationWithKeyPath:@"transform"];
transformAnimation.duration = 2.0f - i * 0.4f;
transformAnimation.fromValue = [NSValue valueWithCATransform3D:CATransform3DMakeScale(0.1f, 0.1f, 0.0f)];
transformAnimation.toValue = [NSValue valueWithCATransform3D:CATransform3DMakeScale(1.0f, 1.0f, 0.0f)];
transformAnimation.timingFunction = [CAMediaTimingFunction functionWithName: kCAMediaTimingFunctionEaseOut];
CABasicAnimation *opacityAnimation = [self createBasicAnimationWithKeyPath:@"opacity"];
opacityAnimation.duration = transformAnimation.duration;
opacityAnimation.fromValue = @(1.0f);
opacityAnimation.toValue = @(0.8f);
opacityAnimation.timingFunction = [CAMediaTimingFunction functionWithName: kCAMediaTimingFunctionEaseOut];
CAAnimationGroup *animationGroup = [self createAnimationGroup];;
animationGroup.beginTime = beginTime + i * 0.4f;
animationGroup.repeatCount = HUGE_VALF;
animationGroup.duration = 2.0f;
animationGroup.animations = @[transformAnimation, opacityAnimation];
[layer addSublayer:circle];
[circle addAnimation:animationGroup forKey:@"animation"];
}
}
@end