setOnScrollChangeListener不兼容

本文介绍了解决在低版本Android中为ScrollView设置滚动监听时出现的兼容性问题。提供了两种解决方案:一是使用ViewTreeObserver,二是自定义ScrollView并重写onScrollChanged方法。这两种方法都能有效避免因API版本不同导致的错误。

开发中为scrollview设置监听,setOnScrollChangeListener报找不到类的错误,
在这里插入图片描述
原来是这个方法是API23才出来的,没有做向下兼容,所以在低版本运行就会报错。

解决这个问题有两个方法:

  1. 解决方案是使用ViewTreeObserver
    scrollView.getViewTreeObserver().addOnScrollChangedListener(new ViewTreeObserver.OnScrollChangedListener() {
        @Override
        public void onScrollChanged() {
     
        }
    });

2.自定义scrollview,自己去实现一个借口
重写 onScrollChanged(int x, int y, int oldx, int oldy)方法,在方法中调用接口。

public class MyScrollView extends ScrollView {
    private OnScrollChanged mOnScrollChanged;
    public MyScrollView(Context context) {
        this(context,null);
    }
 
    public MyScrollView(Context context, AttributeSet attrs) {
        this(context, attrs,0);
    }
 
    public MyScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
        init();
    }
 
    private void init() {
 
    }
 
    @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);
    }
}

转载自:https://blog.youkuaiyun.com/gone_the_rainbow/article/details/52851360

<androidx.coordinatorlayout.widget.CoordinatorLayout android:id="@+id/parent_view" android:layout_width="match_parent" android:layout_height="match_parent"> <!-- android:elevation="1dp"比header中的高,就会置与上层--> <View android:id="@+id/toolBar" android:layout_width="match_parent" android:layout_height="100dp" android:layout_gravity="top" android:background="#627788" android:elevation="1dp" /> <!-- 顶部 Header(可以自定义内容) --> <LinearLayout android:id="@+id/header" android:layout_width="match_parent" android:layout_height="50dp" android:background="#6200EE" android:layout_marginTop="100dp" android:orientation="vertical"/> <WebView android:id="@+id/webView" android:layout_marginTop="150dp" android:layout_width="match_parent" android:layout_height="match_parent" /> </androidx.coordinatorlayout.widget.CoordinatorLayout> 我有这样一个布局,我想控制上滑webview,header随之隐藏,下拉webview,header随之显示,使用如下代码: header.post { val initialHeaderHeight = header.height var initialHeight = 0 webView.setOnScrollChangeListener { v, scrollX, scrollY, oldScrollX, oldScrollY -> // 根据滚动距离调整header的高度 val newHeight = initialHeaderHeight.coerceAtMost(initialHeaderHeight - scrollY).coerceAtLeast(0) Log.d(TAG, "setOnScrollChangeListener, scrollY=$scrollY, oldScrollY=$oldScrollY, ") Log.d(TAG, "setOnScrollChangeListener, initialHeaderHeight=$initialHeaderHeight, scrollY=$scrollY, ") header.layoutParams.height = newHeight header.requestLayout() Log.d(TAG, "setOnScrollChangeListener, header.height=${header.height}") // 调整WebView的高度以填充剩余空间 if (initialHeight == 0) { initi
03-28
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值