Investigé cómo se agregan las animaciones a la capa UIAlertView
al voltear -[CALayer addAnimation:forKey:]
. Estos son los valores que tengo para transformar la escala que realiza animaciones:
0.01f -> 1.10f -> 0.90f -> 1.00f
con duraciones
0.2s, 0.1s, 0.1s
.
Todas las animaciones utilizan una función de temporización de facilidad/facilidad. Aquí está una CAKeyframeAnimation
que encapsula esta lógica:
CAKeyframeAnimation *bounceAnimation = [CAKeyframeAnimation animationWithKeyPath:@"transform"];
bounceAnimation.fillMode = kCAFillModeBoth;
bounceAnimation.removedOnCompletion = YES;
bounceAnimation.duration = 0.4;
bounceAnimation.values = @[
[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.01f, 0.01f, 0.01f)],
[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.1f, 1.1f, 1.1f)],
[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.9f, 0.9f, 0.9f)],
[NSValue valueWithCATransform3D:CATransform3DIdentity]];
bounceAnimation.keyTimes = @[@0.0f, @0.5f, @0.75f, @1.0f];
bounceAnimation.timingFunctions = @[
[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut],
[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut],
[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut]];
Creo UIAlertView
también realiza una animación simple opacidad 0.0f
-1.0f
largo de la duración total de la animación de transformación (0.4
).
¡Gracias! Esto fue muy útil. –