我有一种在我的网络视图中更改文本的方法,以检测当前插入符号位置的可见矩形。
UITextPosition *endPos = self.selectedTextRange.end;
CGRect rect = [self caretRectForPosition:endPos];
[self scrollRectToVisible:rect animated:NO];
它工作得很好,除非我在文档末尾并按下键盘上的删除键。在这种情况下,它会滚动到文档的开头,这是出乎意料的。
我有一种在我的网络视图中更改文本的方法,以检测当前插入符号位置的可见矩形。
UITextPosition *endPos = self.selectedTextRange.end;
CGRect rect = [self caretRectForPosition:endPos];
[self scrollRectToVisible:rect animated:NO];
它工作得很好,除非我在文档末尾并按下键盘上的删除键。在这种情况下,它会滚动到文档的开头,这是出乎意料的。
我遇到了类似的问题......这似乎是文本视图中的时间问题。我的解决方案是:
A:从 caretRectForPosition 中检测无效结果。在我的情况下,无效坐标似乎总是大的负值(-1.0 似乎是 iO!)或 origin.y 的“无限”。
B:在短时间内重新询问插入符号位置的文本视图。我检查了一些延迟值;0.05 似乎在很大程度上就足够了。
编码:
- (void)textViewDidChange:(UITextView *)pTextView {
UITextPosition* endPos = pTextView.selectedTextRange.end;
CGRect caretRectInTextView = [pTextView caretRectForPosition:endPos];
if ((-1.0 > CGRectGetMinY(caretRectInTextView)) ||
(INFINITY == CGRectGetMinY(caretRectInTextView))) {
NSLog(@"Invalid caretRectInTextView detected!");
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.05 * NSEC_PER_SEC)),
dispatch_get_main_queue(),
^{
// Recall
[self textViewDidChange:pTextView];
});
return;
}
... your code ...
}