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类:

Android加载Html的方法_第1张图片

这个类可以显示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>


效果截图如下: Android加载Html的方法_第2张图片

看右下角那个不能显示的图片,如何可以实现图片显示呢?那就下下面那个重载的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> 这里为了简便直接返回了资源库中的图片了:
Android加载Html的方法_第3张图片



②第三个参数是个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代码中所有的节点标签

更多相关文章

  1. android window的requestWindowFeature()的使用方法
  2. Android异步加载图片
  3. Android对图片局部扩大的实现
  4. Android上实现zlib解压缩的方法 Inflater用法
  5. Android N 7.0中报错:android.os.FileUriExposedException的解决
  6. Android Studio打包生成Jar包的方法
  7. android集成百度地图SDK 自定义keystore无法编译 Keystore was t

随机推荐

  1. 五款不错的Web前端开发工具,可以尝试一下!
  2. 微信偷偷上线了新功能!你发现了吗?
  3. 「 视频云大赛 — 大咖驾到 」下一代技术
  4. 小姐姐用动画图解Git命令,一看就懂!
  5. 利用 Harbor 搭建企业级私有镜像仓库
  6. 如何在Mac上重置SMC?
  7. 虎虎生威,挑战云上魔方(活动期完成可得实
  8. 介绍一款免费好用的可视化数据库管理工具
  9. 微软被指剽窃他人开源作品!作者被迫终止该
  10. 老司机常用的kafka监控-eagle