项目中在使用TextView时,总会有因要显示的内容过多而需要我们进行处理的问题。我们第一时间想到的是TextView的android:ellipsize属性,
比如 android:ellipsize="end",效果是在文字的尾部打三个小点。
但是这个属性要配合android:singLine="true"使用。通常来说,要实现尾端三个点的省略号形式是比较容易的。
如果要求文字全部显示,但是为了保存UI界面美观,有限大小的TextView中如何显示全部的超长文本呢,我们就想到了让文本滚动显示。
大家也想到了通过 android:ellipsize="marquee"来实现,不过我在项目中使用这个也没有实现效果。
配合了android:singLine="true"也一样不能实现文本滚动显示。网上有很多解决方案,几乎都是说到焦点问题。
比如有人建议在布局文件中的TextView添加 android:focusable="true",不过有时也是没有效果的。
我的处理方法是,复写TextView,只要简单地改一个代码即可:
public class MarqueTextView extends TextView {
public MarqueTextView(Context context, AttributeSet attrs, int defStyle) {
super(context, attrs, defStyle);
}
public MarqueTextView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public MarqueTextView(Context context) {
super(context);
}
@Override
public boolean isFocused() {
//就是把这里返回true即可
return true;
}
}
然后把复写的TextView当成控件写在布局文件中,添加:
android:marqueeRepeatLimit="marquee_forever"
android:ellipsize="marquee"
android:singleLine="true"
等属性,当然不要忘记写width,height等必备属性哦。
最后在使用该TextView的时候,还要添加一句:
MarqueTextView tv=(MarqueTextView)findViewById(R.id.my_text_view);
tv.setSelected(true);
滚动效果就有了。