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"
         />


posted on 2014-07-08 19:31  小尾巴猴子  阅读(3653)  评论(0编辑  收藏  举报

导航