您的位置:首页 > 移动开发 > Android开发

Android加载Html的方法

2015-10-15 10:25 671 查看
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系统会直接会用一个默认的图片放上去,等着我们自己去加载图片,完成之后,把加载成功的图片替代上去,

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

效果截图如下:


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

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

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

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;
}
};

   这里为了简便直接返回了资源库中的图片了:



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

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

   上面就直接返回了传入的那段HTML代码中所有的节点标签
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: