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>";@Overrideprotected 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); // 支持缩放wwebSettings.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(){@Overridepublic 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();}@Overrideprotected 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"><WebViewandroid: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() {@Overridepublic void onToolbarCollapseButtonClicked() {}@Overridepublic void onToolbarExpandButtonClicked() {}@Overridepublic void onToolbarFormatButtonClicked(@NonNull ITextFormat iTextFormat, boolean b) {}@Overridepublic void onToolbarHeadingButtonClicked() {}@Overridepublic void onToolbarHtmlButtonClicked() {}@Overridepublic void onToolbarListButtonClicked() {}@Overridepublic 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.AztecTextandroid: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"/>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/704622.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Nexus Repository Manager

Nexus Repository Manager https://s01.oss.sonatype.org/#welcome https://mvnrepository.com/-CSDN博客

Ubuntu22.04环境下载安装中文搜狗输入法

0、查看CPU系统架构 确定架构后&#xff0c;下载对应的安装包&#xff0c;否则无法正常安装应用程序 1、进入搜狗拼音输入法官网&#xff0c;下载搜狗输入法 搜狗输入法-首页搜狗拼音输入法官网下载&#xff0c;荣获多个国内软件大奖的搜狗拼音输入法是一款打字更准、词库更大…

Java实战:Spring Boot项目Jar包加密

本文将详细介绍如何在Spring Boot项目中实现Jar包加密。我们将探讨Jar包加密的基本概念&#xff0c;以及如何使用Spring Boot的Jar工具和第三方库来实现Jar包的加密和解密。此外&#xff0c;我们将通过具体的示例来展示如何在Spring Boot项目中使用Jar包加密来保护项目的代码和…

3、函数定义,函数调用,this指向总结,闭包

一、函数的定义方式 1、函数声明 function demo1() {var num 12var result Math.pow(num,2)//指数函数return result }2、函数表达式 var demo2 function (x,y) { //内置对象arguments前面的两个参数 是 x,yvar sum arguments[0] arguments[1]console.log(sum) }3、构…

【物联网应用案例】唐山世园会照明管理项目

世园会作为国际盛会&#xff0c;不仅仅是一次花卉和园艺的展示&#xff0c;更是城市形象和文化的集中展现。夜间照明系统作为其中的重要组成部分&#xff0c;其重要性不言而喻。它不仅关乎着每一位到访游客的视觉体验&#xff0c;更是城市名片的重要展示。 为了给游客带来一次…

精品基于SpringBoot+Vue的常规应急物资管理系统

《[含文档PPT源码等]精品基于SpringBootVue的常规应急物资管理系统[包运行成功]》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功&#xff01; 软件开发环境及开发工具&#xff1a; Java——涉及技术&#xff1a; 前端使用技术&#xff…

十五届蓝桥杯第三期模拟赛题单(C++、java、Python)

备战2024年蓝桥杯 省赛第三期模拟赛题单 备战Python大学A组 第一题 【问题描述】 请问 2023 有多少个约数&#xff1f;即有多少个正整数&#xff0c;使得 2023 是这个正整数的整数倍。 【问题描述】 这是一道结果填空的题&#xff0c;你只需要算出结果后提交即可。本题的结果…

计网Lesson15 - TCP可靠传输

文章目录 1. 停止等待ARQ协议2. 连续ARQ协议与滑动窗口协议 1. 停止等待ARQ协议 ARQ&#xff08;Automatic Repeat–reQuest&#xff09;自动重传请求 几种重传情况 发送端丢失 发送方过久没有接收到接收方的确认报&#xff0c;这种情况会触发超时重传机制&#xff0c;发送方…

Facebook的未来蓝图:数字社交的下一个篇章

在数字化时代&#xff0c;社交媒体已经成为人们日常生活中不可或缺的一部分。而在众多的社交媒体平台中&#xff0c;Facebook一直处于领先地位&#xff0c;不断探索着数字社交的新领域和新形式。随着科技的不断发展和社会的不断变革&#xff0c;Facebook正在谱写着数字社交的未…

JSON:简介与基本使用

目录 什么是JSON&#xff1f; JSON的基本结构 JSON的基本使用 在JavaScript中使用JSON 创建JSON对象 解析JSON字符串 生成JSON字符串 在其他编程语言中使用JSON 总结 什么是JSON&#xff1f; JSON&#xff0c;全称为JavaScript Object Notation&#xff0c;是一种轻量…

lv21 QT入门与基础控件 1

1 QT简介 QT是挪威Trolltech开发的多平台C图形用户界面应用程序框架 典型应用 2 工程搭建 2.1 新建ui工程 不要写中文路径 2.1 不勾选UI&#xff08;主讲&#xff09; 3 QT信号与槽机制 语法&#xff1a;Connect&#xff08;A, SIGNLA(aaa()), B, SLOT(bbb())&#xff09;…

代码随想录算法训练营day59 || 583. 两个字符串的删除操作,72. 编辑距离

动态规划之子序列&#xff0c;还是为了编辑距离做铺垫 | LeetCode&#xff1a;583.两个字符串的删除操作_哔哩哔哩_bilibili 动态规划终极绝杀&#xff01; LeetCode&#xff1a;72.编辑距离_哔哩哔哩_bilibili 583. 两个字符串的删除操作 思路&#xff1a;返回使得s与t相同所…

k8s中基于alpine-3.7.0的pod无法解析域名问题

现象 在pod内无法解析指定域名 # 执行ping bash-4.4# ping xx-xx-svc-0.xxx-fcp.svc.cluster.local ping: bad address xx-xx-svc-0.xxx-fcp.svc.cluster.local排查经过 # 执行nslookup bash-4.4# nslookup xx-xx-svc-0.xxx-fcp.svc.cluster.local Server: 172.43.0…

27.HarmonyOS App(JAVA)可复用列表项的ListContainer

可复用列表项的ListContainer 简短的列表可以通过定向布局实现,但是如果列表项非常多,则使用定向布局就不再合适。如需要创建50个列表项的列表,那么用定向布局实现至少需要创建50个以上的组件了。然而,限于设备屏幕大小的限制,绝大多数组件不会显示在屏幕上,却会占据大量的内存…

C#使用QQ邮箱发送邮件

简介 在c#中发送邮箱我们只需要引入官方提供的命名空间 System.Net.Mail &#xff0c;这个命名空间包含了一系列类&#xff0c;用于创建、配置和发送电子邮件消息。 这个命名空间中的一些主要类包括&#xff1a; MailMessage&#xff1a;表示一个电子邮件消息&#xff0c;包…

计网自顶向下:网络应用层【Web应用与HTTP协议】

目录 Web应用Web页URLWorld Wide Web 超文本传输协议——HTTP超文本C/S结构报文请求报文响应报文HTTP响应状态码try&#xff1a;在命令行里手工给web服务器发送请求 http连接的两种类型非持久&#xff08;http1.0&#xff09;持久&#xff08;http1.1&#xff09;▷ 流水线▷ 非…

重新安装VSCode后,按住Ctrl(or Command) 点击鼠标左键不跳转问题

重新安装VSCode后&#xff0c;按住Ctrl&#xff08;or Command&#xff09; 点击鼠标左键不跳转问题 原因&#xff1a;重新安装一般是因为相应编程语言的插件被删除了或还没有下载。 本次是由于Python相关的插件被删除了&#xff0c;因此导致Python无法跳转。 解决办法 在vs…

告别枯燥代码,Matplotlib学习网站让图表活起来!

介绍&#xff1a;Matplotlib是一个广泛使用的Python绘图库&#xff0c;专门用于创建高质量的2D图形。 Matplotlib的特点包括&#xff1a; 丰富的图表类型&#xff1a;支持多种图表类型&#xff0c;如线图、散点图、柱状图、直方图等&#xff0c;满足不同的数据可视化需求。 高度…

MySQL数据库进阶第五篇(锁)

文章目录 一、锁的概述二、全局锁三、表级锁四、元数据锁&#xff08;meta data lock, MDL&#xff09;五、意向锁六、行级锁七、行锁&#xff08;Record Lock&#xff09;八、间隙锁&#xff08;Gap Lock&#xff09;九、临键锁&#xff08;Next-Key Lock&#xff09;十、锁总…

beego代理前端web的bug

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 一、beego代理前端web的bug总结 一、beego代理前端web的bug *报错&#xff0c;为web压缩包index.html里面的注释被错误解析&#xff0c;删掉就行 2024/02/22 10:2…