天天看點

使用Html.fromHtml()怎麼加載Html中的圖檔

extView是不隻可以String的,我們平常用的給setText()方法傳遞String參數的時候,其實是調用的public final void setText (CharSequence text)方法,String類是CharSequence的子類。

而CharSequence子類衆多,其中有一個接口Spanned,即類似html的帶标記的文本。我們可以用它來在TextView中顯示html(自然,有很多html标記是不支援的,隻支援一部分)。

Android.text.Html類的一個方法:

[java]  view plain copy print ?

  1. public static Spanned fromHtml (String source)  

可以将html代碼轉換為Spanned。

[java]  view plain copy print ?

  1. html = "<h1>this is h1</h1>"  
  2.         + "<p>This text is normal</p>"  
  3.         + "<img src='https://www.google.com.hk/intl/zh-CN/images/logo_cn.png' />";  
  4. Spanned sp = Html.fromHtml(html);  
  5. textView.setText(html);  

顯示效果:

使用Html.fromHtml()怎麼加載Html中的圖檔

可以看出,字型效果基本是顯示出來了,但是圖檔沒有顯示。

要實作圖檔的顯示需要使用Html.fromHtml的另外一個重構方法:

public static Spanned fromHtml (String source, Html.ImageGetter imageGetter, Html.TagHandler tagHandler)

其中Html.ImageGetter是一個接口,我們要實作此接口,在它的getDrawable(String source)方法中傳回圖檔的Drawable對象才可以。

修改後的代碼:

[java]  view plain copy print ?

  1. Spanned sp = Html.fromHtml(html, new Html.ImageGetter() {  
  2.     @Override  
  3.     public Drawable getDrawable(String source) {  
  4.         InputStream is = null;  
  5.         try {  
  6.             is = (InputStream) new URL(source).getContent();  
  7.             Drawable d = Drawable.createFromStream(is, "src");  
  8.             d.setBounds(0, 0, d.getIntrinsicWidth(),  
  9.                     d.getIntrinsicHeight());  
  10.             is.close();  
  11.             return d;  
  12.         } catch (Exception e) {  
  13.             return null;  
  14.         }  
  15.     }  
  16. }, null);  
  17. textView.setText(sp);  

看起來有些複雜,但其實隻是fromHtml()的第二個參數是一個匿名類,用以圖檔的擷取。

其中

[java]  view plain copy print ?

  1. is = (InputStream) new URL(source).getContent();  
  2. Drawable d = Drawable.createFromStream(is, "src");  

用以通過圖檔的位址擷取相應的Drawable執行個體。

由于用到了網絡資源的圖檔,是以要在Mainifest檔案中加入權限:

[html]  view plain copy print ?

  1. <uses-permission android:name="android.permission.INTERNET" />  

修改後的運作結果:

使用Html.fromHtml()怎麼加載Html中的圖檔

圖檔正常顯示了。