使用 TextView 缓存显示html页面中图片

使用SDK中已有的ImageGetter来显示html中的图片

    //mTv是你显示html所使用的TextView
    mTv.setText(Html.fromHtml("要显示的html", imageGetter, null));
/**
     * html显示
     */
    private Html.ImageGetter imageGetter = new Html.ImageGetter() {
        @Override
        public Drawable getDrawable(String s) {
        //字符串s是html中的图片链接
            LogUtils.i("test", s);
            InputStream is = null;
            try {
                URL url = new URL(s);
                is = url.openStream();
                Drawable d = Drawable.createFromStream(is, "image.jpg");
                //限制图片显示位置和大小
                d.setBounds(0, 0, d.getIntrinsicWidth(),
                        d.getIntrinsicHeight());
                is.close();
                return d;
            } catch (Exception e) {
                try {
                    if(is != null){
                    //记得在异常处理中加关闭is的代码
                        is.close();
                    }
                } catch (IOException e1) {
                    e1.printStackTrace();
                }
                return null;
            }
        }
    };

不过这段代码涉及了从网络获取图片,如果要显示的图片一多就会特别卡,要是在主线程中使用还会把app给kill了。我最开始是在网上找的一个用异步加载html中图片的方法,不过那方法在显示图片的时候必须设置图片大小,不然会出现图片重叠。不过我最后找到了一个使用ImageLoader加载图片的方法,解决了这个问题。

使用ImageLoader加载html中的图片

使用这种方法必须重写ImageGetter和重新自己定义一个BitmapDrawable 类

//使用方式:
mTv.setText(Html.fromHtml(farmLand.getContent(), new URLImageGetter(mTv), null));

URLDrawable.java:

public class URLDrawable extends BitmapDrawable {

    protected Bitmap bitmap;

    @Override
    public void draw(Canvas canvas) {
        if (bitmap != null) {
            canvas.drawBitmap(bitmap, 0, 0, getPaint());
        }
    }
}

URLImageGetter.java:

public class URLImageGetter implements Html.ImageGetter {

    TextView textView;

    public URLImageGetter(TextView textView) {
        this.textView = textView;
    }

    @Override
    public Drawable getDrawable(String paramString) {

        final URLDrawable urlDrawable = new URLDrawable();
        ImageLoader.getInstance().loadImage(paramString, new SimpleImageLoadingListener() {
            @Override
            public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
                urlDrawable.bitmap = loadedImage;
                urlDrawable.setBounds(0, 0, loadedImage.getWidth(), loadedImage.getHeight());
                //textView.invalidate();
                //为了防止图片重叠必须重新设置textView
                textView.setText(textView.getText()); 
            }
        });
        return urlDrawable;
    }
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值