Android用过TextView实现跑马灯效果的示例
以前就遇到过这个问题,今天重新拾起来。
跑马灯效果其实就是当文字超过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上实验两种方法都没有问题。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。
赞 (0)