Android中TextView文本过长滚动显示实现

项目中在使用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);

滚动效果就有了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值