我怎样才能达到这个效果?
5 回答
从您的屏幕截图中不会立即注意到这一点,但我相信您希望该标题工具栏在用户滚动时向上滑动,对吗?(我建议澄清那部分)
您可以通过几种方式做到这一点,并且在所有这些方式中,您都必须实现自己的滚动逻辑,这意味着标题工具栏向上滑动的程度取决于您滚动的位置。也就是说,这是如何做到的:
1 . 如果您正在使用UITableView
,我假设您已将视图控制器设置为delegate
. 由于已经UITableView
是的子类UIScrollView
,只需将其添加UIScrollViewDelegate
到您的视图控制器。这将为我们提供滚动事件,因为它们发生了。你会想要在scrollViewDidScroll:
.
2 .. 如果您只是使用UIScrollView
,只需将您的视图控制器设置为其委托,实现UIScrollViewDelegate
并在scrollViewDidScroll:
.
也就是说,您的代码可能如下所示:
- (void) scrollViewDidScroll:(UIScrollView *)scrollView {
CGPoint scrollPos = scrollView.contentOffset;
if(scrollPos.y >= 40 /* or CGRectGetHeight(yourToolbar.frame) */){
// Fully hide your toolbar
} else {
// Slide it up incrementally, etc.
}
}
无论如何,希望我有所帮助。
如果您已正确设置委托,您的表格将在滚动时调用 scrollViewDidScroll:。
因此,在您的控制器中,您可以添加如下内容:
- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
if (scrollView.contentOffset.y >0) //means that the user began to scroll down the table
{
[UIView animateWithDuration:0.4 animations:^{
//animations you want to perform
}];
}
}
在这里,我在 tableview 滚动时实现了 UIView Hide / Show 的代码。当 tableview 向下滚动时 UIView 被隐藏,当向上滚动时 UIView 显示。我希望它对你有用......!
第 1 步:- 在 .h 文件中创建一个属性
@property (nonatomic) CGFloat previousContentOffset;
第 2 步:- 在 scrollViewDidScroll 方法中写下这段代码。
-(void)scrollViewDidScroll:(UIScrollView *)scrollView {
CGFloat currentContentOffset = scrollView.contentOffset.y;
if (currentContentOffset > self.previousContentOffset) {
// scrolling towards the bottom
[self.subButtonView setHidden:YES];
} else if (currentContentOffset < self.previousContentOffset) {
// scrolling towards the top
[self.subButtonView setHidden:NO];
}
self.previousContentOffset = currentContentOffset;
}
这将回答您的问题:
相同的概念,不同的控制。您可以将 UIView 放在 tableview 的第一行或任何其他相关控件(例如按钮)上。
祝你好运。