自定义ScrollView,实现导航条悬浮置顶

本文详细介绍了如何自定义ScrollView以实现导航条在滚动时始终保持悬浮置顶的效果。关键点包括:当ScrollView内嵌ListView时,需重写onMeasure方法设置ListView高度;解决滑动事件冲突,可通过重写onInterceptTouchEvent来控制事件分发。通过实例代码和布局设计,展示了如何在顶部布局使用相对布局确保悬浮组件的正确显示。
摘要由CSDN通过智能技术生成

Android ScrollView向上滑动控件顶部悬浮效果实现
* 导航栏实现悬浮置顶效果(顶部图片隐藏,下面的单选框导航悬浮)
【上滑停靠顶端的悬浮框】里的实现方法是使用两个控件,滑动时,监听ScrollView的滚动Y值,
* 从而通过对两个控件的显示隐藏来实现控件的顶部悬浮。但是实际应用场景中,
* 有可能需要悬浮的控件里面的内容是比较多的,如果通过显示隐藏的方式来实现的话,
* 操作控件里的内容时,需要重复定义两套变量,对控件里的内容进行修改时也是要操作再次,非常麻烦。
本文的方法是通过addViewremoveView来实现的


	当外面嵌套一层ScrollView后,就能做上下或左右滑动,但能滑动多少系统不知道,
* 	这时就需要你给计算出一个滑动区域给ScrollView


知识点:

1、当ScrollView垂直滚动视图中嵌套ListView时,ListView必须重写onMeasure方法,返回高度和大小,否则,只会显示一行布局!!!


2、滑动事件会有冲突:重写
onInterceptTouchEvent方法(或者其他事件的方法),根据情况获得事件!



首先继承ScrollView类:

public class HoveringScrollview extends ScrollView {
    private OnScrollListener onScrollListener;
    /**
     * 主要是用在用户手指离开本view,本view还在继续滑动,我们用来保存Y的距离,然后做比较
     */
    private int lastScrollY;

    public HoveringScrollview(Context context, AttributeSet attrs) {
        super(context, attrs);
        // TODO Auto-generated constructor stub
    }

    /**
     * 设置滚动接口
     *
     * @param onScrollListener
     */
    public void setOnScrollListener(OnScrollListener onScrollListener) {
        this.onScrollListener = onScrollListener;
    }

    /**
     * 用于用户手指离开MyScrollView的时候获取MyScrollView滚动的Y距离,然后回调给onScroll方法中
     */
    private Handler handler = new Handler() {

        public void handleMessage(android.os.Message msg) {
            int scrollY = HoveringScrollview.this.getScrollY();

            // 此时的距离和记录下的距离不相等,在隔6毫秒给handler发送消息?
            if (lastScrollY != scroll
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值