Android webview 下拉刷新

今天由于业务需要,需要对webview下来刷新,但webview肯定没这功能呀,于是就想,在用xlistview把webview放在头部,下拉webview时,就重新加载webview,但这样说不定,可能照成滑动冲突。于是,在stack overflow找到了不错的解决方案。

SwipeRefreshLayout 是谷歌官方下拉刷新控件,4.0以下的版本需要用到 Android-support-v4.jar包才能用到。
SwipeRefreshLayout 使用起来是非常简单的,只需要在可以滑动的控件外层添加即可,如:WebView、ListView和ScroolView.

demo例子如下:
public class MainActivity extends Activity {

private WebView webView;
private WebSettings webSettings;
private SwipeRefreshLayout swipeLayout;
private String linkUrl="https://www.baidu.com/";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    swipeLayout = (SwipeRefreshLayout)findViewById(R.id.swipe_container);
    // 设置刷新监听器
    swipeLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {

        @Override
        public void onRefresh() {
            //重新刷新页面
            // webview.loadUrl(webview.getUrl());
            webView.reload();
        }
    });

    //设置进度条渐变的颜色
    swipeLayout.setColorScheme(R.color.holo_blue_bright,
            R.color.holo_green_light, R.color.holo_orange_light,
            R.color.holo_red_light);

    //初始化webview
    initwebview();
}

private void initwebview(){
    webView= (WebView) findViewById(R.id.webview);
    webSettings= webView.getSettings();
    webView.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
    webSettings.setSupportZoom(false);
    webSettings.setBuiltInZoomControls(false);
    webSettings.setAppCacheMaxSize(1024 * 1024 * 9);// 设置缓冲大小
    webSettings.setAllowFileAccess(true);
    webSettings.setAppCacheEnabled(true);
    webSettings.setJavaScriptEnabled(true);
    webSettings.setDomStorageEnabled(true);
    webView.setWebViewClient(new WebViewClient() {
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            view.loadUrl(url);
            return true;
        }
    });

    //设置进度条
    webView.setWebChromeClient(new WebChromeClient() {
        @Override
        public void onProgressChanged(WebView view, int newProgress) {
            if (newProgress == 100) {
                //隐藏进度条
                swipeLayout.setRefreshing(false);
            } else {
                if (!swipeLayout.isRefreshing())
                    //显示进度条
                    swipeLayout.setRefreshing(true);
            }

            super.onProgressChanged(view, newProgress);
        }
    });
    webView.loadUrl(linkUrl);
}

}

### 回答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、付费专栏及课程。

余额充值