一种可以展开收起的TextView

项目中我们经常遇到遇到这样一种情况,当你的TextvView里面内容很多时,需要隐藏一部分,并提供展开,收起的功能,下面是我的一个小demo

可以写出一个自定义控件。

package com.mrpeng.collapsibletextviewdemo;

import android.content.Context;
import android.text.TextUtils;
import android.util.AttributeSet;
import android.view.View;
import android.widget.LinearLayout;
import android.widget.TextView;

/**
 * <一句话功能描述>
 * <功能详细描述>
 *
 * @author pengjingnag
 * @see [相关类/方法]
 * @since [产品/模板版本]
 * @deprecated
 */
public class CollapsibleTextView extends LinearLayout implements View.OnClickListener
{

    /** default text show max lines */
    private static final int DEFAULT_MAX_LINE_COUNT = 2;

    //
    private static final int COLLAPSIBLE_STATE_NONE = 0;
    private static final int COLLAPSIBLE_STATE_SHRINKUP = 1;
    private static final int COLLAPSIBLE_STATE_SPREAD = 2;
    private final TextView mDesc;
    private final TextView mDescOp;
    private String str;

    private int mState;
    //默认false
    private boolean flag;

    public CollapsibleTextView(Context context, AttributeSet attrs)
    {
        super(context, attrs);
        View inflate = inflate(context, R.layout.collapsible_textview, this);
        mDesc = (TextView)inflate.findViewById(R.id.desc_tv);
        mDescOp = (TextView)inflate.findViewById(R.id.desc_op_tv);
        mDescOp.setOnClickListener(this);


    }

    /**
     * 当View确定本身已经不再适合现有的区域是,该view本身
     * 调用这个方法,要求ParentView重新调用它的OnMeasure
     * onLayout方法来重新设置自己位置
     * 特别的当view的layoutparameter发生改变,并且它的值还没能应用到view上,这时候
     * 适合调用这个方法,
     * 此外有个invalidate:view本身迫使view重画
     */
    public final void setDesc(String str)
    {
        this.str = str;
        mState = COLLAPSIBLE_STATE_SPREAD;

        mDesc.setText(str);
        requestLayout();


    }

    /**
     * onLayout方法是ViewGroup中子View的布局方法,
     * 用于放置子View的位置。放置子View很简单,
     * 只需在重写onLayout方法,然后获取子View的实例,
     * 调用子View的layout方法实现布局。在实际开发中,
     * 一般要配合onMeasure测量方法一起使用。
     *
     * 父视图的子视图的个数为0,就会执行一次。
     * 否则就会执行多次。因为开始时父试图中是没有子试图的。
     * 但是当你从xml文件中加载子试图或者在java代码中添加子试图时,
     * 父试图的状态会发生变化,这个变化会引起onlayout甚至是onmeasure。
     *
     * @param changed
     * @param l
     * @param t
     * @param r
     * @param b
     */

    @Override
    protected void onLayout(boolean changed, int l, int t, int r, int b)
    {
        super.onLayout(changed, l, t, r, b);
        //此处flag相当重要,onLayout执行完,即设为true,使得只执行一次。
        if(!flag)
        {
            flag = true;
            /**
             * 文本行数比设定的还小
//             */
            if(mDesc.getLineCount()<=DEFAULT_MAX_LINE_COUNT)
            {
                mState = COLLAPSIBLE_STATE_NONE;
                mDescOp.setVisibility(GONE);
                mDesc.setMaxLines(DEFAULT_MAX_LINE_COUNT+1);

            }else
            {
                /**
                 * 抛到UI线程
                 */
                post(new InnerRunnable());
            }


        }


    }

    @Override
    public void onClick(View v)
    {
        flag = false;
        requestLayout();
        mDesc.setEllipsize(null);
    }

    private class InnerRunnable implements Runnable
    {
        @Override
        public void run()
        {
            if(mState == COLLAPSIBLE_STATE_SPREAD)
            {
                mDesc.setMaxLines(DEFAULT_MAX_LINE_COUNT);
                mDescOp.setVisibility(VISIBLE);
                mDescOp.setText("展开");
                mDesc.setEllipsize(TextUtils.TruncateAt.END);
                mState = COLLAPSIBLE_STATE_SHRINKUP;
            }else if(mState == COLLAPSIBLE_STATE_SHRINKUP)
            {
                mDesc.setMaxLines(Integer.MAX_VALUE);
                mDescOp.setVisibility(VISIBLE);
                mDescOp.setText("收起");
                mState = COLLAPSIBLE_STATE_SPREAD;
            }
        }
    }
}
在xml中引用它

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.mrpeng.collapsibletextviewdemo.CollapsibleTextView
        android:id="@+id/main"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"></com.mrpeng.collapsibletextviewdemo.CollapsibleTextView>
</RelativeLayout>



最后在act中显示之:

public class MainActivity extends AppCompatActivity
{

    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        CollapsibleTextView textView = (CollapsibleTextView)findViewById(R.id.main);
        textView.setDesc(this.getString(R.string.text));

    }
}


源码:点击打开链接






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值