概述
做Android的都知道textView这个控件,在常用不过啦,都知道它可以显示不同 的颜色的文本,但是同一个textView 控件,同一段文字能够根据 自己的需要显示 不同的颜色、识别emoj如同请求表情、网页中的图片、html标签的富文本等;之前自己也多次在项目中用到过,今天做下简单的总结,也希望对其他朋友有所帮助。
首先是识别html中各种标签:
1)html中常用的标签:
HTML 标题(Heading)是通过 <h1> - <h6> 等标签进行定义的。例如:<h1>This is a heading</h1>
HTML 段落是通过 <p> 标签进行定义的。例如:<p>This is a paragraph.</p>
HTML 链接是通过 <a> 标签进行定义的。例如:<a href="http://www.w3school.com.cn">This is a link</a>
HTML 图像是通过 <img> 标签进行定义的。例如:<img src="w3school.jpg" width="104" height="142" />
HTML通过加粗强调文本例如 <em>强调文本(通常是斜体加黑体)</em>
HTML通过斜体加黑体强调文本例如<strong></strong> 加重文本(通常是斜体加黑体)
HTML通设置文本字体的大小和颜色例如<font size="" color=""></font> 设置字体大小从1到7,颜色使用名字或RGB的十六进制值
还有一些其他标签:
<big></big> 字体加大
<SMALL></SMALL> 字体缩小
<STRIKE></STRIKE> 加删除线
<sup></SUP> 上标字
<SUB></SUB> 下标字
以上都可以通过texString tv1conent = "<font color='#ff0000'>" + "android 富文本显示" + "</font><br/>" + "<font color='#00ff00'>" + "昆明景色宜人四季如春" + "</font>";
tv1.setText(Html.fromHtml(tv1conent));tView 来实现:
2)显示图片的文本
运用html中的img标签:
String viewContent = "<img src='" + R.mipmap.circle_icon_good_selected + "'>" + "<font color='#0000ff'>" + "被选中的状态" + "</font>";
tv2.setText(Html.fromHtml(viewContent2, new Html.ImageGetter() {
@Override
public Drawable getDrawable(String s) {
int drawableId = Integer.parseInt(s);
Drawable drawable = getResources().getDrawable(drawableId);
drawable.setBounds(0, 0, drawable.getIntrinsicWidth(), drawable.getIntrinsicHeight());
return drawable;
}
}, null));
---------------------------------------------------------------------------------------------------------------------------------------------------------------------
除啦通过以上那这个呢方式来实现也可以使用一下两种方法:
- 通过xml的布局文件,在textView的xml中设置drawableLef 、tdrawableRight、drawableBottom、drawableEnd、drawableStart、drawableTop来设置图片显示的方向;设置drawablePadding可以设置图片和文字的距离
- 也可以使用Java代码的形式 来设置 Drawable drawable = getResources().getDrawable(R.mipmap.circle_icon_good_selected);
tv2.setCompoundDrawables(drawable, null, null, null); drawable.setBounds(0,0,drawable.getIntrinsicWidth(),drawable.getIntrinsicHeight());需要注意的是咋使用代码设置textView张显示图片时必须要设置setBounds()这一属性,否则图片会显示不出来。- 其实还有方式也可以显示富文本内容可以使用spannableString
- SpannableStringBuilder builder = new SpannableStringBuilder();
int startPoint = builder.length();
builder.append("[abstract]");//占位使用
int endPoint = builder.length();
MyImageSpan imageSpan = new MyImageSpan(this, R.mipmap.circle_icon_good_normal);
builder.setSpan(imageSpan, startPoint, endPoint, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
builder.append(" ");
// builder.append(brief);
tv5.setText(builder);
//第二种形式
String str = "这是设置TextView部分文字背景颜色和前景颜色的哭大哭偷笑大笑demo!";
int bstart = str.indexOf("背景");
int bend = bstart + "背景".length();
int fstart = str.indexOf("前景");
int fend = fstart + "前景".length();
SpannableStringBuilder style = new SpannableStringBuilder(str);
style.setSpan(new BackgroundColorSpan(Color.RED), bstart, bend, Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
style.setSpan(new ForegroundColorSpan(Color.RED), fstart, fend, Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
tv6.setText(style);- demo下载地址:http://download.csdn.net/download/smxueer/9951865
最后
以上就是勤奋向日葵为你收集整理的Android TextView富文本的使用的全部内容,希望文章能够帮你解决Android TextView富文本的使用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复