android自定义textview---富文本的使用

首先重写这个类:
该类中可以重新定义显示的字体、颜色以及下划线等
public class ClickSpan extends ClickableSpan{
String text;
@Override
public void onClick(View widget) {
// TODO Auto-generated method stub

}

public ClickSpan(){
super();
}

@Override
public void updateDrawState(TextPaint ds) {
// TODO Auto-generated method stub
//颜色下划线等
super.updateDrawState(ds);

ds.setColor(Color.parseColor("#b01313"));
ds.setUnderlineText(false);
}



}

然后使用:


htmlText = "<font color='#000000'>" + "简介:" + tv.getShow() + "</font>";
htmlText2 = "<font color='#b01313'>[+展开]</font><br/>";
htmlText3 = "<font color='#b01313'>[收回]</font><br/>";
text = Html.fromHtml(htmlText + htmlText2);
spannableString = new SpannableString(text);
spannableString.setSpan(
new ClickSpan() {
[align=left][/align]
@Override
public void onClick(View widget) {
if (flag) {
flag = false;
tv.setAll(flag);
text = Html.fromHtml("<font color='#000000'>"
+ "简介:" + tv.getShow() + "</font>"
+ htmlText3);
SpannableString spannableString2 = new SpannableString(
text);
spannableString2.setSpan(new ClickSpan() {

@Override
public void onClick(View widget) {
flag = true;
tv.setAll(flag);
content.setText(spannableString);
}
}, text.length() - 5, text.length() - 1,
Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
content.setText(spannableString2);
}
}
}, text.length() - 6, text.length() - 1,
Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);

content.setText(spannableString);
content.setMovementMethod(LinkMovementMethod.getInstance());//不要忘了这句话
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值