iOS开发 - ScrollView滚动时怎么判断滚动停止及滚动的方向

简介: iOS开发 - ScrollView滚动时怎么判断滚动停止及滚动的方向

上一篇博客渐变导航栏中,在渐变的过程中需要判断滚动的方向,滚动停止,改变方向,这篇博客,博主将对这三个问题分别进行说明。


1.判断滚动停止


先看下代码:

- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
currentPostion = scrollView.contentOffset.y;
[NSObject cancelPreviousPerformRequestsWithTarget:self];              
[self performSelector:@selector(scrollViewDidEndScrollingAnimation:) withObject:nil afterDelay:0.00001];
}
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{
    [NSObject cancelPreviousPerformRequestsWithTarget:self];
    //有nav时一开始的偏移量为-64,所以这里加上了64,如果是自定义nav则没有这种情况
    stopPosition = currentPostion + 64;
    NSLog(@"滑动停止:%f",stopPosition);
}

这种方法判断的是scrollView停止滚动时的位置,请注意一点,是我们手动滑动,然后scrollView自然停止滚动后的位置,但是在操作中,几乎不会有人等到scrollView停止后才回去滑动界面,所以当你拿不到停止的位置,恰好又改变了方向的时候,停止的位置还是初始位置,在中部滚动时改变方向,nav就会消失,有兴趣的可以用代码尝试,为了解决这个问题,我们继续看下面。


2.判断改变方向

- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
    currentPostion = scrollView.contentOffset.y;
    if(currentPostion > lastPosition)
    {
        NSLog(@"Scroll Up");
    }
    else
    {
        NSLog(@"Scroll Down");
    }
    lastPosition = currentPostion;
   }

这里判断的是滚动的上下方向,但是博主觉得这部足矣判断未停止滚动强制改变方向时的位置,所以,有了下面的小方法。


3.判断改变方向时的位置

- (void)viewDidLoad {
    [super viewDidLoad];
     //一开始一定要设定向下滚动的标示,否则是进不去改变方向的if的,一开始我们认为只能向上滚动(scrollView的弹性可以向下拉一段距离,这个因为设置了便宜量大于0,所以可忽略)
    [[NSUserDefaults standardUserDefaults]setObject:@"1" forKey:@"first"];
    [[NSUserDefaults standardUserDefaults]synchronize];
}
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
    currentPostion = scrollView.contentOffset.y;
    if (currentPostion > 0) {
        if (currentPostion - _lastPosition >= 0) {
            //仔细看的话你会发现这里的if在每次改变方向时执行一次,在这里拿到当时的位置,然后删除标示,设定改变方向的标示,改变方向后的设置和这里一样的原理。所以,这里的代码每次改变方向时只执行一次,就无需判断停止时的位置,而是在改变方向时瞬间拿到当时的停止位置。不要说这里存在误差,执行的瞬间就可以拿到位置,所以误差几乎忽略不计。
            if ([[NSUserDefaults standardUserDefaults]objectForKey:@"first"]!=nil) {
                [[NSUserDefaults standardUserDefaults]removeObjectForKey:@"first"];
                [[NSUserDefaults standardUserDefaults]synchronize];
                [[NSUserDefaults standardUserDefaults]setObject:@"1" forKey:@"second"];
                [[NSUserDefaults standardUserDefaults]synchronize];
                //加64因为系统nav初始偏移量会为-64,自定义可不加
                stopPosition = currentPostion + 64;
            }
            _lastPosition = currentPostion;
            NSLog(@"Scroll Up    current:%f    last:%f    stop:%f",currentPostion,_lastPosition,stopPosition);
            self.navigationController.navigationBar.alpha = 1 - currentPostion / 400;
        }
        else
        {
            if ([[NSUserDefaults standardUserDefaults]objectForKey:@"second"]!=nil) {
                [[NSUserDefaults standardUserDefaults]removeObjectForKey:@"second"];
                [[NSUserDefaults standardUserDefaults]synchronize];
                [[NSUserDefaults standardUserDefaults]setObject:@"1" forKey:@"first"];
                [[NSUserDefaults standardUserDefaults]synchronize];
                stopPosition = currentPostion + 64;
            }
            _lastPosition = currentPostion;
            NSLog(@"Scroll Down    current:%f   last:%f    stop:%f",currentPostion,_lastPosition,stopPosition);
                      self.navigationController.navigationBar.alpha = (stopPosition - currentPostion)/200;
        }   
    } 
}

总结:其实仔细看的话,会发现上下的透明度在改变方向时是独立计算的,没有相关联,如果比较注意细节的话会发现nav会突兀的出现,所以需要把向上下滚动的透明度结合起来,博主改进后会发出来,各位也可以自己尝试下,思路很明了,一些小技巧就可以实现。

目录
相关文章
|
7天前
|
iOS开发 开发者
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
|
1月前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
125 66
|
18天前
|
存储 监控 API
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
|
1月前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
136 3
|
1月前
|
Java 调度 Android开发
安卓与iOS开发中的线程管理差异解析
在移动应用开发的广阔天地中,安卓和iOS两大平台各自拥有独特的魅力。如同东西方文化的差异,它们在处理多线程任务时也展现出不同的哲学。本文将带你穿梭于这两个平台之间,比较它们在线程管理上的核心理念、实现方式及性能考量,助你成为跨平台的编程高手。
|
2月前
|
存储 前端开发 Swift
探索iOS开发:从新手到专家的旅程
本文将带您领略iOS开发的奇妙之旅,从基础概念的理解到高级技巧的掌握,逐步深入iOS的世界。文章不仅分享技术知识,还鼓励读者在编程之路上保持好奇心和创新精神,实现个人成长与技术突破。
|
2月前
|
安全 IDE Swift
探索iOS开发之旅:从初学者到专家
在这篇文章中,我们将一起踏上iOS开发的旅程,从基础概念的理解到深入掌握核心技术。无论你是编程新手还是希望提升技能的开发者,这里都有你需要的指南和启示。我们将通过实际案例和代码示例,展示如何构建一个功能齐全的iOS应用。准备好了吗?让我们一起开始吧!
|
物联网 Android开发 iOS开发
iOS开发 - 蓝牙学习的总结
iOS开发 - 蓝牙学习的总结
200 0
|
iOS开发
IOS开发---菜鸟学习之路--(九)-利用PullingRefreshTableView实现下拉刷新
本章主要讲解如何利用PullingRefreshTableView实现下拉(上拉)刷新的操作  PullingRefreshTableView 实现上下拉刷新的例子百度有很多,大家可以自己搜索下,先看下那些例子(一般搜索过来的都是一样的大家反正先把那部分内容先了解一下,然后再看本文档比较好。
895 0
|
iOS开发 Android开发 存储
IOS开发---菜鸟学习之路--(十)-实现新闻详细信息浏览页面
前面已经将了上下拉刷新 实现了上下拉刷新后我们的第一级界面就做好,接下来我们就需要实现 新闻详细信息浏览了 我个人认为一般实现新闻详细页面的方法有两种(主要是数据源的不同导致了方法的不同) 第一种是本身新闻就是一个链接地址,同时是已经处理好的适应手机浏览的网页 对于这种类型的数据源,我们直接在页面中放一个WebView控件,然后将URL传递过去就好了 另一种则是普通的包含标题、时间、内容、图片等数据结构的新闻内容(我们要实现的也是这种新闻,因为实现了这种之后, 我们就可以实现任何自定义的详细信息的页面了。
893 0

热门文章

最新文章