本文实例为大家分享了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都可呈现跑马灯效果。
您可能感兴趣的文章:TextView实现跑马灯效果 就这么简单!android TextView实现跑马灯效果Android自定义TextView跑马灯效果Android中使用TextView实现文字跑马灯效果Android使用TextView跑马灯效果Android 中TextView中跑马灯效果的实现方法Android TextView实现跑马灯效果的方法Android TextView跑马灯效果实现方法Android用过TextView实现跑马灯效果的示例