onTouchEvent(二) 使用Scroller实现黏性滑动的ScrollView

本文介绍如何结合Scroller和手势操作,创建一个具有黏性滑动效果的自定义ScrollView。通过复写onMeasure(), onLayout(), onTouchEvent()和computeScroll()方法,限制滚动范围并实现平滑过渡。当手指松开时,视图会根据当前位置自动滑动到顶部或底部。详细讲解了每个关键函数的作用和实现过程。" 88814252,8464102,使用iView上传并解析Excel数据教程,"['iView', '上传组件', 'Excel处理', '前端框架', 'JavaScript']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文为楼主原创,转载请表明出处:http://blog.youkuaiyun.com/suma_sun/article/details/52900476
上一篇博文介绍了onTouchEvent()手势控制相关的一些坐标概念,这篇文章结合上一篇内容加上Scroller实现一个简单的带黏性滑动的ScrollView。

这里写图片描述

思路

  1. 滑动的时候判断最终偏移量是不是超出了子view(ViewGroup内容)的范围,如果超出了就限制不让其超出,这样就可以做出一个滑动的ScrollView并且不会滑出界
  2. 当松手(action_up)的时候判断当前偏移量在该子view的什么位置,如果小于三分之一就滑动回该view的头部,如果超出三分之二就滑动到下个view

首先看看我们需要做些什么,自定义View要复写的方法有好几个,我们要复写的有:
1. onMeasure()
2. onLayout()
3. onTouchEvent()
4. computeScroll()

因为是ViewGroup需要计算、定位子View所以需要复写1和2两个函数。
3不用说了,要实现滑动功能必须要实现的函数。
4这是配合Scroller使用的一个函数。

首先介绍下Scroller这个类,这个类是一个工具,并不是实际UI操作。这个工具提供的功能是提供差值计算,就像属性动画一样,要做一个平滑过渡的动画需要用到差值器来辅助提供偏移差值。

下面是一个不使用Scroller的Demo。
这里写图片描述

差别很明显。

onMeasure

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        //遍历子View,测量子View
        int count = getChildCount();
        for (int i = 0; i < count; i++) {
            View view = getChildAt(i);
            measureChild(view, widthMeasureSpec, heightMeasureSpec);
        }
        super.onMeasure(widthMeasureSpec, heightMeasureSpec);
    }

onMeasure()没什么好说的,遍历子view,测量子view。

onLayout

 @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b) {
//        这里的四个坐标都是以ViewGroup来参照的,而不是屏幕的原点 
//        top默认0
//        left默认0
//        right默认屏幕宽度,ViewGroup的布局mactch_parent
//        bottom默认屏幕高度,ViewGroup的布局mactch_parent
        int count = getChildCount();
        for (int i = 0; i < count; i++) {
            View view = getChildAt(i);
            //这个demo模仿垂直的ScrollView所以就没有累计宽度
            int right = view.getMeasuredWidth();
            //设置子View摆放位置
            //mMaxHeight初始化为0
            view.layout(l , mMaxHeight, right, mMaxHeight + view.getMeasuredHeight());
            mMaxHeight += view.getMeasuredHeight();
            //mHeights是一个集合,用于保存每个自view的高度,用于粘性滑动判断
            mHeights.add(mMaxHeight);
            if(right > mMaxWidth){
                mMaxWidth = right;
            }
        }
    }

要说明的都已经在注释上了。

onTouch

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值