Android TextView显示Html类解析的网页和图片及自定义标签用法示例

Psyche ·
更新时间:2024-11-10
· 545 次阅读

本文实例讲述了Android TextView显示Html类解析的网页和图片及自定义标签。分享给大家供大家参考,具体如下:

Android系统显示HTML网页的最佳控件为WebView,有时候为了满足特定需求,需要在TextView中显示HTML网页、图片及解析自定义标签。

1、TextView显示Html类解析的网页

CharSequence richText = Html.fromHtml("<strong>萝卜白菜的博客</strong>--<a href='http://orgcent.com'>http://orgcent.com</a>"); mTVText.setText(richText); //此行必须,否则超链接无法点击,ScrollingMovementMethod实现滚动条 mTVText.setMovementMethod(LinkMovementMethod.getInstance());

PS: 如果想同时让内容可滚动和超链接可点击,只要设置LinkMovementMethod即可。因为其继承了ScrollingMovementMethod。关于ScrollingMovementMethod说明,可查看android实现TextView垂直或水平滚动

2、TextView显示Html解析的图片和自定义标签

final String html = "萝卜白菜的博客<img src='http://huoche.7234.cn/images/jb51/spmak2t5t5x.jpg'/><mytag color='blue'>自定义</mytag>"; //处理未知标签,通常是系统默认不能处理的标签 final Html.TagHandler tagHandler = new Html.TagHandler() { int contentIndex = 0; /** * opening : 是否为开始标签 * tag: 标签名称 * output:输出信息,用来保存处理后的信息 * xmlReader: 读取当前标签的信息,如属性等 */ public void handleTag(boolean opening, String tag, Editable output, XMLReader xmlReader) { if("mytag".equals(tag)) { if(opening) {//获取当前标签的内容开始位置 contentIndex = output.length(); try { final String color = (String) xmlReader.getProperty("color"); } catch (Exception e) { e.printStackTrace(); } } else { final int length = output.length(); String content = output.subSequence(contentIndex, length).toString(); SpannableString spanStr = new SpannableString(content); spanStr.setSpan(new ForegroundColorSpan(Color.GREEN), 0, content.length(), Spannable.SPAN_INCLUSIVE_EXCLUSIVE); output.replace(contentIndex, length, spanStr); } } System.out.println("opening:" + opening + ",tag:" + tag + ",output:" + output); }}; //解析图片 final Html.ImageGetter imageGetter = new Html.ImageGetter() { public Drawable getDrawable(String source) { //在此必须异步加载图片 Drawable d = null; try { InputStream is = new DefaultHttpClient().execute(new HttpGet(source)).getEntity().getContent(); Bitmap bm = BitmapFactory.decodeStream(is); d = new BitmapDrawable(bm); //setBounds(0, 0, bm.getWidth(), bm.getHeight()); d.setBounds(0, 0, 200, 300); } catch (Exception e) {e.printStackTrace();} return d; } }; richText = Html.fromHtml(html, imageGetter, tagHandler); mTVText.setText(richText);

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android控件用法总结》、《Android视图View技巧总结》、《Android文件操作技巧汇总》、《Android操作SQLite数据库技巧总结》、《Android操作json格式数据技巧总结》、《Android数据库操作技巧总结》、《Android编程之activity操作技巧总结》、《Android编程开发之SD卡操作方法汇总》、《Android开发入门与进阶教程》及《Android资源操作技巧汇总》

希望本文所述对大家Android程序设计有所帮助。

您可能感兴趣的文章:Android实现3D标签云效果Android自定义控件ViewGroup实现标签云(四)解析在Android中为TextView增加自定义HTML标签的实现方法Android开发技巧之在a标签或TextView控件中单击链接弹出Activity(自定义动作)Android中使用include标签和merge标签重复使用布局android nfc常用标签读取总结android配合viewpager实现可滑动的标签栏示例分享Android实现热门标签的流式布局Android入门之ActivityGroup+GridView实现Tab分页标签的方法Android实现3D标签云简单效果



自定义标签 自定义 HTML 示例 图片 标签 Android

需要 登录 后方可回复, 如果你还没有账号请 注册新账号