项目里面有个多行文本时默认显示2行,点击全文按钮显示全部的需求.
参考[参考链接][1] 实现,以下是自己的一些思考.
显示文本肯定还是使用textview来实现,但如果文本多的时候默认显示2行是怎么做到呢.我们是从网络获取数据,获取到数据后让其显示,超过2行只显示2行,怎么做到超过2行只显示2行了,直接setText,内容会完全显示出来,可能会超过2行.
textView显示多高是height属性控制,如果我们把textView的高度设置为2行的高度,那是不是textView就显示2行了呢,是的,是这样的.思路就是这样,那怎么知道2行多高呢.看textView的api里面有个getLineHeight()方法,是的,这个方法就是1行的高度,正是我们需要的.这样我们直接就textView的高度设置为getLineHeight()2,可不是所有的内容都能达到2行的高度,所以我们需要先判断textView显示了总共多少行,当显示行数超过2行的时候再设置textView的高度为单行高度2,再次查看textView的Api,发现了getLineCount()方法,正如我们期望的,改方法返回的就是textView显示的总行数.注意肯定是先setText内容显示出来之后,再立刻获取改值.所以我们直接:
tvContent.post(new Runnable() {
@Override
public void run() {
int showCount = tvContent.getLineCount();
tvAllSign.setVisibility(maxLine <showCount ? VISIBLE : GONE);
if (showCount > maxLine) {
int singleHeight = tvContent.getLineHeight();
tvContent.setHeight(maxLine * singleHeight);
}
}
});
有了上面2个方法的支撑,展开折叠的思路就非常明显了,当显示行数超过2行时,点击折叠将textview的高度设置为2行的高度,这样就实现了折叠.当显示行数为2行时,点击全文将textView的高度设置为getLineCount()*getLineHeight();直接设置变化有点突兀,给个时间使用ValueAnimator将高度渐变达到要求值.
坑1:注意在使用自定义属性textSize属性的时候
textSize = typedArray.getDimensionPixelSize(R.styleable.ExpandableTextview_textSize,11);
获取到textSize后要使用
tvAllSign.setTextSize(TypedValue.COMPLEX_UNIT_PX, textSignSize);
设置文字大小,获取值与设置textSize使用同一方式,否则你的textView大小不是你期望的.
因为setText的源码:
public void setTextSize(float size) {
setTextSize(TypedValue.COMPLEX_UNIT_SP, size);
}
默认采用的单位是sp.
经过自己测试发现:
typedArray.getDimensionPixelOffset(R.styleable.TestTextSize_customSize,11);
获取到的是数值的整数部分,没有四舍五入奥. 比如11.8获取到的也是11.