Android 用webview加载连接的时候有时会出现连接在浏览器里一切正常,但用webview加载连接会出现一些问题,如不能弹出弹框,图片缺失等,出现这种情况是因为没有对webview的相应属性进行设置,而且由于Android系统的级别不一样对连接的反应也不同,5.0,6.0,7.0的手机有时需要特殊处理,以下是我用webview的过程中总结的一些属性设置。
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { mWebView.getSettings().setMixedContentMode(WebSettings.MIXED_CONTENT_ALWAYS_ALLOW); } //当加载Html里有https和http混合的时候,5.0以上的手机需要开启混合模式才可以正常加载图片如当html是https的连接但连接里的图片是http的,这时候5.0以上的手机会加载不出来http图片,需要开启此设置才能正常显示图片。 mWebView.getSettings().setJavaScriptEnabled(true); //可以夹杂javaScript mWebView.getSettings().setJavaScriptCanOpenWindowsAutomatically(true); //设置允许js弹出alert对话框。 mWebView.getSettings().setSupportZoom(true);//是否可以缩放,默认是true mWebView.getSettings().setBuiltInZoomControls(true);//是否可以显示缩放按钮,默认是false mWebView.getSettings().setUseWideViewPort(true);//设置此属性,可任意比例缩放,大视图模式 mWebView.getSettings().setLoadWithOverviewMode(true);//和setUseWideViewPort(true)一起解决网页自适应问题 mWebView.getSettings().setAppCacheEnabled(true);//是否使用缓存 mWebView.getSettings().setDomStorageEnabled(true);//DOM Storage // mWebView.getSettings().setCacheMode(WebSettings.LOAD_DEFAULT); //设置 缓存模式 mWebView.getSettings().setPluginState(WebSettings.PluginState.ON); //播放视频
mWebView.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE); //设置不用缓存 mWebView.getSettings().setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
mWebView.getSettings().setGeolocationEnabled(true); //设置可以定位
mWebView.setWebChromeClient(new MyWebChromeClient());
mWebView.setWebViewClient(new WebViewClient() { //在webViewClient里对url进行处理 @Override public void onLoadResource(WebView view, String url) { super.onLoadResource(view, url); } @RequiresApi(api = Build.VERSION_CODES.LOLLIPOP) @Override public boolean shouldOverrideUrlLoading(WebView view, WebResourceRequest request) { String url = request.getUrl().toString(); return false; } @RequiresApi(api = Build.VERSION_CODES.ICE_CREAM_SANDWICH_MR1) @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { return false; } @Override public void onPageStarted(WebView view, String url, Bitmap favicon) { super.onPageStarted(view, url, favicon); } @Override public void onPageFinished(WebView view, String url) { super.onPageFinished(view, url); } });
//设置下载监听在上一篇博客中已经详细说过了,这里就不再说了
mWebView.setDownloadListener(new MyDownLoadListener(MainActivity.this));
mWebView.loadUrl(h5Path); //要加载连接
public class MyWebChromeClient extends WebChromeClient {
/** * 设置网页可以请求位置信息,因为有的手机加载连接后不会弹出请求位置信息的弹框,用户看不到没有点击导致网页一直处于加 *载中而加载不出页面。 * @param origin * @param callback */
@Override public void onGeolocationPermissionsShowPrompt(String origin, GeolocationPermissions.Callback callback) { callback.invoke(origin, true, true); super.onGeolocationPermissionsShowPrompt(origin, callback); }
}