gpt4 book ai didi

ios7 - 当存在 UITabBar 时,如何正确地为键盘顶部的 View 设置动画?

转载 作者:行者123 更新时间:2023-12-04 23:38:05 25 4
gpt4 key购买 nike

this answer 中详述的技术关于如何正确地为 View (如评论输入框)设置动画以在动画进出时保持在键盘顶部效果很好。在 View 底部和底部布局指南之间设置垂直高度约束,并使用键盘动画的曲线和持续时间将其设置为键盘框架高度的动画。

但是当您使用 UITabBarController 并且在屏幕底部有一个标签栏时,这是行不通的——您最终会得到一个 UITabBar 高度差距您的 View 和键盘,因为底部布局指南仍位于选项卡栏的顶部,但键盘覆盖了选项卡栏,并且其框架的高度是从屏幕底部计算的。

简单地从键盘框架高度中减去标签栏高度是行不通的,因为这会破坏动画效果。你可以在 iOS 7 的 iPhone Facebook 应用程序中清楚地看到这种效果;当您关闭键盘时,评论框和键盘之间存在间隙:

Note gap between bottom of comment entry box and tab bar as keyboard animates away

(尝试在 iPhone Facebook 应用程序中的帖子上调用和关闭键盘以查看动画效果。)

我可以想出几种方法来解决这个问题,我想知道是否有人尝试过这些方法或有更好的想法:

1) 隐藏 UITabBar,使底部布局指南在键盘动画消失之前最终位于屏幕底部(如何?),并在键盘动画返回之前再次显示它

2) 调整动画曲线/时间,使我的 View 正确地“跟上”键盘(最好不要猜测/破解它)

3) 将我的 View 的底部约束附加到底部布局指南以外的其他东西(什么?)

最佳答案

我一直在困惑这个问题,我找到了一个解决方案,它可能不太优雅,但还可以

在您结束编辑并因此开始隐藏键盘的方法中,您可以启动一个 NSTimerscheduledTimerWithTimeInterval:0.05 调用如下方法:

在调用NSTimer之前设置:

// define these once
textViewHeight = self.textView.frame.size.height;
tabBarHeight = self.tabBar.frame.size.height;
maxOrigin = self.view.frame.size.height - textViewHeight - tabBarHeight;

NSTimer 调用:

CGFloat currentOrigin = self.textView.frame.origin.y;

if (currentOrigin > maxOrigin)
{
CGRect f = self.textView.frame;
f.origin.y = maxOrigin;
[self.textView setFrame:f];

[timer invalidate];
timer = nil;
}

这样动画会继续将其设置到它已经存在的位置,并且 View 会停留在键盘上,直到它到达 y 轴上的“maxOrigin”

关于ios7 - 当存在 UITabBar 时,如何正确地为键盘顶部的 View 设置动画?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21160116/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com