zoukankan      html  css  js  c++  java
  • (五十)TextView文本滚动效果实现

    一、若要让TextView里的文本滚动,必须满足以下几个因素:

    1、TextView里文本宽度超过TextView的宽度
    2、android:ellipsize="marquee"(实现跑马灯效果)
    3、只有在TextView获取到焦点时,才会滚动.所以加上android:focusableInTouchMode="true"  android:focusable="true",最容易忽略的是此条.

    4、滚动重复次数设置:android:marqueeRepeatLimit="marquee_forever"

       让文字可以水平滑动:android:scrollHorizontally="true"

    二、TextView文本滚动例子程序

    2.1 activity_main.xml代码如下所示:

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_gravity="center_horizontal"
        android:background="#ffffffff"
        android:orientation="vertical"
        android:paddingLeft="20dp" >
    
        <TextView
            android:id="@+id/tv_recommend_app_name"
            android:layout_width="50dp"
            android:layout_height="wrap_content"
            android:layout_marginTop="9dp"
            android:ellipsize="marquee"
            android:focusable="true"
            android:focusableInTouchMode="true"
            android:gravity="center"
            android:marqueeRepeatLimit="marquee_forever"
            android:scrollHorizontally="true"
            android:singleLine="true"
            android:text="应用名称marqueeRepeatLimit"
            android:textColor="#999999"
            android:textSize="10sp" />
    
    </LinearLayout>

    2.2 MainActivity.java代码

    package com.example.textviewautorolling;
    
    import android.app.Activity;
    import android.os.Bundle;
    
    public class MainActivity extends Activity {
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
        }
    }

     2.3 Textview的字体不能实现滚动效果的解决办法

       在一个textview之前有同一级树或更高一级的textview在xml文件里设置了滚动属性后,再对该textview在xml里设置滚动属性则不起作用。解决办法:在代码中对TextView inside 进行设置inside.setSelected(true),就能实现textview滚动效果了,此方法对任何情况下的textview都适用。

  • 相关阅读:
    ngRoute AngularJs自带的路由
    AngularJs $resource 高大上的数据交互
    AngularJs filter 过滤器
    eBPF监控工具bcc系列一启航
    [转载] kprobe原理解析(一)
    c++通过CMake实现debug开关
    如何使用fio模拟线上环境
    汇编学习pushl, popl
    block:cfq 学习02
    阻抗匹配详细讲解(以前的转贴)
  • 原文地址:https://www.cnblogs.com/fuyanan/p/4422365.html
Copyright © 2011-2022 走看看