本人也是菜鸟一枚,最近在写一个商城的项目,以前后台传过的数据是Json格式的,但是客户突然有了新的需求,要能传多张图片位置也不固定,所以后台就换成了Html格式的数据了。我知道Android自带了一个方法可以解析Html的数据,
Html.fromHtml(“需要解析的内容”),
单纯的使用这个方法解析一段带有文字和图片的Html的数据,文字能够显示出来,但是图片就显示不出来。所以这就达不到我们的需求。然后我就在网上各种查资料,经过多次运行修改运行修改最终写出了一个比较适合自己的方法。
1.首先这个方法特别简单,解析出来的数据使用一个TextView控件就能全部展示出来,包括图片。
2.因为解析Html需要根据标签解析,虽然这个方法已经包含了这个功能,但是解析出来的图片地址还是需要我们做进一步处理的,我们要根据地址把图片显示出来。
注意以上两点,理解了以后,方法就好写了。
步骤:(1)准备一个放数据的TextView控件。infoContent=(TextView)findViewById(R.id.infoContent);
(2)然后写一个内部类来实现对图片标签的解析及加载,上代码:
public class URLImageParser implements Html.ImageGetter { TextView mTextView; public URLImageParser(TextView textView) { this.mTextView = textView; } @Override public Drawable getDrawable(String source) { String sources=""; final URLDrawable urlDrawable = new URLDrawable();
ImageLoader.getInstance().loadImage(sources, new SimpleImageLoadingListener() { @Override public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) { urlDrawable.bitmap= loadedImage; urlDrawable.setBounds(0, 0, loadedImage.getWidth(), loadedImage.getHeight()); mTextView.invalidate(); mTextView.setText(mTextView.getText()); // 解决图文重叠 } }); return urlDrawable; } }(3)这里用到了一个工具类,用于显示图片:
public class URLDrawable extends BitmapDrawable { public Bitmap bitmap; @Override public void draw(Canvas canvas) { if (bitmap != null) { canvas.drawBitmap(bitmap, 0, 0, getPaint()); } } }(4)最后我们就开始进行调用了:
infoContent.setText(Html.fromHtml("需要解析的内容", new URLImageParser(infoContent), null));
然后就完成了。
希望对初学者有所帮助!