如果我没有足够的拖动,我想恢复我的UIScrollView的内容偏移量:
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(CGPoint *)targetContentOffset {
self.endingOffset = scrollView.contentOffset;
if(abs(verticalOffset) > [self cellHeight] / 9) { // If the user scrolled enough distance, attempt to scroll to the next cell
...
} else if(self.nextCellOrigin.y != 0) { // The scroll view is still scrolling and the user didn't drag enough
...
} else { // If the user didn't drag enough
self.tableView.decelerationRate = UIScrollViewDecelerationRateNormal;
(*targetContentOffset) = self.startingOffset;
}
}
恢复到原始位置的代码位于else部分,它始终有效。但是,当我不够滚动并快速做出手势时,它会快速向后移动。如果我稍微滚动一下然后保持该位置的时间比平时略长,它会平稳地恢复。
我没有在API参考中找到用户触摸UIScrollView多长时间的任何内容,即使我这样做也不能立即明白如何使用它来改变我的还原代码的行为。我也尝试用setContentOffset滚动到这个位置:动画:但这似乎并没有解决这个急动。
有什么想法吗?
答案 0 :(得分:5)
您是否尝试记录速度以了解在急动发生时的速度?
修改强>:
你可以尝试做的是实现这两个scrollView委托方法而不是willEndDragging方法。这个解决方案会给scrollView带来不同的感觉,但试一试。
使用您需要的所有逻辑填充checkOffset
方法。
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate {
// if scrollView's contentOffset reached its final position during scroll, it will not decelerate, so you need a check here too
if (!decelerate) {
[self checkOffset];
}
}
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {
[self checkOffset];
}
- (void)checkOffset {
CGPoint newOffset;
...
// Do all the logic you need to move the content offset, then:
...
[self.scrollView setContentOffset:newOffset animated:YES];
}
编辑#2: 如果您也将此添加到我的解决方案中,也许您可以获得更好的结果..尝试;)
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(CGPoint *)targetContentOffset {
// This should force the scrollView to stop its inertial deceleration, by forcing it to stop at the current content offset
*targetContentOffset = scrollView.contentOffset;
}