Android加载Html的方法


http://blog.csdn.net/yhb5566/article/details/7922660


1.跳转到浏览器直接访问页面,这段代码是在Activity中拷贝来的,所以有startActivity()方法

Uri uri = Uri.parse("http://www.XXXX.com"); //要链接的地址

Intent intent = new Intent(Intent.ACTION_VIEW, uri);

startActivity(intent);

2.使用TextView显示HTML方法

TextView text1 = (TextView)findViewById(R.id.TextView02);

text1.setText(Html.fromHtml(“<font size='20'>网页内容</font>”));

3.直接使用android中自带的显示网页组件WebView

webview = (WebView) findViewById(R.id.WebView01);

webview.getSettings().setJavaScriptEnabled(true);

webview.loadUrl("http://www.xxxx.com");
4 显示本地html
@1
webview = (WebView) findViewById(R.id.webview); 
webview.getSettings().setJavaScriptEnabled(true); 
webview.loadUrl("content://com.android.htmlfileprovider/sdcard/index.html");
@2
Uri uri = Uri.parse("content://com.android.htmlfileprovider/sdcard/01.htm");
Intent intent = new Intent();
intent.setData(uri);
intent.setClassName("com.android.htmlviewer", "com.android.htmlviewer.HTMLViewerActivity");
startActivity(intent);

@3
String encoding = "UTF-8";
String mimeType = "text/html";
final String html = 
"<p><a href=\"file:///sdcard/web/acdf2705\">链接google</a></p>"+ 
"<p><a href=\"file:///sdcard/ebook/user_defined/browser/localweb/\532fa8dc\"& gt;链接google</a></p>"; 

mWebView.loadDataWithBaseURL("file://", html,mimeType, encoding, "about:blank");



===========================================================================


 今天学习了TextView的进行加载HTML来显示文字,图片等信息;

     首先来看一个Textview的一个属性android:autoLink 这个属性来解析Textview的中的一些特殊字符例如:web,email,phone,map,..当还可以通过android:textColorLink来设定这些特殊字符的颜色;另外其他的属性可以设定字体大小,颜色等等;虽然这些都可以实现所需要的功能,不过Google还提供了一个Html类来直接加载HTML代码。一起来学习下。

(一):看下Html类的继承图:这是直接继承了Object类:

 \

这个类可以显示Html代码转换成对应的text,但不是所有的HTML的标签都支持。

      Html主要有下面的方法:

1:public static Spanned fromHtml (String source)

    这个方法是返回显示的文本,但是如果遇到img标签的话,android系统会直接会用一个默认的图片放上去,等着我们自己去加载图片,完成之后,把加载成功的图片替代上去,


[java] <span style="font-size: 16px; ">      _TextView 
                .setText(Html 
                        .fromHtml("<b>江苏</b><h1>南通</h1><font color='#00FF00'>海门</font>" + 
                                "<img src='http://developer.android.com/assets/images/bg_logo.png'/>"));</span> 


效果截图如下: \

看右下角那个不能显示的图片,如何可以实现图片显示呢?那就下下面那个重载的fromHtml方法...

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

    ①:这个重载方法中第二个参数是个ImageGetter接口 其中我们实现这个接口的一个public abstract Drawable getDrawable (String source)方法,这个方法来加载图片,【注意:这是一定要调用setbounds()方法来设置图片的大小】


[java] <span style="font-size: 18px; ">  </span><span style="font-size: 16px; ">ImageGetter _ImageGetter = new Html.ImageGetter() { 
            @Override 
            public Drawable getDrawable(String source) { 
                if (source != null) { 
                    BitmapDrawable _BitmapDrawable = (BitmapDrawable) getResources() 
                            .getDrawable(R.drawable.tu); 
                    _BitmapDrawable.setBounds(0, 0, 100, 100); 
                    return _BitmapDrawable; 
                } 
                return null; 
            } 
        };</span> 
<span style="font-size: 18px; "> </span><span style="font-size: 16px; ">ImageGetter _ImageGetter = new Html.ImageGetter() {
   @Override
   public Drawable getDrawable(String source) {
    if (source != null) {
     BitmapDrawable _BitmapDrawable = (BitmapDrawable) getResources()
       .getDrawable(R.drawable.tu);
     _BitmapDrawable.setBounds(0, 0, 100, 100);
     return _BitmapDrawable;
    }
    return null;
   }
  };</span>   这里为了简便直接返回了资源库中的图片了:
\



②第三个参数是个TagHandler 接口,实现这个接口中的public abstract void handleTag (boolean opening, String tag, Editable output, XMLReader xmlReader)方法来解析标签,尤其那些不是属于HTML的中标签,可以理解为自定义的。。。


[java] TagHandler _TagHandler = new Html.TagHandler() { 
            @Override 
            public void handleTag(boolean opening, String tag, Editable output, 
                    XMLReader xmlReader) { 
                Toast.makeText(TestActivity.this, tag, 2000).show(); 
            } 
        }; 
TagHandler _TagHandler = new Html.TagHandler() {
   @Override
   public void handleTag(boolean opening, String tag, Editable output,
     XMLReader xmlReader) {
    Toast.makeText(TestActivity.this, tag, 2000).show();
   }
  };

   上面就直接返回了传入的那段HTML代码中所有的节点标签



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值