首页 > 系统 > Android > 正文

Android用过TextView实现跑马灯效果的示例

2019-12-12 02:16:42
字体:
来源:转载
供稿:网友

以前就遇到过这个问题,今天重新拾起来。

跑马灯效果其实就是当文字超过TextView控件宽度的时候,使用滚动的方式显示出来:

方法1:(直接xml搞定)

Android系统中TextView实现跑马灯效果,必须具备以下几个条件:

1、android:ellipsize=”marquee”;

2、TextView必须单行显示,且内容必须超出TextView宽度;

3、TextView要获得焦点才能滚动。

xml代码如下:

  <TextView   android:id="@+id/alarm_location"   android:layout_width="20dp"   android:padding="@dimen/space_4"   android:layout_height="wrap_content"   app:layout_rowWeight="2"   app:layout_columnWeight="2"   android:text="0"   android:ellipsize="marquee"   android:focusableInTouchMode="true"   android:singleLine="true"   android:focusable="true"/>

其中:ellipsize属性指的是文字长度超过TextView的长度的时候的显示方式,具体参数有

**Android:ellipsize=”start”―省略号显示在开头 “…pedia”

android:ellipsize=”end”――省略号显示在结尾 “encyc…”

android:ellipsize=”middle”―-省略号显示在中间 “en…dia”

android:ellipsize=”marquee”以横向滚动方式显示(需获得当前焦点时)**

方法2(自定义控件)

我看了自己以前的实现方式是这样,也许在低版本的平台上第一种方式适配不好吧。如果达不到要求可以试试这种方式。

TextVeiwSlide.Java 

package edu.hrbeu.ice.mobilecar.widget;import android.content.Context;import android.util.AttributeSet;import android.widget.TextView;/** * @author 编写人: xiaox * @date 创建时间: 2017/1/10 * @Description 功能描述: 该类 */public class TextViewSlide extends TextView { public TextViewSlide(Context context) {  super(context); } public TextViewSlide(Context context, AttributeSet attrs) {  super(context, attrs); } @Override public boolean isFocused() {  return true; }}

activity_main.xml 

 <edu.hrbeu.ice.mobilecar.widget.TextViewSlide  android:id="@+id/alarm_type"  android:layout_width="@dimen/item_width"  android:layout_height="wrap_content"  android:gravity="center_horizontal"  android:layout_gravity="center_vertical"  android:layout_weight="1"  android:padding="8dp"  android:marqueeRepeatLimit="marquee_forever"  android:ellipsize="marquee"  android:scrollHorizontally="true"  android:focusableInTouchMode="true"  android:singleLine="true"  tool:text="asda" />

可以看到第二种方式也就是在自定义控件中获取了该控件的焦点。感觉和第一种没有区别。

目前在android7.1.1和android4.4上实验两种方法都没有问题。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持武林网。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表