Android中TextView文本过长滚动显示实现
来源:互联网 发布:华云数据 融资 编辑:程序博客网 时间:2024/06/05 05:15
项目中在使用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);
滚动效果就有了。
阅读全文
2 1
- Android中TextView文本过长滚动显示实现
- TextView布局文件中实现文本过长时滚动显示效果
- android中textView文本过长打省略号
- Android:文本过长,实现添加滚动条
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- 【转】Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android之TextView实现文字过长时省略部分或者滚动显示
- Android中TextView内容过长 添加滚动条进行展示
- android中textview文本滚动效果
- 目标检测模型(不用在ImageNet上预训练)
- 机器学习基石 8.3 Algorithmic Error Measure
- C++结构体和JSON字符串之间的相互转换
- 防火墙策略_firewall
- 用JS做下拉菜单
- Android中TextView文本过长滚动显示实现
- C#学习笔记-C#中Json.Net(newtonjs)的使用
- github|fatal:unable to access|OpenSSL SSL_connect: SSL_ERROR_SYSCALL in connection to github.com 443
- Ctrl+H 浪潮Raid配置文档
- 好用的图标插件 Font Awesome
- 决策树小结
- 用线程解决简单的两车相遇
- Makefile执行过程中出错:make: *** No rule to make target ` ‘, needed by xxx. Stop.
- html5中canvas元素使用