热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

Androidscrollview如何监听滑动状态

这篇文章主要介绍了Androidscrollview监听滑动状态的实例代码,代码简单易懂,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

ScrollView

视图的滚动过程,其实是在不断修改原点坐标。当手指触摸后,ScrollView会暂时拦截触摸事件,使用一个计时器。假如在计时器到点后没有发生手指移动事件,那么ScrollView发送tracking events到被点击的subView;若是在计时器到点后发生了移动事件,那么ScrollView取消tracking自己促发滚动。

首先说一下 NestedScrollView 的滑动事件的监听,

如果使用 

nestedScrollView.setOnScrollChangeListener(new View.OnScrollChangeListener() {
      @Override
      public void onScrollChange(View v, int scrollX, int scrollY, int oldScrollX, int oldScrollY) {
 
      }
    });

这个方法在 API >= 23  时才可以使用,怎么解决呢 。我们可以自己定义一个ScrollView

public class MyScrollView extends NestedScrollView {
   private OnScrollChanged mOnScrollChanged;
  public MyScrollView(Context context) {
    this(context, null);
  }
  public MyScrollView(Context context, AttributeSet attributeSet) {
    this(context, attributeSet, 0);
  }
  public MyScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
  }
  @Override
  protected void onScrollChanged(int l, int t, int oldl, int oldt) {
    super.onScrollChanged(l, t, oldl, oldt);
    if (mOnScrollChanged != null) {
      mOnScrollChanged.onScroll(l, t, oldl, oldt);
    }
  }
  public void setOnScrollChanged(OnScrollChanged onScrollChanged) {
    this.mOnScrollChanged= onScrollChanged;
  }
  public interface OnScrollChanged {
    void onScroll(int l, int t, int oldl, int oldt);
  }
}

这样我们就可以通过实现 onScrollChanged() 监听滑动事件了 ,其中可以监测到滑动距离,这样就可以做好多事情了;

但是现在有一个需求就是【滑动的时候隐藏 一个靠边的悬浮框,不滑动是悬浮框显示出来】,这样的话就需要监测滑动状态了。scrollview 不像recyclerview一样可以监测滑动状态。

以下是我的一个实现方案,通过CountDownTimer 来实现

在刚才的onScrollChanged  接口中增加方法

public interface OnScrollChanged {
    void onScroll(int l, int t, int oldl, int oldt);
 
    void onTouch(boolean isDown);
  }

然后重写onTouchEvent方法

@Override
  public boolean onTouchEvent(MotionEvent ev) {
      switch (ev.getAction()) {
      case MotionEvent.ACTION_UP:
      case MotionEvent.ACTION_CANCEL:
        if (mOnScrollChanged != null) {
          mOnScrollChanged.onTouch(false);
        }
        break;
      case MotionEvent.ACTION_DOWN:
      case MotionEvent.ACTION_MOVE:
        if (mOnScrollChanged != null) {
          mOnScrollChanged.onTouch(true);
        }
        break;
    }
    return super.onTouchEvent(ev);
  }

这里的isDown=true代表是按下或者滑动的状态,对应ACTION_DOWN和ACTION_MOVE,fale代表ACTION_UP和ACTION_CANCEL

下面使用这个自定义的scrollerview

//静止状态
private final static int SCROLL_STATE_IDLE = 1;
//拖动或者惯性滑动状态
private final static int SCROLL_STATE_SCROLL = 2;
 
//判断是否是拖动状态
boolean isDragState = false;
 
int currentState = SCROLL_STATE_IDLE;
 
//这里采用100ms来判断是否已经是静止状态,100ms结束后证明是静止状态
private CountDownTimer scrollCountTimer = new CountDownTimer(100, 1) {
    @Override
    public void onTick(long millisUntilFinished) {
 
    }
 
    @Override
    public void onFinish() {
      setScrollState(SCROLL_STATE_IDLE);
    }
};
 
private void initScrollView() {
    scrollView.setOnScrollChanged(new MyScrollView.OnScrollChanged() {
      @Override
      public void onScroll(int l, int t, int oldl, int oldt) {
        if (isDragState) {//拖动状态单独处理不再进行滚动状态监测
          return;
        }
        //滑动时先取消倒计时,设置滑动状态
        scrollCountTimer.cancel();
        if(currentState != SCROLL_STATE_SCROLL) {
          setScrollState(SCROLL_STATE_SCROLL);
        }
        scrollCountTimer.start();
      }
 
      @Override
      public void onTouch(boolean isDown) {
        isDragState = isDown;
        //我这里把按下的状态默认为了滚动的状态,当然你也可以分开定义
        if (isDown) {
          scrollCountTimer.cancel();
          setScrollState(SCROLL_STATE_SCROLL);
        } else {
          scrollCountTimer.start();
        }
      }
});
//最后记得页面销毁时,cancel掉timer

总结

以上所述是小编给大家介绍的Android scrollview如何监听滑动状态,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!


推荐阅读
  • Vue 2 中解决页面刷新和按钮跳转导致导航栏样式失效的问题
    本文介绍了如何通过配置路由的 meta 字段,确保 Vue 2 项目中的导航栏在页面刷新或内部按钮跳转时,始终保持正确的 active 样式。具体实现方法包括设置路由的 meta 属性,并在 HTML 模板中动态绑定类名。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍如何使用arm-eabi-gdb调试Android平台上的C/C++程序。通过具体步骤和实用技巧,帮助开发者更高效地进行调试工作。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文将详细介绍如何使用剪映应用中的镜像功能,帮助用户轻松实现视频的镜像效果。通过简单的步骤,您可以快速掌握这一实用技巧。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
author-avatar
koujj
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有