HorizontalScrollView滑动位置的监听,及其判断处于顶部和底部

本文介绍如何使用HorizontalScrollView实现滑动监听,通过设置OnTouchListener并利用MotionEvent来判断滑动位置,实现加载数据和切换图标等功能。
  • HorizontalScrollView 中判断当前滑动的位置不像listview直接设置监听那么简单,我们可

以通过setOnTouchListener 设置监听来通过MotionEvent 判断。

  • 如下图
mSvTools.setOnTouchListener(new View.OnTouchListener() {
            @Override
            public boolean onTouch(View v, MotionEvent event) {
                switch (event.getAction()) {
                    case MotionEvent.ACTION_DOWN:

                        break;
                    case MotionEvent.ACTION_MOVE:

                        View firstView = ((HorizontalScrollView) v).getChildAt(0);
                        Log.d("TagX", "firstView.getMeasuredWidth()-----" + firstView
                                .getMeasuredWidth());
                        Log.d("TagX", " v.getScrollX()-----" + v.getScrollX());
                        Log.d("TagX", "v.getWidth-----" + v.getWidth());


                        if (firstView.getMeasuredWidth() <= v.getScrollX() + v.getWidth()) {
                            //加载数据代码
                            mIbShouqi.setBackgroundResource(R.drawable.image_zhankai);
                        } else if (v.getScrollX() <= 10) {
                            mIbShouqi.setBackgroundResource(R.drawable.image_shouqi);
                        }
                        break;
                    default:
                        break;
                }
                return false;
            }
        });

    }

根据输出的log信息,如下图:

这里写图片描述
这是起始位置时的情况。
这里写图片描述
这是滑动到终点时的情况。

  • getMeasuredWidth()方法得到的是整个HorizontalScrollView控件的宽度

  • 而getWidth得到的是显示在屏幕上的宽度

  • getScrollX则得到的是滑动的宽度

所以,firstView.getMeasuredWidth() <= v.getScrollX() + v.getWidth() 即为滑动到最右端

v.getScrollX() == 0为滑动到最左端

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值