标签:android style color io ar strong 数据 sp c
第一种:
通过Html.fromHtml(String,ImageGetter,tagHandler)
CharSequence text = Html.fromHtml(capter, new ImageGetter() {
@Override
public Drawable getDrawable(String source) {
Drawable drawable = null;
try {
drawable = Drawable.createFromStream(new URL(source).openStream(),"image");//从远程获取图片
drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight());//要设置边界信息 Drawable本身是没有边界信息的
} catch (Exception e) {
e.printStackTrace();
}
return drawable;
}}, null);
capter_view= (TextView)findViewById(R.id.bookcapter);
capter_view.setText(text);//就可以显示出img的图片信息了(推荐)
第二种:
这个需要服务端配合,服务端需要将图片和文字信息在服务端分割开,同时给index来标示位置(为了解决内容分割后不会交叉,客户端可以按index按原来的顺序来排列显示)
服务端返回的是以图片img标签分割的json数组(这个操作android端应该也可以做)
客户端遍历json数组显示
如果是img的类型则创建ImageView来显示img
如果是text的类型则创建TextView来显示text
这块操作可以封装成 继承LinearLayout 的自定义TestView控件
然后把json数组转成List<HashMap<key,value>> datas;
模拟TextView的setText方法,我们也可以自定义一个setText(),当然你也可以定义其他名称,这个方法不是重写,所以随便自定义。
在这个方法里遍历数据生成ImageView或TextView
最后通过调用TestView.setText(datas);
就可以显示出来图片了
(但服务端的数据结构需要和客户端协议好,数据格式固定,个人觉得不是很灵活。)
标签:android style color io ar strong 数据 sp c
原文地址:http://www.cnblogs.com/jshen/p/4008062.html