Android WebView加载html片段

作者: 李moumou | 来源:发表于2017-08-29 21:39 被阅读1135次

这里我先简单描述一下需求:服务器返回的是html页面的一部分带有标签的内容。
解决的思路是:将服务器返回的内容片段拼凑成一个完整的页面。

下面直接上核心代码:
这里是WebView一些配置

WebSettings settings = webView.getSettings();
settings.setJavaScriptEnabled(true);
settings.setDomStorageEnabled(true);
settings.setUseWideViewPort(true);
settings.setLoadWithOverviewMode(true);
webView.setWebViewClient(new MyWebViewClient(activity));
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {         
  settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING);
} else {
  settings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NORMAL);
}
webView.loadData(getHtmlData(item.content), "text/html;charset=utf-8","utf-8");
private String getHtmlData(String bodyHTML) {
        String head = "<head>" +
                "<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0, user-scalable=no\"> " +
                "<style>html{padding:15px;} body{word-wrap:break-word;font-size:13px;padding:0px;margin:0px} p{padding:0px;margin:0px;font-size:13px;color:#222222;line-height:1.3;} img{padding:0px,margin:0px;max-width:100%; width:auto; height:auto;}</style>" +
                "</head>";
        return "<html>" + head + "<body>" + bodyHTML + "</body></html>";
    }

static class MyWebViewClient extends WebViewClient{
        private WaitingDialog dialog;
        private Activity activity;
        public MyWebViewClient(Activity activity){
            dialog = new WaitingDialog(activity);
            this.activity = activity;
        }

        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            LogUtil.e(url);
            view.loadUrl(url);
            return true;
        }

        @Override
        public void onPageStarted(WebView view, String url, Bitmap favicon) {
            super.onPageStarted(view, url, favicon);
            if(!activity.isFinishing()) dialog.show();
        }

        @Override
        public void onReceivedSslError(WebView view, SslErrorHandler handler, SslError error) {
            handler.proceed();
            super.onReceivedSslError(view, handler, error);
        }

        @Override
        public void onPageFinished(WebView view, String url) {
            super.onPageFinished(view, url);
            if(!activity.isFinishing()) dialog.dismiss();
        }

笔者在Nexus6 7.0上面测试偶尔出现,html内容无法加载出来,显示一片空白,开启硬件加速后完美解决。
在上面WebView设置的部分加上如下代码

if (webView.isHardwareAccelerated()) webView.setLayerType(View.LAYER_TYPE_HARDWARE,null);

怎么样简单吧,如果有点帮助,帮忙点个赞O(∩_∩)O谢谢!

相关文章

  • Android WebView加载html片段

    这里我先简单描述一下需求:服务器返回的是html页面的一部分带有标签的内容。解决的思路是:将服务器返回的内容片段拼...

  • 正则表达式笔记

    a.过滤替换Android Webview加载html片段,由于html 的字符串中间穿插很多图片的尺寸是不定的,...

  • WebView 与JS 互相调用

    WebView加载本地html loadUrl("file:///android_asset/html/index...

  • Android webview 加载html片段笔记

    场景:一些内容是直接PC端编辑器保存的,包含了大量的html标签甚至是ubb语言的标签。直接使用大量的冗余信息(类...

  • WebView中的文件选择

    html示例 Android代码 参考:Android使用WebView加载网页选择文件上传[https://bl...

  • 关于 android Webview

    关于 android Webview 基本使用 加载html四种方式 简单使用 在AndroidManifest....

  • webview js交互

    由于项目需要,再次使用到了android的webview,webview要加载的页面是html5的页面; 需要有点...

  • ReactNative WebView加载html Androi

    今天项目在android上测试发现webView加载的html安卓机型显示乱码,因为后台返回的是html字段,安卓...

  • swift使用webView加载html

    format好html字符串 加载html webViewDidFinishLoad()方法webView加载完调...

  • Android中的WebView详解

    Android中的WebView详解 WebView详解 基本用法 布局文件配置WebView WebView加载...

网友评论

    本文标题:Android WebView加载html片段

    本文链接:https://www.haomeiwen.com/subject/rxpadxtx.html