使用TextView显示网页中的图片

随时随地阅读更多技术实战干货,获取项目源码、学习资料,请关注源代码社区公众号(ydmsq666)、QQ技术交流群(183198395)。

Html类下有一个ImageGetter接口可以帮助我们完成,直接上代码:

MainActivity:

package com.home.testhtml;

import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;

import android.app.Activity;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.text.Html;
import android.text.Html.ImageGetter;
import android.text.Spanned;
import android.widget.TextView;

public class MainActivity extends Activity {
	private TextView tv;
	private String htmlStr = "<h1>测试html的img标签</h1><p font='red'>这里是测试内容</p><p><img src='http://avatar.profile.csdn.net/A/E/5/2_piaopiaohu123.jpg'></p>";
	private Handler mHandler = new Handler() {
		public void handleMessage(Message msg) {
			Spanned sp = (Spanned) msg.obj;
			tv.setText(sp);
		};
	};

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		tv = new TextView(this);
		setContentView(tv);
		new Thread() {
			public void run() {
				Spanned sp = Html.fromHtml(htmlStr, new MyImageGetter(), null);
				Message msg = new Message();
				msg.obj = sp;
				mHandler.sendMessage(msg);
			};
		}.start();
	}

	class MyImageGetter implements ImageGetter {

		@Override
		public Drawable getDrawable(String source) {
			Drawable mDrawable = null;
			try {
				mDrawable = Drawable.createFromStream(
						new URL(source).openStream(), "test.jpg");
				mDrawable.setBounds(0, 0, mDrawable.getIntrinsicWidth(),
						mDrawable.getIntrinsicHeight());
			} catch (MalformedURLException e) {
				e.printStackTrace();
			} catch (IOException e) {
				e.printStackTrace();
			}
			return mDrawable;
		}

	}
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

u010142437

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值