TextView使部分文字具有超链接(或点击)功能

最近项目中用到一个字符串后面跟着另外一个带有点击效果的字符串,开始用2个TextView,在一个LinearLayout布局中水平显示,第一个TextView正常显示字符串,第二个TextView也显示带有颜色的字符串,添加了点击效果setOnClickListener。结果发现在其他语言的情况下,第一个字符串显示过长,会导致第二个字符串显示部分或者不显示,严重影响使用和体验。本篇博客就是对字符串进行处理,使其中的部分字符串str2具有点击效果。

所以将2个TextView改成一个,将字符串Can\'t find?%1$s,在代码中动态的将另外一个字符串添加进去。代码如下:

String str2 = getString(R.string.str2);
    	SpannableString strAll= new SpannableString(getString(R.string.str1,str2));//对str1和str2进行拼接
    	int i = strAll.toString().indexOf(str2); //得到str2开始的位置
    	strAll.setSpan(new ClickSpanOpen(this), i, i + str2.length(),
                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); //参数是:继承ClickableSpan的类,对应效果的开始位置,对应效果的结束位置
    	final TextView message = (TextView) findViewById(R.id.search);
    	if(message == null) {
    		return;
    	}
        message.setText(strAll);
        message.setMovementMethod(LinkMovementMethod.getInstance());

setMovementMethod(LinkMovementMethod.getInstance());这行代码很重要,如果没有这行代码,TextView中的部分字符串点击效果就不起作用了。

下面介绍一下自定义的ClickSpanOpen类:
public class ClickSpanOpen extends ClickableSpan {

        private Context context;

        public ClickSpanOpen(Context context) {
            super();
            this.context = context;
        }

        @Override
        public void onClick(View widget) {  	
        	//要执行的操作
        }

        @Override
        public void updateDrawState(TextPaint ds) {
            // TODO Auto-generated method stub
            super.updateDrawState(ds);          
            ds.setColor(context.getResources().getColor(R.color.autolink_color));//设置文本的颜色
            ds.setUnderlineText(false);//超链接形式的下划线,false 表示不显示下划线,true表示显示下划线
        }

    }
这样就会前面字符串正常显示,后面的字符串带有颜色,且有点击效果,并且会自动换行,不影响使用。






你可能感兴趣的:(android应用)