Android用过TextView实现跑马灯效果的示例
程序员文章站
2023-11-20 19:03:10
以前就遇到过这个问题,今天重新拾起来。
跑马灯效果其实就是当文字超过textview控件宽度的时候,使用滚动的方式显示出来:
方法1:(直接xml搞定)
androi...
以前就遇到过这个问题,今天重新拾起来。
跑马灯效果其实就是当文字超过textview控件宽度的时候,使用滚动的方式显示出来:
方法1:(直接xml搞定)
android系统中textview实现跑马灯效果,必须具备以下几个条件:
1、android:ellipsize=”marquee”;
2、textview必须单行显示,且内容必须超出textview宽度;
3、textview要获得焦点才能滚动。
xml代码如下:
<textview android:id="@+id/alarm_location" android:layout_width="20dp" android:padding="@dimen/space_4" android:layout_height="wrap_content" app:layout_rowweight="2" app:layout_columnweight="2" android:text="0" android:ellipsize="marquee" android:focusableintouchmode="true" android:singleline="true" android:focusable="true"/>
其中:ellipsize属性指的是文字长度超过textview的长度的时候的显示方式,具体参数有
**android:ellipsize=”start”—–省略号显示在开头 “…pedia”
android:ellipsize=”end”——省略号显示在结尾 “encyc…”
android:ellipsize=”middle”—-省略号显示在中间 “en…dia”
android:ellipsize=”marquee”–以横向滚动方式显示(需获得当前焦点时)**
方法2(自定义控件)
我看了自己以前的实现方式是这样,也许在低版本的平台上第一种方式适配不好吧。如果达不到要求可以试试这种方式。
textveiwslide.java
package edu.hrbeu.ice.mobilecar.widget; import android.content.context; import android.util.attributeset; import android.widget.textview; /** * @author 编写人: xiaox * @date 创建时间: 2017/1/10 * @description 功能描述: 该类 */ public class textviewslide extends textview { public textviewslide(context context) { super(context); } public textviewslide(context context, attributeset attrs) { super(context, attrs); } @override public boolean isfocused() { return true; } }
activity_main.xml
<edu.hrbeu.ice.mobilecar.widget.textviewslide android:id="@+id/alarm_type" android:layout_width="@dimen/item_width" android:layout_height="wrap_content" android:gravity="center_horizontal" android:layout_gravity="center_vertical" android:layout_weight="1" android:padding="8dp" android:marqueerepeatlimit="marquee_forever" android:ellipsize="marquee" android:scrollhorizontally="true" android:focusableintouchmode="true" android:singleline="true" tool:text="asda" />
可以看到第二种方式也就是在自定义控件中获取了该控件的焦点。感觉和第一种没有区别。
目前在android7.1.1和android4.4上实验两种方法都没有问题。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。