给部分文字设置颜色以及点击

xiaoxiao2021-02-28  100

首先要想实现文字变色以及点击,都需要使用到SpannableStringBuilder,实例化该类也很简单,只需将你想要处理的字符串当做参数 SpannableStringBuilder spannable = new SpannableStringBuilder(content); 1 1 那么下边便是开始实现文字变色了,调用SpannableStringBuilder的setSpan方法,该方法有四个参数:  你要设置的颜色需要变色文字开始的Index需要变色文字结束的index这个参数描述文字较多,我就不赘述了点击查看 spannable.setSpan(new ForegroundColorSpan(Color.RED),startIndex,endIndex ,Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); textView.setText(spannable); 123 123 接下来是指定文字的点击事件设置,步骤与设置文字变色基本相同,只需要ClickableSpan这个类来处理点击事件,我们先写一个类,继承ClickableSpan private class TextClick extends ClickableSpan{ @Override public void onClick(View widget) { //在此处理点击事件 } } 123456 123456 接下来又是setSpan这个方法,但第一个参数换成我们继承ClickableSpan类的实例化,其它三个参数同上,需要注意的是setMovementMethod这个方法一定要记得设置,不然点击是不会生效的 //这个一定要记得设置,不然点击不生效 textView.setMovementMethod(LinkMovementMethod.getInstance()); spannable.setSpan(new TextClick(),startIndex,endIndex , Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); 1234 1234 那么接下来出现了一个问题,我既要让文字可点击,但是又要指定它的颜色该怎么办呢。我们查看ClickableSpan的源码会发现,它除了onClick之外,还有updateDrawState @Override public void updateDrawState(TextPaint ds) { ds.setColor(ds.linkColor); ds.setUnderlineText(true); } 12345 12345 它的实现很简单,一目了然,就是设置文字颜色以及是否有下划线。那么这个问题就迎刃而解了,在我们的TextClick重写updateDrawState,即是 private class TextClick extends ClickableSpan{ @Override public void onClick(View widget) { //在此处理点击事件 } @Override public void updateDrawState(TextPaint ds) { ds.setColor(Color.RED); } } 123456789101112 123456789101112 下边加一张简单的效果图  至此,问题就全部解决了!Demo下载地址 转载至:http://blog.csdn.net/u013676055/article/details/50809384
转载请注明原文地址: https://www.6miu.com/read-54494.html

最新回复(0)