[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开发与分享

【Android】RecyclerView的使用

2515
来自专栏向治洪

ListView专题

ListView专题 1.ListView属性: fadingEdge属性 ListView上边和下边有黑色的阴影,android : fadingEdge ...

1698
来自专栏拂晓风起

Stage3d AGAL GPU处理照片 旧照片效果 sepia || pixelbender

943
来自专栏学海无涯

Android开发之GridView实现弹出式选择器

前段时间,写了一个小项目,里面有个界面如下图所示,之前的版本是用Spinner来做,觉得不够拉轰,所以采用GridView做了一个实现,效果还不错,Mark一下...

2805
来自专栏Android机器圈

GridView结合tablayout实现展开收缩功能

PS:最近有一些粉丝给我留言说怎么实现那种 上面多个item,然后可以展开收缩,当点击了item后下方会出现一些数据,而且item对应多个型号,我当时看到这也...

4278
来自专栏项勇

笔记11 | 动态设置TextView的字体大小

1676
来自专栏Flutter入门

Android OpenGL ES(七) - 生成抖音照片电影

之前我们结合相机和视频,结合滤镜,做了实时的预览和录制。 这期,我们来试试利用OpenGL+MediaCodc,不进行预览直接录制成视频的情况。

1033
来自专栏向治洪

RecyclerView详解

RecyclerView是support-v7包中的新组件,是一个强大的滑动组件,与经典的ListView相比,同样拥有item回收复用的功能,但是直接把vi...

17510
来自专栏分享达人秀

ViewPager轻松完成TabHost效果

上一期学习了ViewPager的简单使用,本期一起来学习ViewPager的更多用法。 ? 相信很多同学都使用过今日头条APP吧,一打开主界面就...

2437
来自专栏向治洪

仿uc下部弹出菜单

先说说我怎么会无聊到这种地步去弄这个代码呢,在今年2月份的时候公司本来要做个这种弹出的菜单的,有5个按钮每个都有一个菜单,记得网上有仿UC菜单的源码,就下下来看...

1838

扫码关注云+社区