Android | 启用 TextView 跑马灯效果的方法

如果要给一个 TextView 设置跑马灯效果,我们仅需要给其设置如下属性即可:

xml 复制代码
<TextView
    android:ellipsize="marquee"
    android:singleLine="true" />

ellipsize 属性设置为 marquee 表示开启跑马灯效果,而 singleLine 则设置其为单行展示。同时需要在 TextView 获焦或被选中时才会有跑马灯效果,因此我们在代码中可以手动让其获焦或者设置其为 selected 的状态 textview.isSelected = true

通过对比发现,设置 android:lines="1"android:maxLines="1" 是没有效果的,一定是要 android:singleLine="true" 才可以,以下是实例代码:

xml 复制代码
<!-- 布局 -->
<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    android:padding="16dp">

    <TextView
        android:id="@+id/tv1"
        style="@style/TextView_Style"
        android:text="(未设置 Selected) 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯" />

    <TextView
        android:id="@+id/tv2"
        style="@style/TextView_Style"
        android:text="(仅设置 Selected) 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯" />

    <TextView
        android:id="@+id/tv3"
        style="@style/TextView_Style"
        android:lines="1"
        android:text="(设置 Selected 设置lines = 1) 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯" />

    <TextView
        android:id="@+id/tv4"
        style="@style/TextView_Style"
        android:maxLines="1"
        android:text="(设置 Selected 设置maxLines = 1) 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯" />

    <TextView
        android:id="@+id/tv5"
        style="@style/TextView_Style"
        android:singleLine="true"
        android:text="(设置 Selected 设置singleLine = true) 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯 跑马灯" />

</LinearLayout>

<!-- style -->
<style name="TextView_Style">
    <item name="android:layout_width">match_parent</item>
    <item name="android:layout_height">wrap_content</item>
    <item name="android:ellipsize">marquee</item>
    <item name="android:textSize">36sp</item>
    <item name="android:layout_marginVertical">8dp</item>
    <item name="android:textColor">@color/black</item>
</style>

各种情况的结果如下:

相关推荐
冬奇Lab3 小时前
MediaPlayer 播放器架构:NuPlayer 的 Source/Decoder/Renderer 三驾马车
android·音视频开发·源码阅读
炸炸鱼.5 小时前
Python 操作 MySQL 数据库
android·数据库·python·adb
用户41659673693556 小时前
nextlib 项目架构与深度技术指南 (Architecture & Technical Master Guide)
android
aq55356007 小时前
Laravel10.x重磅升级,新特性一览
android·java·开发语言
Trouvaille ~7 小时前
【MySQL篇】数据类型:存储数据的基础
android·数据库·mysql·adb·字符集·数据类型·基础入门
2401_885885049 小时前
开发视频短信接口好开发吗?图文视频短信接口对接教程
android·音视频
千码君201610 小时前
kotlin:Jetpack Compose 给APP添加声音(点击音效/背景音乐)
android·开发语言·kotlin·音效·jetpack compose
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.10 小时前
MySQL半同步复制与GTID实战详解
android·mysql·adb
用户416596736935511 小时前
深度解码:记一次视频时间戳(PTS)异常导致的播放故障排查
android
qxl_79991511 小时前
MinIO Windows 安装与配置文档(含开机自启)
经验分享