当前位置:   article > 正文

监听ScrollView 的上下滑动_swiftui如何 监听 scrollview 滚动

swiftui如何 监听 scrollview 滚动

转载请注明:http://blog.csdn.net/wlytctw/article/details/51249821

最近在一些APP(新闻资讯)应用上看到当向上滑动列表的时候底部的导航栏隐藏、向下滑动的时候底部导航栏显示!
为此做出一下实现方式,重写ScrollView (滚动视图)

刚开始在重写ScrollView 的时候,觉得重写OnTouch 事件,但是当我们需要知道滑动了多少距离,是否滑到布局的顶部或者底部。可惜的是SDK并没有提供相应的方法,最终经过一番查找和了解发现了这个方法

/**
    Parameters:
     *@param l Current horizontal scroll origin.(水平滚动原点)
     *@param t Current vertical scroll origin.(垂直滚动原点)
     *@param oldl Previous horizontal scroll origin.(以前的水平滚动原点)
     *@param oldt Previous vertical scroll origin.(以前的垂直滚动原点)
     */
  @Override 
  protected void onScrollChanged(int l, int t, int oldl, int oldt) { 
   super.onScrollChanged(l, t, oldl, oldt);  
  }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

所以做出一下代码重写:


    @Override  
    protected void onScrollChanged(int l, int t, int oldl, int oldt) {  
        super.onScrollChanged(l, t, oldl, oldt);  
        Log.e("wangly", "onScrollChanged");
        if (oldt < t && ((t - oldt) > 15)) {// 向上  
            Log.e("wangly", "距离:"+(oldt < t) +"---"+(t - oldt));
            Log.d("TAG","向上滑动")

        }  else if (oldt > t && (oldt - t) > 15) {// 向下  
            Log.e("wangly", "距离:"+(oldt > t) +"---"+(oldt - t));
            Log.d("TAG"," 向下滑动")
        } 
    } 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

这样我们就可以在改方法中控制 底部导航的显示和隐藏

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/在线问答5/article/detail/780920
推荐阅读
相关标签
  

闽ICP备14008679号