美文网首页Android知识点点滴汇聚
Android 多行文本折叠展开效果

Android 多行文本折叠展开效果

作者: 幸福的程序媛 | 来源:发表于2016-10-29 21:49 被阅读1087次

    项目里面有个多行文本时默认显示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.

    相关文章

      网友评论

        本文标题:Android 多行文本折叠展开效果

        本文链接:https://www.haomeiwen.com/subject/scvyuttx.html