zoukankan      html  css  js  c++  java
  • TextView的单行滚动效果

    首先,一个Textview可以很简单的实现,但是多个textview的实现方式就比较麻烦 .

    一个Textview实现滚动的条件:

    1、文本长度足够长

    2、ellipsize="marquee"

    3、focusable="true"  --- focusableInTouchMode="true" 

    当然,既然要滚动那就必须设置singleLine属性为true

        <TextView
            android:id="@+id/TextView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:ellipsize="marquee"
            android:focusable="true"
            android:focusableInTouchMode="true"
            android:singleLine="true"
            android:text="@string/text" />

    多个textview的滚动实现:

    我们在设置单个textview的时候会发现第三步设置了focusable,但是这个属性在对第二个textview设置的时候是无效的,即不能滚动了。所以我们需要自建一个textview

    新建一个类继承自textview,重写构造函数,加入isFocused函数返回为true

    public class MarqueeText extends TextView {
        public MarqueeText(Context context) {
            super(context);
        }
    
        public MarqueeText(Context context, AttributeSet attrs, int defStyleAttr) {
            super(context, attrs, defStyleAttr);
        }
    
        public MarqueeText(Context context, AttributeSet attrs) {
            super(context, attrs);
        }
    
        @Override
        public boolean isFocused() {
            return true;
        }
    }

    在使用textview中使用,甚至可以不再加入focusable="true"  --- focusableInTouchMode="true" 这两个属性

        <com.puzzle.lyxin.myapplication_textview.MarqueeText
            android:id="@+id/TextView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:ellipsize="marquee"
            android:singleLine="true"
            android:text="@string/text" />

    另外,这样默认的重复滚动次数好像是3次,如果要一直滚动可以加入属性到xml中

      android:marqueeRepeatLimit="marquee_forever"

  • 相关阅读:
    Redis常用数据类型介绍、使用场景及其操作命令
    spring的官方文档地址
    ps基础学习笔记一
    类的加载时机与步骤(转)
    jvm的基本结构以及各部分详解(转)
    jdk1.8使用的url和driverName的改变
    测试框架简单了解
    shiro简单学习的简单总结
    easyui弹框后销毁当前tab弹框不显示的解决方式
    springboot学习章节代码-Spring MVC基础
  • 原文地址:https://www.cnblogs.com/lyxin/p/5756298.html
Copyright © 2011-2022 走看看