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代码中所有的节点标签