Android学习札记47:TextView显示Html类解析的网页和图片及自定义标签
2012-08-22 23:50
816 查看
1、TextView 显示 Html 类解析的网页
PS:如果想同时让内容可滚动和超链接可点击,只要设置 LinkMovementMethod 即可,因为其继承了 ScrollingMovementMethod。
2、TextView 显示 Html 解析的图片和自定义标签
转载自:
http://orgcent.com/android-textview-parse-html-image-tag/
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。
2、TextView 显示 Html 解析的图片和自定义标签
final String html = "萝卜白菜的博客<img src='http://m3.img.libdd.com/farm3/115/BBE681F0CAFB16C6806E6AEC1E82D673_64_64.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);
转载自:
http://orgcent.com/android-textview-parse-html-image-tag/
相关文章推荐
- Android TextView显示Html类解析的网页和图片及自定义标签用法示例
- TextView显示Html类解析的网页和图片及自定义标签
- TextView显示Html类解析的网页和图片及自定义标签
- TextView显示Html类解析的网页和图片及自定义标签
- TextView显示Html类解析的网页和图片及自定义标签
- Android在TextView中显示html标签以及异步加载网页图片
- Android学习札记51:在TextView显示插入的图片
- Android自定义TextView实现文字图片居中显示
- Android自定义TextView实现文字图片居中显示的方法
- android---textview控件学习笔记之显示表情图片和文本(二)
- 解析在Android中为TextView增加自定义HTML标签的实现方法
- android 让TextView支持的Html标签实现自定义时钟显示组件DigitalClock
- Android学习札记48:将TextView中的指定文字转换为表情显示
- Android中SpannableString学习以及实现自定义TextView的显示更多(展开)和收起功能
- Android TextView 显示HTML代码以及代码中的图片标签
- 解析在Android中为TextView增加自定义HTML标签的实现方法
- Android学习之TextView显示html图片的方法
- Android基础教程——在TextView中显示Html 自定义标签,获取标签属性
- android 使用html标签在textview中显示图片
- Android 自定义view-如何设置TextView drawableLeft 图片大小?