您的位置:首页 > 移动开发 > Android开发

Android TextView内容过长加省略号,点击显示全部内容

2015-01-29 22:23 573 查看
Android TextView中有个内容过长加省略号的属性,即ellipsize,用法如下:

在xml中:

android:ellipsize="end"   省略号在结尾

android:ellipsize="start"   省略号在开头

android:ellipsize="middle" 省略号在中间

android:ellipsize="marquee" 跑马灯

最好加一个TextView显示行数的约束,例如:android:singleline="true"或者android:lines="2"

在java文件中:

tv.setEllipsize(TextUtils.TruncateAt.valueOf("END"));

tv.setEllipsize(TextUtils.TruncateAt.valueOf("START"));

tv.setEllipsize(TextUtils.TruncateAt.valueOf("MIDDLE"));

tv.setEllipsize(TextUtils.TruncateAt.valueOf("MARQUEE"));

最好加一个TextView显示行数的约束,例如:tv.setSingleLine(true);

不仅对于textview有此属性,对于editext也有,不过它不支持marquee。

文字展开和收缩

public class DemoActivity extends BaseActivity {

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main); // 在xml文件中设置了android:singleline="true"

final TextView tv = (TextView)findViewById(R.id.task_2_title);

//tv.setMovementMethod(ScrollingMovementMethod.getInstance());

tv.setOnClickListener(new OnClickListener() {

Boolean flag = true;

@Override

public void onClick(View v) {

Log.i("tv.getLineCount()",tv.getHeight()+"");

if(flag){



flag = false;

tv.setEllipsize(null); // 展开

//tv.setSingleLine(flag);

}else{

flag = true;

tv.setEllipsize(TextUtils.TruncateAt.END); // 收缩

//tv.setSingleLine(flag);

}

}

});

}

}其实,只是把样式清空而已。就能完全展开了。有人可能要说,万一我想初始几行呢?放心,一样可以。上代码:在xml文件中设置了如下属性:android:lines="4" //我初始化的4行 Activity那边代码一样,只改一点 if(flag){

flag = false;

tv.setEllipsize(null); // 展开

tv.setSingleLine(flag);

}else{

flag = true;

tv.setEllipsize(TextUtils.TruncateAt.END); // 收缩

}

设置setSingleLine的目的是为了取消lines==“4”这个固定值

————————————————————————————————————————————————————————————

实例:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:orientation="vertical" >

    <ImageView
        android:id="@+id/vod_grid_img"
        android:layout_width="100dp"
        android:layout_height="70dp"
        android:background="@drawable/default_movie_post" />

    <LinearLayout
        android:layout_width="100dp"
        android:layout_height="70dp" >

        <TextView
            android:id="@+id/vod_grid_text"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:gravity="center|top"
            android:textColor="@color/black"
            android:textSize="15sp"
            android:ellipsize="end"
            android:lines="3" />
    </LinearLayout>

</LinearLayout>


效果:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: