android开发使用TextView显示html富文本、markdown文本的强大框架记录一下
<div class="cnblogs_code"><pre><span style="font-size: 16px">android开发时,有时我们想灵活修改样式灵活,所以想使用富文本显示方式展示,一般我们有以下两种方式:<br>1.使用TextView显示,使用textView.setText(Html.from(html))显示富文本内容<br>2.使用WebView加载,使用webView.loadData()或者webView.loadDataWithBaseURL()加载富文本内容<br><br>但是以上两个方法都不够完美,TextView显示的富文本样式支持非常有限;<br>WebView性能损耗比较大而且容易造成内容泄露,整个页面单独进程使用WebView还可以,页面某部分特别是列表页面嵌入WebView不太可能吧。<br><br>所以下面就介绍一个比较有名好用的开源框架Markwon,它的原理是解析对应标签为Spanned,然后再显示到TextView上面。好用性能又好,太牛逼了。<br>下面介绍基本使用:<br> 框架地址:https://noties.io/Markwon/ 以及github:https://github.com/noties/Markwon<br> android项目里引入:<br> allprojects{repositories{</span><span class="s1">maven { url 'https://oss.sonatype.org/content/repositories/snapshots/' }</span><span style="font-size: 16px">}</span><span style="font-size: 16px">}<br></span> api 'io.noties.markwon:core:4.3.1' //引入核心库<br> api 'io.noties.markwon:image:4.3.1' //引入图库支持库<br> api 'io.noties.markwon:image-glide:4.3.1' //引入使用Glide加载图片的支持库<br> 更多具体库,请查看:https://noties.io/Markwon/docs/v4/install.html 以及 https://search.maven.org/search?q=io.noties.markwon<br><br> android使用demo代码kotlin写法:</pre>
<pre> val content = "!(http://static.runoob.com/images/runoob-logo.png)\n" +<br> "\n" +<br> "1. 第一项:\n" +<br> " - 第一项嵌套的第一个元素\n" +<br> " - 第一项嵌套的第二个元素\n" +<br> "\n" +<br> "这是一个链接 [菜鸟教程](https://www.runoob.com)\n"<br> val markwon = Markwon.builder(this)<br> .usePlugin(GlideImagesPlugin.create(this))<br> .usePlugin(GlideImagesPlugin.create(Glide.with(this)))<br> .usePlugin(GlideImagesPlugin.create(object : GlideImagesPlugin.GlideStore {<br> override fun cancel(target: Target<*>) {<br> Glide.with(this@TestActivity).clear(target);<br> }<br> override fun load(drawable: AsyncDrawable): RequestBuilder<Drawable> {<br> return Glide.with(this@TestActivity).load(drawable.destination);<br> }<br> }))<br> .build()<br> markwon.setMarkdown(textView, content)</pre>
<pre> 上面是显示markdown富文本demo,如果想要显示html也是可以的,不过要添加对应的html依赖库。</pre>
</div>
<p> </p><br><br>
来源:https://www.cnblogs.com/yongfengnice/p/12859537.html
頁:
[1]