TextView实现滚动显示的效果
一.TextView基础
TextView实现文字滚动需要以下几个要点:
1.文字长度长于可显示范围:android:singleLine="true"2.设置可滚到,或显示样式:android:ellipsize="marquee"
3.TextView只有在获取焦点后才会滚动显示隐藏文字,因此需要在包中新建一个类,继承TextView。重写isFocused方法,这个方法默认行为是,如果TextView获得焦点,方法返回true,失去焦点则返回false。跑马灯效果估计也是用这个方法判断是否获得焦点,所以把它的返回值始终设置为true。
TextView属性介绍:
ellipsize属性
设置当文字过长时,该控件该如何显示。有如下值设置:”start”—–省略号显示在开头;”end”——省略号显示在结尾;”middle”—-省略号显示在中间;”marquee” ——以跑马灯的方式显示(动画横向移动)
marqueeRepeatLimit属性
在ellipsize指定marquee的情况下,设置重复滚动的次数,当设置为marquee_forever时表示无限次。
focusable属性
能否获得焦点,同样focusableInTouchMode是滑动时能否获得焦点。
二.实现
1、在frameworks\base\core\java\android\widget\下创建AlwaysMarqueeTextView.java,内容如下:
package android.widget; import android.content.Context; import android.util.AttributeSet; import android.widget.TextView; import android.widget.RemoteViews.RemoteView; @RemoteView public class AlwaysMarqueeTextView extends TextView { public AlwaysMarqueeTextView(Context context) { super(context); } public AlwaysMarqueeTextView(Context context, AttributeSet attrs) { super(context, attrs); } public AlwaysMarqueeTextView(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); } @Override public boolean isFocused() { return true; } }2、执行update-api的命令:
./mk update-api
3、重新编译整个工程
4、修改相应的TextView控件
- <TextView + <AlwaysMarqueeTextView android:id="@+id/item_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_toRightOf="@id/item_icon" android:layout_marginBottom="6dip" android:textAppearance="?android:attr/textAppearanceMedium" + android:focusableInTouchMode="true" android:singleLine="true" - android:ellipsize="none" + android:ellipsize="marquee" + android:marqueeRepeatLimit="marquee_forever" />