在IOS开发过程中,经常会有这种需求,需要通过点击状态栏返回到顶部,给用户更好的体验效果,下面这篇文章给大家详细介绍了实现过程,有需要的可以参考借鉴。
前言
大家都知道实现状态栏(statusBar)点击自动回到顶部效果,旨在为用户在浏览界面时提供便利,点击状态栏能够快速回到界面顶部,所以主要针对可以滚动的UIScrollView
和其子类UITableVIew
和UICollectionView
。
这里将从以下几个方面实现该功能。
1.苹果自带功能
分析:
首先,苹果自己已经提供了该功能,往上滑动tabView
,点击statusBar
,tableView
会自动回到初始位置。如下图所示,此时点击statusBar
,屏幕最上方显示的将是第一个cell
。在一个控制器上添加一个tabView
,那么默认点击statusBar
是可以自动回到顶部的。
既然苹果已经提供了该功能,我们直接拿来用就好了,干嘛还要自己实现呢?
其实不然,在一些情况下该功能是无效的。比如,在窗口上同时存在两个或两个以上UIScrollView
或其子类时。例如,将上面的tabView
先添加到一个scrollView
上,然后再将该scrollView
添加到控制器的View
上,此时点击statusBar
,tabView不能自动回到顶部。
因为,该效果是否有效,与 scrollsToTop
属性相关。查看官方文档,以下几点值得注意:
1.默认情况下scrollsToTop
是为YES的,只有当该属性为YES时,点击statusBar
才有效。
2.该效果是让距离statusBar
最近的ScrollView
自动回到顶部
3.在iPhone屏幕上方,当存在多个ScrollView
(或其子类),如果scrollsToTop= YES
的ScrollView
超过一个,所有ScrollView
都不会响应statusBar
的点击。
小结:
从上面分析我们可以得出结论:我们必须保证窗口上scrollsToTop == YES
的ScrollView
(及其子类)同一时间内有且只有一个。这一样才能保证点击statusBar,该唯一存在的ScrollView
能自动回到顶部。
如何保证苹果自带的该功能一直好使呢?
解决办法:我们希望回到顶部的ScrollView
的scrollsToTop =YES
,其他scrollsToTop = NO
。
有时,为了满足某种需求,我们在一个scrollView
上面会添加多个TabView
,实现上下滑动显示cell
的不同内容,左右滑动可以切换不同的tabView
,这时点击statusBar
是没有效果的。因为所有的scrollView
的scrollsToTop =YES
。要想展示每个TableView
时,点击statusBar
都有效,必须让除了展示在最上面的TabView
以外的所有的ScrollView
的scrollsToTop =NO
。这就需要去判断,到底显示的是哪一个TabView
。
参考代码如下:
1.让最下面的scrollView
,scrollsToTop =NO
。其他TableView
都是该scrollView
的子类。
2.遍历判断
// 控制scrollView的scrollsToTop属性
for (NSInteger i = 0; i < self.childViewControllers.count; i++) {
UIViewController *childVc = self.childViewControllers[i];
// 如果控制器的view没有被创建,跳过
if (!childVc.isViewLoaded) continue;
// 如果控制器的view不是scrollView,就跳过
if (![childVc.view isKindOfClass:[UIScrollView class]]) continue;
// 如果控制器的view是scrollView
UIScrollView *scrollView = (UIScrollView *)childVc.view;
scrollView.scrollsToTop = (i == index);
}
2.自己实现
在statusBar
的区域添加一个遮盖,监听遮盖的点击事件。
UIView
首先我们想到用UIView
来做这个遮盖。但是,在这里我们使用UIView
是着不住statusBar
的,UIView
会一直在statusBar
的下面,所以不能接收点击事件。因为statusBar
其实是一个UIWindow
,且优先级高于下面的keyWindow
。所以,添加的UIView
会在statusBar
的下面。
UIWindow
由于优先级的关系,我们可以用一个UIWindow
来做遮盖,设置遮盖window
的优先级高于statusBar
即可。当然,设置最高优先级(UIWindowLevelAlert
)肯定是可以的。然后给遮盖Window
添加一个点击事件,背景色设置透明即可。
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
UIWindow * coverWindow =[[UIWindow alloc]initWithFrame:CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 20)];
self.coverWindow = coverWindow;
coverWindow.hidden = NO;
coverWindow.backgroundColor = [UIColor redColor];
coverWindow.windowLevel = UIWindowLevelAlert;
//添加手势
UITapGestureRecognizer *tap = [[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(coverWindowClick)];
[self.coverWindow addGestureRecognizer:tap];
});
- (void)coverWindowClick {
[UIView animateWithDuration:0.5 animations:^{
self.tableView.contentOffset = CGPointMake(0, 0);
}];
}
AppDelegate中直接监听statusBar的点击
在AppDelegate
中实现touchesBegan:
方法
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
if ([touches.anyObject locationInView:nil].y > 20) return;
[[NSNotificationCenter defaultCenter]postNotificationName:@"click" object:nil];
}
接收通知,修改tabView
的contentOffset
- (void)coverWindowClick {
[UIView animateWithDuration:0.5 animations:^{
self.tableView.contentOffset = CGPointMake(0, 0);
}];
}
总结
以上就是这篇文章的全部内容,希望对大家开发IOS能有所帮助,如果有疑问大家可以留言交流,谢谢大家对编程学习网的支持。
本文标题为:iOS实现点击状态栏自动回到顶部效果详解
基础教程推荐
- Android实现短信验证码输入框 2023-04-29
- iOS开发 全机型适配解决方法 2023-01-14
- Android开发Compose集成高德地图实例 2023-06-15
- iOS Crash常规跟踪方法及Bugly集成运用详细介绍 2023-01-18
- iOS中如何判断当前网络环境是2G/3G/4G/5G/WiFi 2023-06-18
- IOS获取系统相册中照片的示例代码 2023-01-03
- MVVMLight项目Model View结构及全局视图模型注入器 2023-05-07
- Flutter进阶之实现动画效果(三) 2022-10-28
- iOS开发使用XML解析网络数据 2022-11-12
- Android Compose自定义TextField实现自定义的输入框 2023-05-13