zoukankan      html  css  js  c++  java
  • 下拉刷新和上拉载入的原理

                非常多App中,新闻或者展示类都存在下拉刷新和上拉载入的效果,网上提供了实现这样的效果的第三方类(详情请见MJRefreshEGOTableViewPullRefresh),用起来非常方便,可是闲暇之余,我们能够思考下,这样的效果实现的原理是什么,我曾经说过,仅仅要是动画都是骗人的,仅仅要不是硬件问题大部分效果都能在系统UI的基础上做出来.

                @以下是关键代码分析:

    // 下拉刷新的原理
    - (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView
    {
        if (scrollView.contentOffset.y < - 100) {
            
            [UIView animateWithDuration:1.0 animations:^{
                
                //  frame发生偏移,距离顶部150的距离(可自行设定)
                self.tableView.contentInset = UIEdgeInsetsMake(150.0f, 0.0f, 0.0f, 0.0f);
            } completion:^(BOOL finished) {
                
                /**
                 *  发起网络请求,请求刷新数据
                 */
    
            }];
        }
    }
    
    // 上拉载入的原理
    - (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
    {
        
        NSLog(@"%f",scrollView.contentOffset.y);
        NSLog(@"%f",scrollView.frame.size.height);
        NSLog(@"%f",scrollView.contentSize.height);
        /**
         *  关键-->
         *  scrollView一開始并不存在偏移量,可是会设定contentSize的大小,所以contentSize.height永远都会比contentOffset.y高一个手机屏幕的
         *  高度;上拉载入的效果就是每次滑动究竟部时,再往上拉的时候请求很多其它,那个时候产生的偏移量,就能让contentOffset.y + 手机屏幕尺寸高大于这
         *  个滚动视图的contentSize.height
         */
        if (scrollView.contentOffset.y + scrollView.frame.size.height >= scrollView.contentSize.height) {
            
            NSLog(@"%d %s",__LINE__,__FUNCTION__);
            [UIView commitAnimations];
            
            [UIView animateWithDuration:1.0 animations:^{
                //  frame发生的偏移量,距离底部往上提高60(可自行设定)
                self.tableView.contentInset = UIEdgeInsetsMake(0, 0, 60, 0);
            } completion:^(BOOL finished) {
                
                /**
                 *  发起网络请求,请求载入很多其它数据
                 *  然后在数据请求回来的时候,将contentInset改为(0,0,0,0)
                 */
            }];
    
        }
    }
    


  • 相关阅读:
    dubbo熔断,限流,服务降级
    jmeter命令行运行与生成报告
    Java堆内存设置
    性能测试之互联网应用需求建模分析
    java命令--jmap命令使用(查找内存泄漏对象)
    WPS宏不可用解决方法
    JDBC
    异常
    Java中常用集合操作
    java抽象、接口 和final
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/4279258.html
Copyright © 2011-2022 走看看