Android WebView与下拉刷新控件滑动冲突的解决方法

Android WebView与下拉刷新控件滑动冲突的解决方法

最近项目里需要加载WebView,并通过原生的下拉刷新控件控制WebView的刷新。实现方式很简单就是WebView外面加上下拉刷新控件即可。但是测试时会发现网页无法上拉,往上滑动就会触发下拉刷新控件的refresh事件。网上查了很多解决办法,有重写WebView的,有重写下拉刷新控件的(我这里使用的下拉刷新控件是第三方的NestRefreshLayout,其他的刷新控件大同小异),但是试过好多以后发现都没有作用。好多方法都是通过webView.getScrollY() 的值来判断是否滚动到顶部,一次来决定刷新控件是否执行刷新的动作,但是无奈webView.getScrollY() 总是 =0。本人的解决方法是:
- 重写WebView里的onTouchEvent方法

 @Override
    public boolean onTouchEvent(MotionEvent event) {
        switch (event.getAction()) {
            case MotionEvent.ACTION_DOWN:
                if (this.getScrollY() <= 0)
                    this.scrollTo(0, 1);
                break;
            case MotionEvent.ACTION_UP:
                //                if(this.getScrollY() == 0)
                //                this.scrollTo(0,-1);
                break;
            default:
                break;
        }
        return super.onTouchEvent(event);
    }

很简单的重写,每次按下的时候,如果在0,0坐标,让它滚动到0,1,这样就会告诉SwipeRefreshLayout他还在滑动,就不会触发刷新事件了。

可能有的同学把代码粘贴过去了,但是并不管用。那是还有一步后续步骤没有完成。下一步是需要在下拉刷新控件里判断是否可以垂直滑动的方法里增加判断:

    @Override
    public boolean canScrollVertically(int direction) {
           if (mTargetView instanceof WebView) {
                return direction < 0 ? mTargetView.getScrollY() > 0
                        : mTargetView.getScrollY() < mTargetView
                        .getMeasuredHeight();
            } else {
                return ViewCompat.canScrollVertically(mTargetView, direction);
            }
    }

代码中mTargetView是刷新控件的子控件,即为WebView,此时mTargetView.getScrollY()的值为1,不在一直为0。两段代码结合即可解决WebView与下拉刷新控件滑动冲突的解决方法,本人用的是NestRefreshLayout,其他控件可在其相应的方法里加入判断,例:

@BindView(R.id.swipe_fresh)
SwipeRefreshLayout refreshLayout;
@BindView(R.id.webview)
WebView webView;
...
...
    // 设置子视图是否允许滚动到顶部
    refreshLayout.setOnChildScrollUpCallback(new SwipeRefreshLayout.OnChildScrollUpCallback() {
       @Override
       public boolean canChildScrollUp(SwipeRefreshLayout parent, @Nullable View child) {
           return webView.getScrollY() > 0;
       }
    });
}

希望此文章对您有帮助!!!

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在WebView中实现下拉刷新,可以通过以下步骤: 1. 在布局文件中添加SwipeRefreshLayout控件,并将WebView作为其子视图。 ``` <androidx.swiperefreshlayout.widget.SwipeRefreshLayout android:id="@+id/swipe_refresh" android:layout_width="match_parent" android:layout_height="match_parent"> <WebView android:id="@+id/web_view" android:layout_width="match_parent" android:layout_height="match_parent" /> </androidx.swiperefreshlayout.widget.SwipeRefreshLayout> ``` 2. 在Activity或Fragment中,获取SwipeRefreshLayout和WebView的实例,并为SwipeRefreshLayout设置下拉刷新监听器。 ``` SwipeRefreshLayout swipeRefreshLayout = findViewById(R.id.swipe_refresh); WebView webView = findViewById(R.id.web_view); swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { @Override public void onRefresh() { webView.reload(); } }); ``` 3. 在WebViewWebViewClient中,重写onPageFinished方法,当页面加载完成时,停止SwipeRefreshLayout的刷新动画。 ``` webView.setWebViewClient(new WebViewClient() { @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); swipeRefreshLayout.setRefreshing(false); } }); ``` 这样,当用户下拉SwipeRefreshLayout时,会触发onRefresh方法,从而重新加载WebView中的页面,并在页面加载完毕后停止刷新动画。 ### 回答2: WebView 下拉刷新是在使用 WebView 控件时,实现下拉刷新页面内容的功能。下拉刷新通常用于在 WebView 中加载新的内容或更新已有的内容。 实现 WebView 下拉刷新的一种常见方式是使用下拉刷新控件,例如 SwipeRefreshLayout。这个控件可以包裹 WebView,并且在用户下拉 WebView 时触发刷新操作。具体代码如下: 首先,在 XML 布局文件中将 WebView 包裹在 SwipeRefreshLayout 中: ```xml <androidx.swiperefreshlayout.widget.SwipeRefreshLayout android:id="@+id/swipeRefreshLayout" android:layout_width="match_parent" android:layout_height="match_parent"> <WebView android:id="@+id/webView" android:layout_width="match_parent" android:layout_height="match_parent" /> </androidx.swiperefreshlayout.widget.SwipeRefreshLayout> ``` 然后,在 Java 代码中设置下拉刷新的监听器,并在刷新时重新加载 WebView 内容: ```java SwipeRefreshLayout swipeRefreshLayout = findViewById(R.id.swipeRefreshLayout); WebView webView = findViewById(R.id.webView); swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { @Override public void onRefresh() { webView.reload(); // 刷新 WebView 内容 swipeRefreshLayout.setRefreshing(false); // 停止刷新动画 } }); ``` 以上代码中,`swipeRefreshLayout.setOnRefreshListener` 方法用于设置下拉刷新的监听器,当用户下拉时,会回调 `onRefresh` 方法。在这个方法中,我们通过 `webView.reload()` 方法重新加载 WebView 内容,之后调用 `swipeRefreshLayout.setRefreshing(false)` 方法停止刷新动画。 通过以上的步骤,我们就可以在 WebView 中实现下拉刷新的功能了。用户在 WebView 上下拉时,会触发刷新动画,并在刷新时重新加载 WebView 内容,使用户能够获取最新的页面内容。 ### 回答3: 在WebView中实现下拉刷新可以通过结合SwipeRefreshLayout和WebView来实现。 首先,在布局文件中添加SwipeRefreshLayout布局和WebView布局,如下所示: ```xml <android.support.v4.widget.SwipeRefreshLayout android:id="@+id/refresh_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <WebView android:id="@+id/webview" android:layout_width="match_parent" android:layout_height="match_parent" /> </android.support.v4.widget.SwipeRefreshLayout> ``` 然后,在代码中找到SwipeRefreshLayout和WebView的实例,并设置下拉刷新监听器和WebView的WebChromeClient,如下所示: ```java SwipeRefreshLayout swipeRefreshLayout = findViewById(R.id.refresh_layout); final WebView webView = findViewById(R.id.webview); // 设置下拉刷新监听器 swipeRefreshLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { @Override public void onRefresh() { // 在这里执行刷新操作,比如重新加载网页 webView.reload(); } }); webView.setWebChromeClient(new WebChromeClient() { @Override public void onProgressChanged(WebView view, int newProgress) { // 在页面加载完成后停止刷新 if (newProgress == 100) { swipeRefreshLayout.setRefreshing(false); } } }); ``` 在下拉刷新监听器中,可以执行刷新操作,比如重新加载网页。当WebView加载完成后,通过setRefreshing(false)停止刷新。 这样,用户在WebView界面中下拉屏幕时,就能触发下拉刷新操作,并重新加载WebView中的网页内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值