[Android学习整理]之滚动布局的监听的和smoothScrollBy方法分析使用

地址

CSDN 地址:http://blog.csdn.net/xiangyong_1521/article/details/50957563

scroollview、listview、gridview是我们常用的滚动类型布局,应工作中的一个需求,需要监听这些布局的页面停留状态,以配合更新页面UI,然后通过按钮点击以控制这些页面的滚动;

目录

  • scroollview监听方法
  • listview监听方法
  • gridview监听方法
  • 通过smoothScrollBy()方法对页面进行控制

一、scroollview监听方法

private class ScrollListener implements OnScrollListener{  

        @Override  
        public void onScrollStateChanged(AbsListView view, int scrollState) {}  

        @Override  
        public void onScroll(AbsListView view, //报告滚动状态的视图  
         int firstVisibleItem,//第一个可见item的索引  
         int visibleItemCount,//可见item的数量  
         int totalItemCount)//项目列表中的适配器的数量  
          {  
            if (firstVisibleItem==0) {  
                View view2 = gridView.getChildAt(firstVisibleItem);  
                if (view2!=null) {  
                    Log.i("TAG","view2.getY()"+view2.getY()); //可获取到任何状态下的第一个可见item索引的getY()值
                    if (view2.getY() == 8) {//在顶部 更新UI  
                        button_up.setBackgroundResource(R.drawable.upb);//向上的键为灰色     
                        button_up.setClickable(false);//且不能按  
                    } else {  
                        button_up.setBackgroundResource(R.drawable.upg);//向上的键为白色     
                        button_up.setClickable(true);//能按  
                    }  
                }  
            }else{  
                button_up.setBackgroundResource(R.drawable.upg);//向上的键为白色     
                button_up.setClickable(true);//能按  
            }if ((firstVisibleItem+visibleItemCount)==totalItemCount) {  
                View view3 = gridView.getChildAt(totalItemCount-1-firstVisibleItem);//scrollview所占的高度  
                if (view3!=null) {  
                    Log.i("TAG","view3.getY()"+view3.getY());  
                    if (view3.getY() == 246) {//在底部  更新UI
                        button_down.setBackgroundResource(R.drawable.downb);    //向下的键为灰色  
                        button_down.setClickable(false);    //且不能按    
                    } else {  
                        button_down.setBackgroundResource(R.drawable.downg);    //向下的键为白色  
                        button_down.setClickable(true); //能按      
                    }  
                }  
            }else{//在中部  更新UI
                button_down.setBackgroundResource(R.drawable.downg);    //向下的键为白色  
                button_down.setClickable(true); //能按      
            }  
        }  
    }

此方法调用OnScrollListener接口来实现Scroll页面的监听,在方法onScroll内,我们可以拿到几个重要的数值,在实际的使用中,可以打印这些数据,以配合功能的实现!


二、listview监听方法

ListView().setOnScrollListener(new OnScrollListener() {  
           @Override  
           public void onScrollStateChanged(AbsListView view, int scrollState) {  
           }  

           @Override  
           public void onScroll(AbsListView view, 
              int firstVisibleItem, //第一个可见item的索引 
              int visibleItemCount,  //可见item的数量  
              int totalItemCount) //项目列表中的适配器的数量
              {  
               if(firstVisibleItem==0){  
                   Log.e("log", "滑到顶部");  
               }  
               if(visibleItemCount+firstVisibleItem==totalItemCount){  
                   Log.e("log", "滑到底部");  
               }  
           }  
       });

listview的监听方法更简单明了,也是调用的setOnScrollListener监听,在onScroll方法内直接计算几个数值即可实现监听。


三、gridview监听方法

@Override  
        public void onScrollChanged(ObservableScrollView observableScrollView,  
                int x, int y, int oldx, int oldy) {  
                int scrollY=observableScrollView.getScrollY();//顶端以及滑出去的距离  
                int height=observableScrollView.getHeight();//界面的高度  
                int scrollViewMeasuredHeight=observableScrollView.getChildAt(0).getMeasuredHeight();//scrollview所占的高度  
            if(scrollY==0){//在顶端的时候  
                button_up.setBackgroundResource(R.drawable.upb);//向上的键为灰色     
                button_up.setClickable(false);//且不能按  
            }else if((scrollY+height)==scrollViewMeasuredHeight){//当在底部的时候  
                button_down.setBackgroundResource(R.drawable.downb);    //向下的键为灰色  
                button_down.setClickable(false);    //且不能按    
            }else {//当在中间的时候  
                button_down.setBackgroundResource(R.drawable.button_down);//向下为白色  
                button_down.setClickable(true); //可点击  
                button_up.setClickable(true);//可点击  
                button_up.setBackgroundResource(R.drawable.button_up);  //向上的键为白色  
            }  
        }

四、通过smoothScrollBy()方法对页面进行控制

button_down.setOnClickListener(new OnClickListener() {  
    @Override  
    public void onClick(View v) {  
        if(true){  
            if(type==1){  
                includeView2.smoothScrollBy(1000, 470);  
            }else{  
                gridView.smoothScrollBy(300, 1000);  
            }else{  
                listView.smoothScrollBy(300, 1000);  
            }  
        }  
    }  
});  
button_up.setOnClickListener(new OnClickListener() {  
    @Override  
    public void onClick(View v) {  
        if(true){  
            if(type==1){  
                includeView2.smoothScrollBy(1000, -470);  

            }else{  
                gridView.smoothScrollBy(-300, 1000);  
            }else{  
                listView.smoothScrollBy(-300, 1000);  
            }  
        }  
    }  
});

通过smoothScrollBy,我们可以控制页面的滚动,我们看下在HorizontalScrollView类中的smoothScrollBy,smoothScrollTo的源码:

/** 
     * Like {@link View#scrollBy}, but scroll smoothly instead of immediately. 
     * 
     * @param dx the number of pixels to scroll by on the X axis 
     * @param dy the number of pixels to scroll by on the Y axis 
     */  
    public final void smoothScrollBy(int dx, int dy) {  
        if (getChildCount() == 0) {  
            // Nothing to do.  
            return;  
        }  
        long duration = AnimationUtils.currentAnimationTimeMillis() - mLastScroll;  
        if (duration > ANIMATED_SCROLL_GAP) {  
            final int width = getWidth() - mPaddingRight - mPaddingLeft;  
            final int right = getChildAt(0).getWidth();  
            final int maxX = Math.max(0, right - width);  
            final int scrollX = mScrollX;  
            dx = Math.max(0, Math.min(scrollX + dx, maxX)) - scrollX;  

            mScroller.startScroll(scrollX, mScrollY, dx, 0);  
            postInvalidateOnAnimation();  
        } else {  
            if (!mScroller.isFinished()) {  
                mScroller.abortAnimation();  
            }  
            scrollBy(dx, dy);  //调用View的scrollBy(x.y)方法  
        }  
        mLastScroll = AnimationUtils.currentAnimationTimeMillis();  
    }  

    /** 
     * Like {@link #scrollTo}, but scroll smoothly instead of immediately. 
     * 
     * @param x the position where to scroll on the X axis 
     * @param y the position where to scroll on the Y axis 
     */  
    public final void smoothScrollTo(int x, int y) {  
        smoothScrollBy(x - mScrollX, y - mScrollY);  
    }

smoothScrollBy(x,y)方法在判断滑动间隔的时间长短后判定是一蹴而就还是慢慢滑向终点,关键方法是调用View的srcoll(x,y)方法,或借助scroller,这里x,y也是相对改变的值。


预告

下一篇,我将整理下scrollTo,scrollBy,smoothScrollBy,smoothScrollTo的资料,以对页面滑动相关的方法有更加清晰的认识。

原文发布于微信公众号 - 项勇(xiangy_life)

原文发表时间:2017-09-02

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏三好码农的三亩自留地

Android-教你写小米系统应用--"我的小米"

前面的文章中,我们已经了解了如何去自定义一个ViewGroup,可以在onLayout中自由的对子View进行位置设定,我们今天这里刚好需要对上面需求提到的三部...

1352
来自专栏学海无涯

Android开发之ListView使用经验分享

在Android开发中,ListView是使用最广泛的组件之一,虽然谷歌推出了RecycleView,但是很多项目中依旧在使用ListView,本文将总结一下使...

3076
来自专栏Android干货园

Android--仿淘宝商品详情(继续拖动查看详情)及标题栏渐变

版权声明:本文为博主原创文章,转载请标明出处。 https://blog.csdn.net/lyhhj/article/details/80...

1101
来自专栏李蔚蓬的专栏

实战 | 使用揭露动画(Reveal Effect)做一个丝滑的Activity转场动画

最近跟几个小伙伴在实践一个项目,考虑到界面效果,我们决定使用揭露动画作为Activity的转场动画。

1343
来自专栏计算机编程

点击显示更多文本自定义控件

写在前面的话: 在正常项目流程中,我们很多情况下会碰到点击显示更多文本,这样可以利于页面变化加载,点击显示更多可能会非常常用,现在博主利用自己的闲暇时间来一点一...

1223
来自专栏Android开发指南

7.侧滑、ViewDragHelper、属性动画

2955
来自专栏程序员叨叨叨

【Android】手把手教你上滑解锁的效果

最近,公司开发的APP中要实现类似上滑解锁效果的推荐页,捣腾了两天,基本实现了效果,附效果图如上。接下来和大家聊聊如何实现这样的效果。

3792
来自专栏移动开发

FruitLoadView 一个自定义view可用来做加载view

Github地址:https://github.com/X-FAN/FruitLoadView 欢迎star

832
来自专栏三好码农的三亩自留地

打造Android微信朋友圈下拉刷新控件

我们初步分析下,界面上主要有二个控件,一个彩虹状的圆形LoadingView,一个是ListView,那么我大致可以有下面三个步骤:

2112
来自专栏androidBlog

你真的了解View的坐标吗?

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/gdutxiaoxu/article/details/...

712

扫码关注云+社区