您的位置:首页 > 移动开发 > Android开发

Android使用TextView实现跑马灯效果

2017-08-09 20:18 741 查看

以前就遇到过这个问题,今天重新拾起来。

跑马灯效果其实就是当文字超过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
4000
创建时间: 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上实验两种方法都没有问题。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: