UIScrollView回滚到顶部解决方案

UIScrollView回滚到顶部解决方案

  • 根据系统的不同分成两种情况
    • iOS9之前,如果页面上有两个UIScroolView,那么点击导航栏将没有反应
    • iOS9之后(包括iOS9),页面内多个UIScrollView,点击导航栏将根据不同情况,回滚不同的UIScroolView

iOS9之前的处理方案

  • 其实现在写这个方案意义不是很大,iOS11正式版很快就要发布了,对于系统的适配,iOS9-11就可以了,iOS8基本上可以放弃了
  • 先说一下思路
    • 需要拦截点击导航栏操作-使用UIWindow,在导航栏上面覆盖一层没有颜色的window,级别设置到最高
    • 拦截点击操作之后,遍历keyWindow上所有的子控件
    • 判断这个子控件是否是UIScrollView
    • 判断这个子控件是否显示在keyWindow上
    • 都满足之后将找到的子控件的contentOffset的y值设置为0即可
  • 这种方式的不足之处:如果有两个UIScrollView都在屏幕上面,都是垂直滚动,那么点击之后,两个都会回到顶部,想要解决个问题,就需要进一步判断是哪一个UIScrollView
// 顶部的window,覆盖在状态栏上面,点击之后将window上显示的scrollView滑动到顶部
#import <Foundation/Foundation.h>

@interface YWTopWindow : NSObject

+ (void)show;

+ (void)hide;

@end


#import "YWTopWindow.h"
#import "UIView+YWExtension.h"

@implementation YWTopWindow

static UIWindow *window_;

+ (void)initialize
{
    window_ = [[UIWindow alloc] init];
    window_.frame = CGRectMake(0, 0, [UIScreen mainScreen].bounds.size.width, 20);
    window_.backgroundColor = [UIColor clearColor];
    // 将级别设置为最高,这样就能盖住状态栏
    window_.windowLevel = UIWindowLevelAlert;
    [window_ addGestureRecognizer:[[UITapGestureRecognizer alloc] initWithTarget:self action:@selector(windowClick)]];
}

+ (void)show
{
    // iOS9之前,可以直接写window_.hidden = NO;
    // 在iOS9之后,直接写会报错,大概的意思就是:在程序启动结束后,window需要有一个根控制器
    // Application windows are expected to have a root view controller at the end of application launch
    dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.25 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
        window_.hidden = NO;
    });
}

+ (void)hide
{
    window_.hidden = YES;
}


/**
 窗口点击
 */
+ (void)windowClick
{
    UIWindow *window = [UIApplication sharedApplication].keyWindow;
    [self searchScrollViewInView:window];
}

+ (void)searchScrollViewInView:(UIView *)superview
{
    for (UIScrollView *subView in superview.subviews) {
        // 如果是UIScrollView,滚动到最顶部
        if([subView isKindOfClass:[UIScrollView class]] && subView.isShowingOnKeyWindow){
            CGPoint offset = subView.contentOffset;
            offset.y = - subView.contentInset.top;
            [subView setContentOffset:offset animated:YES];
        }
        // 不是UIScrollView或者不是显示在keyWindow上,继续寻找
        [self searchScrollViewInView:subView];
    }
}
@end

// 写在UIView的分类中的方法
// 判断一个控件是否显示在主窗口上面
- (BOOL)isShowingOnKeyWindow
{
    // 主窗口
    UIWindow *keyWindow = [UIApplication sharedApplication].keyWindow;
    
    // 以主窗口左上角为坐标原点,计算self的矩形框
    CGRect newFrame = [keyWindow convertRect:self.frame fromView:self.superview];
    CGRect winBounds = keyWindow.bounds;
    
    // 主窗口的bounds和self的矩形框是否有重叠
    BOOL intersects = CGRectIntersectsRect(newFrame, winBounds);
    
    return !self.isHidden && self.alpha > 0.01 && self.window == keyWindow && intersects;
}

iOS9之后(包含iOS9)

  • 页面上两个UIScrollView,类似今日头条的布局,第一个横向滑动,第二个也是横向滑动,但是里面有好多UITableView
    • 这种可以不用管,系统会自动将当前显示的UITableView滑动到顶部
  • 页面上有两个UIScrollView,都是垂直滚动,两个都显示在页面上
    • 左右分布,那么点击导航栏位置在那个控件上方,滚动那个UIScrollView
    • 上下分布,点击导航栏时,上方的控件在初始位置,那么滚动下方的控件,如果上方的有滚动过,那么就会将上方的UIScrollView滚动到最上方
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,298评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,701评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,078评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,687评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,018评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,410评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,729评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,412评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,124评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,379评论 2 242
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,903评论 1 257
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,268评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,894评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,014评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,770评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,435评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,312评论 2 260

推荐阅读更多精彩内容