TextView自定义省略号、部分文字变色、部分文字点击

原创 2016年08月29日 09:34:50

1、如果文本内容超过最大行数,在两个字符串拼接处添加省略号省略代码:

ViewTreeObserver observer = textView.getViewTreeObserver();
observer.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {

@Override
public void onGlobalLayout() {
ViewTreeObserver obs = textView.getViewTreeObserver();
obs.removeGlobalOnLayoutListener(this);
if (textView.getLineCount() > maxLine) {//判断行数大于多少时改变
int lineEndIndex = textView.getLayout().getLineEnd(maxLine - 1); //设置第maxLine行打省略号
String subStr = str.substring(str.lastIndexOf(strFlag));
Log.i("subStr", subStr);
String text = textView.getText().subSequence(0, lineEndIndex - subStr.length()) + "..." + subStr;
textView.setText(text);
}
}
});
}

2、部分文字变颜色:

String str = "小明回复小红:";
int firstStartIndex = 0;
int firstBendIndex = str.indexOf("回复");
int secondStartIndex = str.indexOf("回复") + "回复".length();
int secondBendIndex = str.indexOf(":");
SpannableStringBuilder style = new SpannableStringBuilder(str);
style.setSpan(new BackgroundColorSpan(Color.BLACK), firstStartIndex, firstBendIndex, Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
style.setSpan(new ForegroundColorSpan(Color.BLUE), firstStartIndex, firstBendIndex, Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
style.setSpan(new ForegroundColorSpan(Color.RED), secondStartIndex, secondBendIndex, Spannable.SPAN_EXCLUSIVE_INCLUSIVE);
text_view.setText(style);

3、部分文字可点击:

String str = "小明回复小红:";
int firstStartIndex = 0;
int firstBendIndex = str.indexOf("回复");
int secondStartIndex = str.indexOf("回复") + "回复".length();
int secondBendIndex = str.indexOf(":");
SpannableString spannableString = new SpannableString(str);
spannableString.setSpan(new MyClickableSpan(new OnTextViewClickListener() {
@Override
public void setTextClick() {
Toast.makeText(MainActivity.this, "小明", Toast.LENGTH_SHORT).show();
}
}), firstStartIndex, firstBendIndex, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);


spannableString.setSpan(new MyClickableSpan(new OnTextViewClickListener() {
@Override
public void setTextClick() {
Toast.makeText(MainActivity.this, "小红", Toast.LENGTH_SHORT).show();
}
}), secondStartIndex, secondBendIndex, Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);
//设置点击文字后的文字背景色为透明
text_view.setHighlightColor(getResources().getColor(android.R.color.transparent));
text_view.setMovementMethod(LinkMovementMethod.getInstance());
text_view.setText(spannableString);
public interface OnTextViewClickListener {
void setTextClick();
}

private class MyClickableSpan extends ClickableSpan {
private OnTextViewClickListener onTextViewClickListener;

public MyClickableSpan(OnTextViewClickListener onTextViewClickListener) {
this.onTextViewClickListener = onTextViewClickListener;
}

@Override
public void updateDrawState(TextPaint ds) {
//super.updateDrawState(ds);
//ds.setColor()设定的是span超链接的文本颜色,而不是点击后的颜色,点击后的背景颜色(HighLightColor)属于TextView的属性,Android4.0以上默认是淡绿色,低版本的是黄色。
ds.setColor(Color.BLUE);
}

@Override
public void onClick(View widget) {
onTextViewClickListener.setTextClick();
}
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Android自定义TextView省略号样式

在布局xml中设置textView的字段 android:maxLines="2"  android:ellipsize="end"字段之后,textview会自动压缩行数,并且对压缩掉的部分用......

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

主要对TextView中的部分字符串进行处理,使之具有点击效果,而且可以对该部分字符串颜色大小进行设置等。

Android 中TextView部分文字颜色、点击跳转设置

需要了这样一个需求:在点击提交按钮的之前,客户需要点击已阅读两个说明书。 实现如下:在一个textview中有两部分文字要颜色要与默认颜色不一样,并且可以点击,并跳转到不同的页面。 如下图:蓝色和...

android中textview中文字显示过长、使其用省略号代替,点击显示全部

tv_name.setOnClickListener(new OnClickListener() { Boolean flag = true; @Override publi...

Android 自定义TextView 实现文字对齐排版且支持点击划词

public class TouchSelectWordText extends TextView { private final String TWO_CHINESE_BLANK = "  ";...

TextView部分变色点击

  • 2016-09-20 18:14
  • 5.59MB
  • 下载

自定义的TextView,使部分内容拥有点击事件,并在点击内容上方出现对应的词义等信息

直接看效果图: 上面图中是一个TextView,注册部分内容(KeyWord)是其拥有点击事件,并通过计算KeyWord的坐标,显示KeyWord的想要的一些信息 /** * 一个Tex...

自定义圆角点击变色TextView

项目中经常使用到TextView当作button来使用,显得更加自然,然后每一个TextView的点击事件需要写3个xml 普通状态,按下状态,状态选择。。。 然后写了一个textView对其进行了一...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)