Android基于TextView实现跑马灯效果

本文实例为大家分享了Android TextView实现跑马灯效果的具体代码,供大家参考,具体内容如下

当Layout中只有一个TextView需要实现跑马灯效果时,操作如下。

在Layout的TextView配置文件中增加

        android:ellipsize="marquee"

        android:focusable="true"

        android:focusableInTouchMode="true"

        android:singleLine="true"

以上四条属性,即可实现跑马灯效果。

当有多个TextView想实现跑马灯效果时,实现起来稍微复杂一些。

首先新建一个类,继承自TextView。

package com.example.project1;

import android.content.Context;

import android.util.AttributeSet;

import android.view.ViewDebug.ExportedProperty;

import android.widget.TextView;

public class MyTextView extends TextView{

public MyTextView(Context context, AttributeSet attrs, int defStyle) {

super(context, attrs, defStyle);

// TODO Auto-generated constructor stub

}

public MyTextView(Context context, AttributeSet attrs) {

super(context, attrs);

// TODO Auto-generated constructor stub

}

public MyTextView(Context context) {

super(context);

// TODO Auto-generated constructor stub

}

@Override

public boolean isFocused() {

// TODO Auto-generatd method stub

return true;

}

}

重写函数 isFocused(),使其始终return true。

将Layout文件中的TextView修改为com.example.project1.MyTextView,如下。

<com.example.project1.MyTextView

android:id="@+id/textView1"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:ellipsize="marquee"

android:focusable="true"

android:focusableInTouchMode="true"

android:singleLine="true"

android:text="@string/longText" />

<com.example.project1.MyTextView

android:id="@+id/textView2"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:ellipsize="marquee"

android:focusable="true"

android:focusableInTouchMode="true"

android:singleLine="true"

android:text="@string/longText" />

此时两个TextView都可呈现跑马灯效果。

以上是 Android基于TextView实现跑马灯效果 的全部内容, 来源链接: utcz.com/z/324985.html

回到顶部