如何在更改 uiview 的隐藏模式时添加动画?
我想在更改其隐藏模式时向视图添加动画,即
my_view.hidden=YES;
我在导航栏中添加了一个按钮。当我们单击它时,新视图将设置为取消隐藏。它绘制在导航表的上部。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
我想在更改其隐藏模式时向视图添加动画,即
my_view.hidden=YES;
我在导航栏中添加了一个按钮。当我们单击它时,新视图将设置为取消隐藏。它绘制在导航表的上部。
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(12)
将视图的不透明度从 100% 设置为 0%。让动画完成回调将视图设置为隐藏。您可能还想在回调期间将不透明度重置回 100%,这样当您取消隐藏视图时,视图将显示为完全不透明。
Animate the view's opacity from 100% to 0%. Have the animation completion callback set the view to be hidden. You might also want to reset the opacity back to 100% during the callback, so the view will display fully opaque when you unhide it.
然而,没有用于隐藏的动画;使用下面的 Swift 代码会得到相同的结果:
There is no animation for hiding however; you get the same result with the Swift code below:
不幸的是,hidden 不是一个可以通过 UIView 动画设置动画的属性。我认为你最好的选择可能是使用 @Erik B 建议的动画之一,或者开始涉足更强大的核心动画。浏览一下 UIView 动画和 Core Animations 的文档。
我通过使用 UIView 动画将新视图从另一个视图下方滑动来实现了类似于您建议的效果。这使它看起来像一个滑出的抽屉。如果你想做这样的事情,你需要拦截 touch up inside 事件并将动画代码放在那里。
Unfortunately, hidden is not a property that is animatable through UIView animations. I think your best bet may be to use one of the animations @Erik B suggested, or start dabbling with Core Animations which are much more powerful. Take a glance at the documentation for UIView animations and Core Animations.
I achieved something like what your suggesting by using UIView animations to slide the new view from below another view. This made it appear like a drawer sliding out. If you want to do something like that, you need to intercept the touch up inside event and place the animation code there.
我认为更合适的做法是:
I think more appropriate way to do it is:
更新至 Swift 3:
如果您希望在第一个视图消失后以动画方式恢复某些内容,您可以使用
alpha = 1
和复制完成块内的代码隐藏=假
。Updated to Swift 3:
And if you wish to animate something back after first view is gone, you can replicate the code inside the completion block with
alpha = 1
andhidden = false
.这是我编写的一个类别,用于在 UIView 上引入一个新的“隐藏”属性,该属性正确支持动画:
Here's a category I wrote to introduce a new "hidden" property on UIView which correctly supports animation:
这是修正后的新泽西州版本:
This is corrected N.J. version:
这是 Swift 版本:
Swift 2
Swift 3, 4, 5
它执行持续时间为 5 秒并延迟 2 秒后的动画。
可用的动画选项有:
Here is swift version for this :
Swift 2
Swift 3, 4, 5
This performs animation with duration of 5 seconds and after delay of 2 seconds.
Available AnimationOptions are :
由于其中一些答案有点混乱,我想我可以发布我对此 API 的简约设计。我还添加了延迟和持续时间 - 因为为什么不呢。
在我们的实现中。
在我们的头文件中。
Since a few of these answers are a bit cluttered I figured I could post my minimalistic design of this API. I also added the delay and duration - because why not.
In the implementation we have.
In the header file we have.
NJ 和斯坦尼斯拉夫在这里的答案帮助我为此创建了一个新类别,我认为这改进了他们的答案,所以我想我会发布我的想法,以防它对其他人有帮助。
请注意,它仅适用于 iOS4 或更高版本,因为它使用块。
UIView+AnimateHidden.m
NJ's and Stanislav's answers here helped me make a new category for this, which I think improves on their answers, so thought I'd post what I came up with in case it helps anyone else.
Note it will only work in iOS4 or later as it's using blocks.
UIView+AnimateHidden.m
如果您希望使用更复杂的动画类型或 UIView 不支持的动画,请使用另一个版本
Another version if you wish to use more complex animation types or animations not supported by the UIView
这是我用来在“显示更多...”和“显示更少...”按钮单击时对视图“增长”和“收缩”进行建模的代码。根据 Palyancodr 的答案建模
这种方法允许我在故事板中创建两个视图,以便约束在不同的 iOS 设备上按预期工作,并且我不需要自定义所有约束的代码。
Here is the code I used to model a view "growing" and "shrinking" on a "show more..." and "show less ..." button click. Modeled off the answer from Palyancodr
This approach allows me to create both views in the storyboard so that the constraints work as expected on the different iOS devices and I don't need to custom code all the constraints.