更多精彩内容,请点击阅读: 《api demos 2.3 学习笔记》 在textview及其子类控件中,当文本内容太长,超过控件长度时,默认情况下,无法完全显示文本内容。此时,通过在xml布局文件中设置控件的android:ellipsize属性,可以将无法显示的部分用省略号表示,
更多精彩内容,请点击阅读:《api demos 2.3 学习笔记》
在textview及其子类控件中,当文本内容太长,超过控件长度时,默认情况下,无法完全显示文本内容。此时,通过在xml布局文件中设置控件的android:ellipsize属性,可以将无法显示的部分用省略号表示,并放在文本的起始,中间或者结束位置;还可以跑马灯的方式来显示文本(即文本控件获得焦点时,文本会进行滚动显示)。具体设置方法如下所示:
1、默认不处理
android:singleline=trueandroid:ellipsize=none
2、省略号放在起始
android:singleline=trueandroid:ellipsize=start
3、省略号放在中间
android:singleline=trueandroid:ellipsize=middle
4、省略号放在结束
android:singleline=trueandroid:ellipsize=end
5、跑马灯效果
android:focusable=trueandroid:focusableintouchmode=trueandroid:singleline=trueandroid:ellipsize=marqueeandroid:marqueerepeatlimit=marquee_forever
注:1、android:singleline=true表示单行显示。
2、在设置跑马灯效果时候,最好加上android:focusable=true和android:focusableintouchmode=true,分别表示可以获得焦点,和在触摸模式下可以获得焦点。
3、android:marqueerepeatlimit表示跑马灯效果重复显示的次数,只能取值marquee_forever和正整数。取值marquee_forever时,表示跑马灯效果一直重复显示。
下面我们进行实例代码解析:
res-value-string.xml
this use the default marquee animation limit of 3this will run the marquee animation oncethis will run the marquee animation forever
res-layout-marquee.xml
src-com.example.android.apis.text-marquee.javapackage com.example.android.apis.text;import com.example.android.apis.r;import android.app.activity;import android.os.bundle;public class marquee extends activity { @override protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); //将marquee布局文件渲染出一个view对象,并作为activity的默认view setcontentview(r.layout.marquee); }}
效果预览: