[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 条评论
登录 后参与评论

相关文章

来自专栏跟着阿笨一起玩NET

c#实现打印功能

2932
来自专栏pangguoming

Spring Boot集成JasperReports生成PDF文档

由于工作需要,要实现后端根据模板动态填充数据生成PDF文档,通过技术选型,使用Ireport5.6来设计模板,结合JasperReports5.6工具库来调用渲...

1.2K7
来自专栏菩提树下的杨过

Flash/Flex学习笔记(23):运动学原理

先写一个公用的小球类Ball: package{ import flash.display.Sprite; //小球 类 public class B...

25410
来自专栏Ceph对象存储方案

Luminous版本PG 分布调优

Luminous版本开始新增的balancer模块在PG分布优化方面效果非常明显,操作也非常简便,强烈推荐各位在集群上线之前进行这一操作,能够极大的提升整个集群...

3265
来自专栏魂祭心

原 canvas绘制clock

4294
来自专栏陈仁松博客

ASP.NET Core 'Microsoft.Win32.Registry' 错误修复

今天在发布Asp.net Core应用到Azure的时候出现错误InvalidOperationException: Cannot find compilati...

4878
来自专栏芋道源码1024

熔断器 Hystrix 源码解析 —— 断路器 HystrixCircuitBreaker

本文主要基于 Hystrix 1.5.X 版本 1. 概述 2. HystrixCircuitBreaker 3. HystrixCircuitBreaker....

5417
来自专栏我和未来有约会

Silverlight第三方控件专题

这里我收集整理了目前网上silverlight第三方控件的专题,若果有所遗漏请告知我一下。 名称 简介 截图 telerik 商 RadC...

4095
来自专栏一个会写诗的程序员的博客

Spring Reactor 项目核心库Reactor Core

Non-Blocking Reactive Streams Foundation for the JVM both implementing a Reactiv...

2232
来自专栏大内老A

The .NET of Tomorrow

Ed Charbeneau(http://developer.telerik.com/featured/the-net-of-tomorrow/) Exciti...

32710

扫码关注云+社区