android布局跑马灯,Android自定义跑马灯效果(适合任意布局)

article/2025/10/22 22:02:10

因为项目需要,做了一个自定义垂直跑马灯,分享给大家。

先上个效果图:

a41d779a0e23e7914d9cf37b9281b289.gif

bbacf6d687aa744275ef2f5f287f25cb.png

从图片中可以看到布局是由包含两个TextView的布局组成,一般的垂直跑马灯效果只支持单个TextView,水平方向的跑马灯更是不需要自定义,原生TextView就支持。

小编的需求不只于此,里面的布局复杂,网上的方案已经不满足我的需求,所以参考别人的垂直跑马灯,自己写了一个支持任意布局的跑马灯效果。

下面贴上View源码:

package com.verticalmarquee.maomao.verticalmarqueedemo;

import android.content.Context;

import android.os.Handler;

import android.util.AttributeSet;

import android.util.Log;

import android.view.View;

import android.view.animation.AnimationUtils;

import android.widget.ViewAnimator;

import java.util.List;

public class VerticalMarqueeLayout extends ViewAnimator {

private static final long DEFAULT_TIMER = 2000L;

private long delayTime = DEFAULT_TIMER;

private int viewIndex;

private List views;

private static Handler handler = new Handler();

private boolean started;//是否已经开始轮播

public VerticalMarqueeLayout(Context context) {

super(context);

this.init();

}

public VerticalMarqueeLayout(Context context, AttributeSet attrs) {

super(context, attrs);

this.init();

}

private void init() {

this.setInAnimation(AnimationUtils.loadAnimation(this.getContext(), R.anim.vertical_marquee_in));

this.setOutAnimation(AnimationUtils.loadAnimation(this.getContext(), R.anim.vertical_marquee_out));

}

protected void onFinishInflate() {

super.onFinishInflate();

}

private void startMarquee() {

if (this.views != null) {

if (this.views.size() > 1) {

handler.postDelayed(new Runnable() {

public void run() {

VerticalMarqueeLayout.this.viewIndex++;

if (VerticalMarqueeLayout.this.viewIndex >= VerticalMarqueeLayout.this.views.size()) {

VerticalMarqueeLayout.this.viewIndex = 0;

}

showNext();

VerticalMarqueeLayout.handler.postDelayed(this, delayTime);

}

}, delayTime);

started = true;

} else if (this.views.size() > 0) {

this.viewIndex = 0;

} else {

this.viewIndex = 0;

}

} else {

this.viewIndex = 0;

}

}

/**

* 获取当前显示的View

* 修改方法名,避免与父类方法重名

*

* @return View

*/

public View getCurView() {

if (this.views != null && this.viewIndex >= 0 && this.viewIndex < this.views.size()) {

return this.views.get(this.viewIndex);

}

return null;

}

/**

* 获取当前显示View的index

*

* @return index

*/

public int getCurIndex() {

return this.viewIndex;

}

/**

* 设置轮播的View列表,该方法会自动轮播

*

* @param views view列表

*/

public void setViewList(List views) {

setViewList(views, DEFAULT_TIMER);

}

/**

* 设置轮播的View列表,该方法会自动轮播

*

* @param views view列表

* @param delayTime 间歇时间

*/

public void setViewList(final List views, long delayTime) {

if (views == null || views.size() == 0) {

return;

}

if (delayTime >= 100) {

//最少100毫秒,否则为默认值

this.delayTime = delayTime;

}

this.views = views;

handler.removeCallbacksAndMessages(null);

started = false;

post(new Runnable() {

@Override

public void run() {

for (View view : views) {

addView(view);

}

startMarquee();

}

});

}

//开始倒计时(轮播),在页面可见并且需要自动轮播的时候调用该方法

public void startTimer() {

if (started || views == null || views.size() <= 1) {

return;

}

stopTimer();

startMarquee();

Log.d("VerticalMarqueeLayout", "VerticalMarqueeLayout startTimer!");

}

//停止倒计时(轮播),如果调用过startTimer();在页面不可见的时候调用该方法停止自动轮播

public void stopTimer() {

if (handler != null) {

handler.removeCallbacksAndMessages(null);

started = false;

Log.d("VerticalMarqueeLayout", "VerticalMarqueeLayout stopTimer!");

}

}

}

源码解析:

init():初始化跑马灯效果(可以修改此处代码,改成水平跑马灯);

startMarquee():开始倒计时刷新页面;

getCurrentView():获取当前显示的View;

getCurrentIndex():获取当前显示的View对应的index;

setViewList(List views):设置跑马灯View列表,间歇时间为默认时间;

setViewList(List views, long delayTime):设置跑马灯View列表,间歇时间为传入的时间,单位为毫秒;

startTimer():开始倒计时,与stopTimer()配套使用;

stopTimer():停止倒计时,与startTimer()配套使用;

使用时直接调用setViewList方法,即可开始倒计时。

startTimer()和stopTimer()方法一般在activity的onResume和onPuase里面调用,为了Activity跳转之后能暂停动画;

原理

其实整个代码的核心点在于继承了ViewAnimator,ViewAnimator里面有自带的子view管理机制,通过调用showNext()可以直接显示下一个子View。这对于轮播效果很有帮助。

使用示例:

xml代码:

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context=".MainActivity">

android:id="@+id/marquee_root"

android:layout_width="match_parent"

android:layout_height="wrap_content" />

Activity代码:

package com.verticalmarquee.maomao.verticalmarqueedemo;

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import android.view.LayoutInflater;

import android.view.View;

import android.widget.TextView;

import java.util.ArrayList;

import java.util.List;

public class MainActivity extends AppCompatActivity {

private VerticalMarqueeLayout marqueeRoot;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

marqueeRoot = findViewById(R.id.marquee_root);

initData();

}

private void initData() {

int count = 5;

List views = new ArrayList<>();

LayoutInflater inflater = LayoutInflater.from(this);

for (int i = 0; i < count; i++) {

views.add(inflateView(inflater, marqueeRoot, "这是标题" + i, "这里是第" + i + "条内容"));

}

marqueeRoot.setViewList(views);

}

private View inflateView(LayoutInflater inflater, VerticalMarqueeLayout marqueeRoot, String name, String desc) {

if (inflater == null) {

inflater = LayoutInflater.from(this);

}

View view = inflater.inflate(R.layout.marquee_item, marqueeRoot, false);

TextView viewName = view.findViewById(R.id.marquee_name);

TextView viewDesc = view.findViewById(R.id.marquee_desc);

viewName.setText(name);

viewDesc.setText(desc);

return view;

}

}

最后修改于2019年5月20日,修改点如下:

修复因getCurrentView方法与父类方法重名导致被调用时出现空指针异常。

开始启动轮播动画和addView操作添加到post的Runnable里面,为避免在页面未显示前调用导致的异常。这样可以放心在任意地点调用setViewList方法。


http://chatgpt.dhexx.cn/article/kHPu9DCD.shtml

相关文章

android跑马灯效果不起作用,Android跑马灯效果失效问题

Android中的跑马灯效果在特定情况下用的效果很不错&#xff0c;调试的时候发现在2.3系统下&#xff0c;文字跑动正常&#xff0c;后来无意换了另一个手机&#xff0c;4.0以上的系统&#xff0c;发现文字跑动效果失效&#xff0c;研究后发现有两种情况会导致失效。 先看跑马灯效…

Unity 跑马灯效果

一、效果 二、需要动画插件DOTween 三、脚本 1.每个格子上的脚本文件 using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; using DG.Tweening; public class MarqueeUIItem : MonoBehaviour {private RawImage m_RawImag…

Android TextView设置跑马灯效果

【前言】 在Textview设置的宽度有限&#xff0c;而需要显示的文字又比较多的情况下&#xff0c;往往需要给Textview设置跑马灯效果才能让用户完整地看到所有设置的文字&#xff0c;所以给TextView设置跑马灯效果的需求是很常见的 一、新手设置跑马灯效果 1、先在xml中给Textvi…

css 实现跑马灯效果

最近有一个跑马灯的效果&#xff0c;需要实现。本来想偷个懒从网上随便拷贝一个&#xff0c;结果发现都不太理想&#xff0c;于是自己动手封装了一个&#xff0c;和大家分享一下。 首先我们要知道跑马灯的具体效果是什么样子的。 效果图 我们通过效果图可以看到&#xff0c;在…

h5跑马灯效果

无缝滚动效果 &#xff0c;外加 手指的移动效果 思路&#xff1a; 1.无缝滚动1个内容区域&#xff0c;复制一下这个内容&#xff0c;追加到改内容的后面&#xff0c;形成无缝滚动的效果 2.手指左滑右滑进行x轴方向的加减 代码如下&#xff1a; <template><div cl…

Android --- 跑马灯效果

1、基于开发者文档的官方说明 跑马灯效果主要使用的控件为TextView&#xff0c;其中涉及的几个标签如下所示&#xff1a; android:ellipsize If set, causes words that are longer than the view is wide to be ellipsized instead of broken in the middle. You will often …

html跑马灯效果

该笔记记录 <marquee> 标签&#xff0c;跑马灯除了使用js实现&#xff0c;还可以使用 marquee标签&#xff0c;自带跑马灯效果。&#xff08;marquee已经 Obsolete了&#xff0c;但是它很好用&#xff09; 基本用法 <!-- marquee是块元素&#xff0c;直接在其内部放…

跑马灯效果如何实现?Smartbi一文助你掌握

大数据时代&#xff0c;人的注意力越来越成为一种稀缺资源&#xff0c;让信息去匹配读者注意力&#xff0c;显然优于让人的注意力去适应信息。因此我们就需要在数据呈现上进行创新。那么如何让数据变得动态化&#xff0c;可视化呢&#xff1f;或许可以尝试一下跑马灯效果。 跑…

滚动动画(跑马灯动画)的几种实现方式

在大屏可视化应用中&#xff0c;滚动动效&#xff08;跑马灯效果&#xff09;也是常见的一种数据展现方式&#xff0c;本章节针对字幕滚动和列表滚动效果做一个小小的总结&#xff0c;结合vue框架&#xff0c;具体展示效果如下&#xff0c;从左至右选型技术分别为&#xff1a;m…

本地KMS虚拟服务器,搭建kms本地服务器

搭建kms本地服务器 内容精选 换一换 Kerberos是一种计算机网络认证协议&#xff0c;它允许某实体在非安全网络环境下通信&#xff0c;向另一个实体以一种安全的方式证明自己的身份。它也指由麻省理工实现此协议&#xff0c;并发布的一套免费软件。软件设计上采用客户端/服务器模…

Ubuntu搭建kms服务器

Key Management Service&#xff08;简称:KMS&#xff09;&#xff0c;这个功能是在Windows Vista之后的产品中的一种新型产品激活机制。我们可以利用手里闲置的VPS安装vlmcsd来搭建KMS激活服务器&#xff0c;这篇文章以Ubuntu为例&#xff0c;当然vlmcsd并不局限限于Ubuntu&am…

linux系统安装kms,Linux安装部署KMS服务器

Loading... # Linux 安装部署 KMS 服务器 ## 一、强制关闭kms-server服务 killall kms-server ## 二、下载 kms 服务文件 ### 1、下载 32bit包 如果你要安装 32位包&#xff0c;请直接下载 bash wget https://dl.wxlost.com/2017/01/Linux/vlmcsd-x86-musl-static -O /usr/bi…

centos7快速搭建KMS服务器

1、下载最新的vlmcsd服务端 https://github.com/Wind4/vlmcsd/releases/tag/svn1113 2、解压&#xff0c;并找到binaries/Linux/intel/static/vlmcsd-x64-musl-static并复制到到/usr/bin/vlmcsd 3、赋予执行权限 chmod x /usr/bin/vlmcsd 4、添加开机启动/etc/rc.local中添…

Windows搭建kms服务器

文章目录 使用Windows系统搭建kms服务器前言准备正式开始 使用Windows系统搭建kms服务器 前言 网上有许多搭建的教程&#xff0c;但是使用的都是Linux系统&#xff0c;而我们正常使用的则是Windows系统。对Linux不熟悉的同学看着那左一个代码命令右一个代码命令的教程如同天书…

kms服务器搭建及测试

vlmcsd代码仓库&#xff1a;https://github.com/Wind4/vlmcsd 搭建步骤 本次操作环境centos7&#xff0c;通过内网进行搭建 1.安装依赖环境 yum install gcc git make -y 2.下载源码&#xff0c;编译安装 cd /var/opt/ git clone https://github.com/Wind4/vlmcsd.git cd vlmcs…

kms的服务器改回系统默认,指定kms服务器地址后还原

指定kms服务器地址后还原 内容精选 换一换 您可以通过本节内容解决如下问题:用户在管理控制台执行弹性云服务器相关操作后出现异常,针对管理控制台提示的异常信息,应该如何处理?用户参见《弹性云服务器接口参考》调用云服务器相关的API接口时,如果返回错误码,应该如何处理…

Windows部署KMS服务器

下载安装vlmcsd 地址&#xff1a;https://github.com/Wind4/vlmcsd/releases/download/svn1111/binaries.tar.gz 解压 binaries.tar.gz 文件&#xff0c;找到 \binaries\Windows\intel 下的 vlmcsd-Windows-x86.exe 或者 vlmcsd-Windows-x64.exe &#xff08;根据操作系统选择…

虚拟机如何搭建kms服务器,linux 搭建kms服务器

linux 搭建kms服务器 内容精选 换一换 用户通过管理控制台创建或者导入密钥对后,在购买弹性云服务器时,登录方式选择密钥对,并选择创建或者导入的密钥对。用户购买弹性云服务器成功后,可使用密钥对的私钥登录弹性云服务器。使用的登录工具(如PuTTY、Xshell)与待登录的弹性云…

查看kms服务器信息,查看kms服务器地址

查看kms服务器地址 内容精选 换一换 可以一次添加一台服务器,也可以一次添加同一网段连续IP的多台服务器。进入任务中心可以查看状态信息,如果状态为成功,说明服务器已添加成功。 查询指定后端云服务器组的后端云服务器。支持过滤查询和分页查询。如未特殊说明,匹配规则为精…

kms服务器搭建

kms服务器搭建 1. 下载vlmcsd 地址&#xff1a;https://github.com/Wind4/vlmcsd/releases 下载最终版压缩包: binaries.tar.gz 解压后&#xff0c;可看到这个压缩包适了各种操作系统 以windows为例&#xff1a; cd C:\Users\admin\Desktop\kms\binaries\Windows\intel #create…