zoukankan      html  css  js  c++  java
  • Android:TextView 自动滚动(跑马灯) (转)

    Android:TextView 自动滚动(跑马灯)  

     

     
     
     
    TextView实现文字滚动需要以下几个要点:
    1.文字长度长于可显示范围:android:singleLine="true"
    2.设置可滚到,或显示样式:android:ellipsize="marquee"
    3.TextView只有在获取焦点后才会滚动显示隐藏文字,因此需要在包中新建一个类,继承TextView。重写isFocused方法,这个方法默认行为是,如果TextView获得焦点,方法返回true,失去焦点则返回false。跑马灯效果估计也是用这个方法判断是否获得焦点,所以把它的返回值始终设置为true。
     
    以下转自他人:
     
    Java语言: AlwaysMarqueeTextView 类
    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;
    }

    在布局XML文件中加入这么一个AlwaysMarqueeTextView,这个加入方法也是刚刚学的。

    XML语言: layout.xml
    <com.examples.AlwaysMarqueeTextView
    android:id=“@+id/AMTV1″
    android:layout_width=“fill_parent”
    android:layout_height=“wrap_content”
    android:lines=“1″
    android:focusable=“true”
    android:focusableInTouchMode=“true”
    android:scrollHorizontally=“true”
    android:marqueeRepeatLimit=“marquee_forever”
    android:ellipsize=“marquee”
    android:background=“@android:color/transparent”
    />

    ellipsize属性
    设置当文字过长时,该控件该如何显示。有如下值设置:”start”—–省略号显示在开头;”end”——省略号显示在结尾;”middle”—-省略号显示在中间;”marquee” ——以跑马灯的方式显示(动画横向移动)

    EidtText和textview中内容过长的话自动换行,使用android:ellipsize与android:singleine可以解决,使只有一行。

    EditText不支持marquee

    用法如下:

    在xml中

    android:ellipsize = "end"    省略号在结尾
    
    android:ellipsize = "start"   省略号在开头
    
    android:ellipsize = "middle"     省略号在中间
    
    android:ellipsize = "marquee"  跑马灯
    
    android:singleline = "true"

    当然也可以用代码语句

    tv.setEllipsize(TextUtils.TruncateAt.valueOf("END"));
    
    tv.setEllipsize(TextUtils.TruncateAt.valueOf("START"));
    
    tv.setEllipsize(TextUtils.TruncateAt.valueOf("MIDDLE"));
    
    tv.setEllipsize(TextUtils.TruncateAt.valueOf("MARQUEE"));
    
    tv.setSingleLine(true);

    marqueeRepeatLimit属性
    在ellipsize指定marquee的情况下,设置重复滚动的次数,当设置为marquee_forever时表示无限次。

    focusable属性
    自己猜测的,应该是能否获得焦点,同样focusableInTouchMode应该是滑动时能否获得焦点。

    组合View的问题:

    XML语言: 组合View
    < LinearLayout
    xmlns:android =“http://schemas.android.com/apk/res/android”
    android:orientation =“vertical”
    android:gravity =“center_vertical”
    android:background =“@drawable/f_background”
    android:layout_width =“fill_parent”
    android:focusable =“true”
    android:layout_height =“50px” >
    < TextView
    android:id =“@+id/info_text”
    android:focusable =“true”
    android:layout_width =“fill_parent”
    android:layout_height =“wrap_content”
    android:text =“test marquee  .. “
    android:textColor =“@color/black”
    android:singleLine =“true”
    android:ellipsize =“marquee”
    android:marqueeRepeatLimit =“3″
    android:textSize =“18sp”
    />
    < TextView
    android:id =“@+id/date_text”
    android:layout_width =“fill_parent”
    android:layout_height =“wrap_content”
    android:layout_gravity =“bottom”
    android:textColor =“@color/gray”
    android:text =“2010/05/28″
    android:textSize =“12sp”
    />
    </ LinearLayout >
    上面示例中2个TextView组合为一个View,由于设置了LinearLayout为focusable而TextView就没法取得焦点了,这样 这个TextView的跑马灯效果就显示不出来,就算你也设置TextView的 android:focusable="true" 也是 没用的. 这个时候就要使用addStatesFromChildren 这个属性了,在LinearLayout中设置这个属性,然后设置TextView的focusable= "true" 就可以了.关于 addStatesFromChildren的说明:

    Sets whether this ViewGroup's drawable states also include its children's drawable states.

    来自:http://hmifly.blog.163.com/blog/static/1285835072011322352406/

  • 相关阅读:
    Rust语言学习笔记(11)
    Rust语言学习笔记(10)
    Rust语言学习笔记(9)
    Rust语言学习笔记(8)
    趣味编程:静夜思(Rust版)
    Python sorted()
    Python 魔法方法
    Python filter()
    Python的map和reduce
    Python函数的参数
  • 原文地址:https://www.cnblogs.com/McCa/p/4505211.html
Copyright © 2011-2022 走看看