zoukankan      html  css  js  c++  java
  • 判断android中ScrollView的开始和结束滚动

    如何判断一个ScrollView滚动时的开始和结束呢,经过测试,可以通过小弟以下的方法实现,但不一定精准。希望各位大侠能够有更为精确和奇妙的方法,小的拭目以待呀……

    1.继承一个ScrollView,重写onScrollChanged方法。
    2.添加如下两个方法:private void onScrollFinished() {}
    private void onScrollStart() {}
    3.用一个变量标志当前状态:boolean isStart = false;初始为不滚动……
    4.定义一个线程进行检测当前位置,class ScrollListener extends Thread……
    5.开始滚动会调用onScrollChanged方法,所以,判断开始其实直接可以在这个方法里面做你想做的事情,但是,这个方法会在滚动的过程中不断的调用……
    6.下面贴下主要代码吧:
    protected void onScrollChanged(int l, int t, int oldl, int oldt) { 
    onScrollStart();
      super.onScrollChanged(l, t, oldl, oldt); 
     }
      private void onScrollFinished() 
    { ...... } 
     private void onScrollStart() 
    { if (!isStart)
      { isStart = true; new  ScrollListener ().start(); } }
     
    class ScrollListener extends Thread
      { int oldX, oldY; public ScrollListener(int oldx, int oldy) 
    { this.oldX = oldx; this.oldY = oldy; }
      public void run()
      
     try { Thread.sleep(1000); } catch (InterruptedException e) {  e.printStackTrace(); } while (isStart) 
    { int newX = GetScrollX(); int newY = GetScrollY(); 
     if (newX == oldX && newY == oldY)
      { onScrollFinished(); isStart = false; } 
    else { oldX = newX; oldY = newY; } 
     } 
     } 
     }
  • 相关阅读:
    扩展的局域网
    参数估计
    以太网的 MAC 层
    poj 1523Tarjan算法的含义——求取割点可以分出的连通分量的个数
    tarjan算法--求解无向图的割点和桥
    spfa负环判断
    codeforce 489d bfs分层处理
    并查集优化——压缩路径——秩优化
    SPFA_queue_链式前向星最短路 & HDU2433
    POJ3046选蚂蚁创建集合_线性DP
  • 原文地址:https://www.cnblogs.com/622698abc/p/2727007.html
Copyright © 2011-2022 走看看