8

我想在 iPhone 上创建一个类似于 Apple 的 Messages 应用程序的 UI。我有一个表格视图和它下面的文本字段。当我选择文本字段时,我会在键盘向上滑动时为表格视图的 contentInset 设置动画,以便内容显示在键盘上方。

我有一些代码使用平移手势识别器来检测用户何时向下滚动表格视图并在发生这种情况时向下动画键盘(如果您看到 Apple 的 Messages 应用程序,它具有关闭键盘的相同功能。向下滚动在表格视图上,当您的手指滑过文本字段时,键盘随之下降)。

这很好用,但是如果表格视图滚动到顶部,并且当键盘向下滑动时我开始更改其内容插图,表格视图会滚动到顶部,然后重新回到顶部,从而导致奇怪的生涩动画。我认为这是因为如果表格视图滚动到顶部,更改 contentInset 会将 contentOffset 重置为表格视图的顶部,这使它表现得很奇怪。

有谁知道如何在不更改其 contentOffset 的情况下更改滚动视图的 contentInset?

4

1 回答 1

7

我设法通过一个小的解决方法让一切都完美地工作。我只是这样做了:

// in a method that gets repeatedly called as the pan gesture recognizer changes
if([tableView contentOffset].y > 0) {
    UIEdgeInsets insets = [tableView contentInsets];
    inset.bottom = currentKeyboardHeight;
    [tableView setContentInset:inset];
}

这样如果 contentOffset 位于最顶部或滚动到顶部,则不会更改插图。如果表格向下滚动并拖动,它将更改插图直到它到达顶部,然后停止更改它们,这样就不会发生奇怪的闪烁。


编辑:找出根本原因,并认为我会更新它,而不是仅仅离开解决方法。我所做的是CGAffineTransformMakeTranslation在我的帧计算中间混合 a,根据 Apple 文档,这是一个很大的禁忌。当transform属性 notCGAffineTransformIdentity时,frame变得未定义,如果我滚动表格视图并同时更改其内容插图,这会导致一些非常奇怪的行为。

于 2012-07-17T05:43:11.213 回答