Android新姿式:能够下拉/上拉回弹的ListView原理(续)

上一次本身根据原理写了个下拉ListView,结果如今才发现,其实谷歌的码神早已经作了相关的实现代码了!!动画


但是为何直接用ListView看不到下拉效果呢?spa


其实这是由于版权的问题,这个下拉的效果是苹果先出的,你们也都知道苹果跟谷歌的版权纠纷,因此谷歌虽然也能作到下拉,但没有明确给出来,只是作了一个动画效果,就是拉到顶部或底部后继续拉会有个亮亮的光出现(注意是2.3以后的系统才有)。继承


接下来看看谷歌给咱们提供了什么。it


首先是View类内的overScrollBy方法。原理

    protected boolean overScrollBy(int deltaX, int deltaY,List

            int scrollX, int scrollY,scroll

            int scrollRangeX, int scrollRangeY,方法

            int maxOverScrollX, int maxOverScrollY,im

            boolean isTouchEvent) {lamp

        final int overScrollMode = mOverScrollMode;

        final boolean canScrollHorizontal =

                computeHorizontalScrollRange() > computeHorizontalScrollExtent();

        final boolean canScrollVertical =

                computeVerticalScrollRange() > computeVerticalScrollExtent();

        final boolean overScrollHorizontal = overScrollMode == OVER_SCROLL_ALWAYS ||

                (overScrollMode == OVER_SCROLL_IF_CONTENT_SCROLLS && canScrollHorizontal);

        final boolean overScrollVertical = overScrollMode == OVER_SCROLL_ALWAYS ||

                (overScrollMode == OVER_SCROLL_IF_CONTENT_SCROLLS && canScrollVertical);


        int newScrollX = scrollX + deltaX;

        if (!overScrollHorizontal) {

            maxOverScrollX = 0;

        }


        int newScrollY = scrollY + deltaY;

        if (!overScrollVertical) {

            maxOverScrollY = 0;

        }


        // Clamp values if at the limits and record

        final int left = -maxOverScrollX;

        final int right = maxOverScrollX + scrollRangeX;

        final int top = -maxOverScrollY;

        final int bottom = maxOverScrollY + scrollRangeY;


        boolean clampedX = false;

        if (newScrollX > right) {

            newScrollX = right;

            clampedX = true;

        } else if (newScrollX < left) {

            newScrollX = left;

            clampedX = true;

        }


        boolean clampedY = false;

        if (newScrollY > bottom) {

            newScrollY = bottom;

            clampedY = true;

        } else if (newScrollY < top) {

            newScrollY = top;

            clampedY = true;

        }


        onOverScrolled(newScrollX, newScrollY, clampedX, clampedY);


        return clampedX || clampedY;

    } 


其实View的这个方法已经帮咱们实现了下拉、上拉,甚至左拉右拉都实现了!!

但是为何ListView继承了View却没有实现下拉呢?


咱们接下来到ListView中的overScrollBy看一下。

protected boolean overScrollBy(int deltaX, int deltaY, int scrollX,

int scrollY, int scrollRangeX, int scrollRangeY,

int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent) {

L.d("deltaX=" + deltaX + ";deltaY=" + deltaY + ";scrollX=" + scrollX

+ ";scrollY=" + scrollY + ";scrollRangeX=" + scrollRangeX

+ ";scrollRangeY=" + scrollRangeY + ";maxOverScrollX="

+ maxOverScrollX + ";maxOverScrollY=" + maxOverScrollY);

return false;


根据我打印的结果,发现后面的maxOverScrollX、maxOverScrollY永远是0!!

原来如此,谷歌也真是机(jiao)智(hua),代码明明实现了,就是不明确摆出来,这样苹果也无话可说了。


那么知道了缘由,要实现也下拉也简单,自定义一个类继承ListView,重写overScrollBy方法便可。

protected boolean overScrollBy(int deltaX, int deltaY, int scrollX,

int scrollY, int scrollRangeX, int scrollRangeY,

int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent) {

return super.overScrollBy(deltaX, deltaY, scrollX, scrollY,

scrollRangeX, scrollRangeY, maxOverScrollX,

500, isTouchEvent);

上面的代码只是给maxOverScrollY硬性的给了个500的值,而后就能够下拉上拉了,很简单吧~~


PS:这种方法作出来的下拉ListView效果通常,也没有下拉刷新功能,若是要用到项目中的话,仍是去找开源的下拉列表吧~~ 

相关文章
相关标签/搜索