Android加载富文本_安卓如何加载富文本-程序员宅基地

技术标签: android  

直接用webview加载:

package com.example.testcsdnproject;

import androidx.appcompat.app.AppCompatActivity;

import android.annotation.SuppressLint;
import android.graphics.Color;
import android.os.Bundle;
import android.util.Log;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import android.webkit.WebViewClient;

import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;

public class RichTextViewActivity extends AppCompatActivity {

    private WebView webview_intro;      //webview加载富文本
    //网页加载富文本的限制标签
    private String CSS_STYLE =" <style> p {color:#FFFFFF;} a {color:#FFFFFF;}  img{max-width:100% !important;height:auto !important}video{max-width:100% !important;height:auto !important}  p span{color:#FFFFFF !important; background-color:#1A1A1A !important; font-size:20px;}</style>";
//    private String CSS_Content = "";
    //测试数据
        private String CSS_Content = "<h3><span style=\"color: rgb(245, 245, 245);\">hello world</span></h3><p><span style=\"color: rgb(255, 251, 143);\">阿大声道啊大师大的撒打算的撒打发的股份的回复的后代鼓捣鼓捣 阿打算打打打算的啊大大十多万鹅鹅鹅我热潮中在大大</span></p><p><br></p><p><br></p><p><span style=\"color: rgb(255, 251, 143);\">撒旦教奥斯卡了的骄傲了看得见卡的好拉屎的金卡价saduoiejwrwmflkvnfslvlkaosfjdfms</span></p><p><span style=\"color: rgb(255, 251, 143);\">舒服vhskdjklvnmxmvxsdfsdfsdfjjsj;lrjewklrjkl</span></p><p><img src=\"https://img1.baidu.com/it/u=186439391,629096241&fm=253&fmt=auto&app=120&f=JPEG?w=500&h=740\" alt=\"\" data-href=\"\" style=\"\"/></p><p><br></p><p><br></p><p><span style=\"color: rgb(255, 77, 79);\">结尾。。。。。。asd.asdas撒as大大啊我u哦IE问问瑞荣 &nbsp;1231312313112313132131231</span><div class=\"media-wrap video-wrap\"><video controls=\"\" class=\"media-wrap video-wrap\" src=\"https://images.artvrpro.com/activity%2F1668587203846-7_1.MP4.7_1.MP4\"></video></div></p>";
//    private String CSS_STYLE =" <style> p {color:#FFFFFF;} a {color:#FFFFFF;}  img{max-width:100% !important;height:auto !important}video{max-width:100% !important;height:auto !important}</style>";


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

        webview_intro = findViewById(R.id.webview_intro);
        initWebViewContent(CSS_Content);
    }


    /**
     * 传入参数为String的时候
     */
    @SuppressLint("NewApi")
    private void initWebViewContent(String content) {
        Log.e("colincontent: ", content);

        WebChromeClient wvcc = new WebChromeClient();
        WebSettings webSettings = webview_intro.getSettings();
        webSettings.setJavaScriptEnabled(true);
        webSettings.setUseWideViewPort(true); // 关键点
        webSettings.setAllowFileAccess(true); // 允许访问文件
        webSettings.setSupportZoom(true); // 支持缩放w
        webSettings.setLoadWithOverviewMode(true);
        webSettings.setAppCacheEnabled(true);
        webSettings.setDatabaseEnabled(true);
        webSettings.setDomStorageEnabled(true);
        webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
        webSettings.setTextZoom(200);


        webview_intro.setBackgroundColor(Color.parseColor("#FF1A1A1A"));

        webview_intro.setWebChromeClient(wvcc);
        content = content.replaceAll("background-color:#ffffff", "background-color:#1A1A1A");
        CSS_Content = content;
        webview_intro.loadDataWithBaseURL(null, CSS_STYLE+getNewContent(content), "text/html", "utf-8", null);

        webview_intro.setWebViewClient(new WebViewClient(){
            @Override
            public void onPageFinished(WebView view, String url) {
                super.onPageFinished(view, url);


                // 解决NestedScrollView嵌套WebView底部留白问题
//                        webview_intro.getLayoutParams().height = ViewGroup.LayoutParams.WRAP_CONTENT;

                //这是我找到的最简单的方法(例如,将文本颜色更改为白色):
                view.loadUrl(
                        "javascript:document.body.style.setProperty(\"color\", \"white\");"
                );

            }
        });


    }

    //视频屏幕宽度 解决视频超出屏幕宽度的问题
    private String getNewContent(String htmlText) {
        Document doc = Jsoup.parse(htmlText);
        Elements elements = doc.getElementsByTag("img");
        for (Element element : elements) {
            element.attr("width", "100%").attr("height", "auto");
        }
        Elements elementsVideo = doc.getElementsByTag("video");
        for (Element element : elementsVideo) {
            element.attr("width", "100%").attr("height", "auto");
        }
        return doc.toString();
    }


    @Override
    protected void onDestroy() {
        super.onDestroy();
        if(webview_intro!=null){    //销毁界面时要释放webview,否则退出页面还会播放视频音频
            webview_intro.loadUrl("about:blank");
            webview_intro =null;
        }
    }
}

xml:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".RichTextViewActivity"
    android:background="#101010">

    <WebView
        android:id="@+id/webview_intro"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="10dp"
        android:layout_marginRight="10dp"
        android:scrollbars="none"
        android:visibility="visible"

        android:focusable="false"
        android:nestedScrollingEnabled="false"/>

</RelativeLayout>

这里用的是原生的webview,会有一个问题,就是特殊的视频格式可能会出问题,项目中可以使用腾讯的X5内核的webview 。

效果如下:

分割线=======================================

如果不想用webview加载富文本也可以用富文本编辑器:

 //导入图文编辑
    api ('com.github.wordpress-mobile.WordPress-Aztec-Android:aztec:v1.3.44')
    api ('com.github.wordpress-mobile.WordPress-Aztec-Android:glide-loader:v1.3.44')
    api ('com.github.wordpress-mobile.WordPress-Aztec-Android:wordpress-comments:v1.3.44')
    api ('com.github.wordpress-mobile.WordPress-Aztec-Android:wordpress-shortcodes:v1.3.44')
private AztecText mAztecText;
protected Aztec aztec;

 aztec = Aztec.with(mAztecText,
                new SourceViewEditText(getActivity()),
                new AztecToolbar(getActivity()),
                new IAztecToolbarClickListener() {
                    @Override
                    public void onToolbarCollapseButtonClicked() {

                    }

                    @Override
                    public void onToolbarExpandButtonClicked() {

                    }

                    @Override
                    public void onToolbarFormatButtonClicked(@NonNull ITextFormat iTextFormat, boolean b) {

                    }

                    @Override
                    public void onToolbarHeadingButtonClicked() {

                    }

                    @Override
                    public void onToolbarHtmlButtonClicked() {

                    }

                    @Override
                    public void onToolbarListButtonClicked() {

                    }

                    @Override
                    public boolean onToolbarMediaButtonClicked() {
                        return false;
                    }
                })
                .setImageGetter(new GlideImageLoader(getActivity()))
                .setOnLinkTappedListener(this)    /*添加超链接点击监听*/
                .setLinkTapEnabled(true)
                .addPlugin(new WordPressCommentsPlugin(mAztecText))
                .addPlugin(new CaptionShortcodePlugin(mAztecText))
                .addPlugin(new HiddenGutenbergPlugin(mAztecText));

        mAztecText.setKeyListener(null);
 aztec.getVisualEditor().fromHtml("富文本", false);

XML:

 <org.wordpress.aztec.AztecText
            android:id="@+id/aztec"
            style="@style/EditTextTheme"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginLeft="@dimen/dp_16"
            android:layout_marginRight="@dimen/dp_16"
            android:focusable="false"
            android:gravity="top|start"
            android:imeOptions="flagNoExtractUi"
            android:paddingEnd="@dimen/dp_16"
            android:paddingLeft="@dimen/dp_16"
            android:paddingRight="@dimen/dp_16"
            android:paddingTop="@dimen/dp_16"
            android:scrollbars="none"
            android:visibility="gone"
            aztec:bulletColor="@color/bulletColor"
            aztec:bulletMargin="@dimen/dp_6"
            aztec:bulletPadding="@dimen/dp_5"
            aztec:codeColor="@color/colorLightBlack"
            aztec:historyEnable="true"
            aztec:historySize="10"
            aztec:linkColor="@color/linkColor"
            aztec:linkUnderline="true"
            aztec:quoteBackground="@color/quoteBackground"
            aztec:quoteColor="@color/quoteColor"
            aztec:quoteMargin="@dimen/dp_0"
            aztec:quotePadding="@dimen/dp_10"
            aztec:quoteWidth="@dimen/dp_5"
            aztec:textColor="@color/colorLightBlack"/>

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_38306233/article/details/136214269

智能推荐

基于SQL Server数据库的安全性对策探究_sqlserver数据库的安全性-程序员宅基地

文章浏览阅读438次。SQL Server数据库的安全与计算机网络安全、数据库系统安全等存在一定的联系,某一环节的安全隐患对整个系统的安全造成一定威胁,因此对数据库安全方面采取防范措施具有一定的必要性,与当下网络信息安全管理方面的要求相适应,它可以为用户提供稳定、安全的网络环境。在数据库系统中,管理者如果从用户界面进入系统,存在的数据库安全问题与使用者面临的安全问题相同,但如果管理者从数据库管理界面进入系统的话,由于这种情况下管理者的权限比较大,如果从数据库服务器的DBMS进入数据库的话,对数据库安全存在比较大的威胁。_sqlserver数据库的安全性

java计算圆锥体积_【身临其境】关于几何体的表面积和体积,就没见过这么详细的解释!!!...-程序员宅基地

文章浏览阅读627次。点击上方蓝色字体“高中数学王晖”关注王晖老师,免费获取各种知识干货和学习经验~~~您的点赞转发是对老师的最大鼓舞~~~距高考还有168天从展开图看几何体表面积基本要求:①理解柱、锥、台体的侧面展开图;②掌握柱、锥、台、球表面积常用公式;③能计算简单组合体的表面积。直棱柱展开直棱柱的侧面展开后,整体的外观形状是矩形。所以,直棱柱的表面积就比较方便计算了:直棱柱表面积=侧面积+2×底面积直棱..._java圆锥体积

dubbo端口冲突解决办法_dubbo 多个服务抢占端口-程序员宅基地

文章浏览阅读2.8k次。在一台机子上部署多个dubbo服务,将各服务的dubbo端口号设为-1,可以确保无端口冲突。_dubbo 多个服务抢占端口

【CISSP备考】第七章-安全运营_cissp sox法案-程序员宅基地

文章浏览阅读2.1k次。第六章密码学和对称秘钥算法:密码可为已存储(静止中)、通过网络传送(传输中)和存在于内存中(使用中)的敏感信息提供保密性、完整性、身份验证和不可否认性保护。凯撒密码:将相关字母顺移密码学的目标:保密性、完整性、身份验证和不可否认性1、保密性:保密性是确保数据在静止、传输和使用等三种不同状态下始终保持私密对称加密系统、非对称加密系统2、完整性完整性确保数据没有被人未经授权更改、消息完整性使用加密的消息摘要实现3、身份验证身份验证用于验证系统用户所声称的身份,是密码系_cissp sox法案

微信小程序开发:实现地图导航功能_微信小程序地图导航功能实现-程序员宅基地

文章浏览阅读4.8k次,点赞2次,收藏25次。其中,id用于调用地图组件,latitude和longitude表示地图的中心点坐标,markers表示地图中的标记点,covers表示地图中的覆盖物,polyline表示地图中的折线图,show-location表示是否显示当前定位点,bindregionchange表示移动地图时触发的事件。其中,id表示标记点的唯一标识,latitude和longitude表示标记点的坐标,title表示标记点的名称,iconPath表示标记点的图标路径,width和height表示标记点的宽度和高度。_微信小程序地图导航功能实现

Invalid initial heap size: -Xms-程序员宅基地

文章浏览阅读4.9k次。-Xxs512m注意 Xxs 和 512m中间无空格就行了。_invalid initial heap size: -xms4g

随便推点

OpenCV Mat数据的按行(列)和多行(列)赋值_mat修改整列-程序员宅基地

文章浏览阅读2.7w次,点赞24次,收藏34次。赋值的不正确情况在使用opencv的过程中,希望多行或者多列进行赋值,我之前的代码是这样的 Mat c = Mat::zeros(3, 5, CV_32F); Mat a = Mat::ones(3, 6, CV_32F); //对a的第一列进行赋值 a.col(0) = c.col(0); //将c的1-5列赋值给a a.colRange(1, 6)_mat修改整列

C语言之输入一个年份,判断是不是闰年_如何判断闰年c语言-程序员宅基地

文章浏览阅读3.1w次,点赞5次,收藏11次。#include int main(){/*输入年份判断是不是闰年*//*闰年:能被400整除, 能被4整除,并且不能被100整除*/ int year,flag; printf("请输入一个年份\n"); scanf("%d",&year); if(year%400==0){ flag=1; }else{ if(year%4==0){_如何判断闰年c语言

LIN协议介绍-程序员宅基地

文章浏览阅读929次。LIN协议介绍_lin协议

Node.js开发概述-程序员宅基地

文章浏览阅读1.4k次。Node.js发布于2009年5月,由Ryan Dahl开发,是一个基于Chrome V8引擎的JavaScript运行环境,使用了一个事件驱动、非阻塞式I/O模型, [1] 让JavaScript 运行在服务端的开发平台,它让JavaScript成为与PHP、Python、Perl、Ruby等服务端语言平起平坐的脚本语言。 [2] Node.js对一些特殊用例进行优化,提供替代的API,使得V8在非浏览器环境下运行得更好,V8引擎执行Javascript的速度非常快,性能非常好,基于Chrome Ja_node.js开发

SVN不完全指南(使用)_svn authz文件在哪-程序员宅基地

文章浏览阅读238次。目录一 、SVN三大指令(检提更) 二、忽略功能 三、版本回退 四、版本冲突 五、配置多仓库与权限控制 六、SVN服务的配置与管理 七、模拟真实的开发环境一 、SVN三大指令(检提更)检出(Checkout)操作 首先在你的项目目录鼠标右键TortoiseSVN版本库浏览器输出SVN服务器地址: svn://SVN服务器地址 Shop项目(仓库) 注: 因为.svn是隐藏_svn authz文件在哪

SpringBoot 不同环境读取不同的配置信息文件_根据不同环境获取不同的配置信息-程序员宅基地

文章浏览阅读1.3w次。在实际开发中,本地开发、测试服务、正式服务的配置信息有的地方是不一样的;比如本地测试log级别可能是debug,而正式环境下则为info;再比如数据库的配置,正式环境下和测试环境下是不一样的。以前我们通过手动更改这些配置来完成测试到正式的转移,但这样做还是有一定的风险,如果手动配置错误,则会导致很多错误。Springboot给我们提供了一种方式,能够自动的切换正式环境配置及测试环境配置,下面就用一个_根据不同环境获取不同的配置信息