我的简单目标是淡化动画隐藏和显示功能。
Button.hidden = YES;
很简单。但是,是否有可能让它消失而不仅仅是消失?那样看起来就很不专业。
在 iOS 4 及更高版本中,有一种方法可以做到这一点,只需使用 UIView 过渡方法,而无需导入 QuartzCore。你可以说:
[UIView transitionWithView:button duration:0.4 options:UIViewAnimationOptionTransitionCrossDissolve animations:^{ button.hidden = YES; } completion:NULL];
UIView.transition(with: button, duration: 0.4, options: .transitionCrossDissolve, animations: { button.hidden = false })
Michail 的解决方案会起作用,但它实际上并不是最好的方法。
Alpha 渐变的问题在于,有时不同的重叠视图层在淡出时看起来很奇怪。还有其他一些使用核心动画的替代方案。首先在您的应用程序中包含 QuartzCore 框架并添加#import <QuartzCore/QuartzCore.h>到您的标题中。现在您可以执行以下操作之一:
#import <QuartzCore/QuartzCore.h>
1)设置button.layer.shouldRasterize = YES;然后使用 Michail 在他的答案中提供的 alpha 动画代码。这将防止图层奇怪地混合,但会带来轻微的性能损失,并且如果按钮未在像素边界上精确对齐,则可能会使按钮看起来模糊。
button.layer.shouldRasterize = YES;
或者:
2) 使用以下代码为淡入淡出动画:
CATransition *animation = [CATransition animation]; animation.type = kCATransitionFade; animation.duration = 0.4; [button.layer addAnimation:animation forKey:nil]; button.hidden = YES;
这种方法的好处是您可以交叉淡化按钮的任何属性,即使它们不是可动画的(例如按钮的文本或图像),只需设置过渡,然后立即设置属性。