echarts 模拟时间轴播放效果

使用echarts柱状图模拟时间轴播放控制。开始/暂停/快进/慢进/点选

在这里插入图片描述

代码可直接放echart官方示例执行

let start = +new Date('2024-01-01');
let end = +new Date('2024-01-10');
let diff = end - start;
let dotLen = 200;let data = [start, end];
option = {color: ['#3398DB'],tooltip: {trigger: 'axis',showContent: false,axisPointer: {type: 'line'}},grid: {top: '8%',bottom: '90%'},xAxis: [{type: 'value',axisLabel: {formatter: (i) => {return new Date(start + (i * diff) / dotLen).toLocaleDateString();}},axisPointer: {show: true},axisTick: {inside: true},minorTick: {show: true},splitLine: { show: false },splitNumber: 10}],yAxis: [{type: 'value',show: false}],series: [{name: 'x',type: 'bar',barWidth: '3',animation: false},{name: 'back',type: 'bar',barWidth: '5',itemStyle: { color: 'rgba(0,0,0,0)' },data: Array(dotLen).fill().map((it, i) => [i, 1]),animation: false}]
};
let index = 0;
let btn = null;
let timerId = null;
let speed = 200;
const play = () =>setInterval(() => {const temp = index++ % dotLen;myChart.setOption({series: [{name: 'x',data: Array(dotLen).fill().map((it, i) => {return [i, i === temp];})}]});}, speed);const initControl = () => {// 慢进let slow = document.createElement('button');slow.appendChild(document.createTextNode('slow'));document.body.prepend(slow);slow.onclick = () => {if (timerId) {speed = 1.1 * speed;clearInterval(timerId);timerId = play();}};// 快进let quick = document.createElement('button');quick.appendChild(document.createTextNode('quick'));document.body.prepend(quick);quick.onclick = () => {if (timerId) {speed = 0.9 * speed;clearInterval(timerId);timerId = play();}};// 播放/暂停btn = document.createElement('button');btn.appendChild(document.createTextNode('play'));document.body.prepend(btn);btn.onclick = () => {if (timerId) {btn.innerText = 'play';clearInterval(timerId);timerId = null;} else {btn.innerText = 'stop';timerId = play();}};
};initControl();myChart.on('click', (evt) => {if (timerId) btn.click();index = evt.dataIndex;myChart.setOption({series: [{name: 'x',data: Array(dotLen).fill().map((it, i) => {return [i, i === index + 1];})}]});index++;
});

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/730371.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

论文解读:Rectifying the Shortcut Learning of Background for Few-Shot Learning

文章汇总 问题&动机&解决方法 图像背景是一种有害知识的来源,这是少数镜头学习模型容易吸收的(问题) 通过在训练和评估中提取图像中的前景目标而不需要任何额外的监督来解决这个问题(动机) 在训练和评估时将模型的注意力吸引到图像前景上(方法) 摘要 …

Day25:安全开发-PHP应用文件管理模块包含上传遍历写入删除下载安全

目录 PHP文件操作安全 文件包含 文件删除 文件编辑 文件下载 云产品OSS存储对象去存储文件(泄漏安全) 思维导图 PHP知识点 功能:新闻列表,会员中心,资源下载,留言版,后台模块,模版引用,框…

关于出国留学和考研比较----以本人双非跨考计算机为例

文章目录 中心论点国内就业现状勿让旧认知害了自己那出国留学真的一无是处了吗?1. 藤校仍旧是具有极高价值2. 时间成本低3. 研究生一定比单纯的本科找工作强!4. 很多人说出国读博好,可以无脑入,真是这样吗? 中心论点 如果在选择出国留学还是国内考研的最终核心诉求都是有更好…

向量的内积、长度、正交性

目录 向量的内积 向量的长度(模) 标准正交基 标准正交化 正交矩阵 向量的内积 向量的长度(模) 标准正交基 标准正交化 正交矩阵

JavaWeb——014SpringBoot原理(配置优先级、Bean管理、SpringBoot原理)

SpingBoot原理 目录 SpingBoot原理1. 配置优先级2. Bean管理2.1 获取Bean2.2 Bean作用域2.3 第三方Bean 3. SpringBoot原理3.1 起步依赖3.2 自动配置3.2.1 概述3.2.2 常见方案3.2.2.1 概述3.2.2.2 方案一3.2.2.3 方案二 3.2.3 原理分析3.2.3.1 源码跟踪3.2.3.2 Conditional 3.2…

超市小程序有哪些功能 怎么制作

超市小程序是非常有用的工具,可以帮助超市提升用户体验,提高销售额。下面我们来看一下超市小程序可以具备哪些功能,以及如何制作一个高效的超市小程序。 1. **商品展示与搜索功能**:用户可以浏览超市的商品信息,包括价…

同等学力申硕专业介绍——管理学硕士

同等学力申硕的专业很多。 目前有十三大门类,分别是医学、法学、管理学、工学、教育学、经济学、艺术学、文学、历史学、理学、哲学、农学、军事学等,每个大门类中都有很多的细分专业。 今天为大家介绍同等学力申硕专业——管理学。 专业介绍 管理学是…

【学习记录】PointLIO代码 update_iterated_dyn_share_modified 中函数指针的用法

最近在看PointLio的代码,有一部分看了半天没看懂,学习整理如下。 1、PointLio在迭代卡尔曼部分的代码 在esekfom.hpp中,有部分代码如下: void init_dyn_share_modified(processModel f_in, processMatrix1 f_x_in, measurement…

上班族真香副业:工资4500,靠steam游戏搬砖项目月入过w

steam游戏搬砖项目已经存在好多年了,这个项目比较冷门且能持续稳定盈利,是一个非常不错的项目。即使你没玩过steam游戏也没关系,这个steam游戏搬砖项目既不需要你会玩游戏,也不需要你懂英语。 steam游戏搬砖项目的盈利点在汇率差和…

Python的数据库编程基础知识

归纳编程学习的感悟, 记录奋斗路上的点滴, 希望能帮到一样刻苦的你! 如有不足欢迎指正! 共同学习交流! 🌎欢迎各位→点赞 👍 收藏⭐ 留言​📝如果停止,就是低谷&#xf…

【代码随想录算法训练营Day29】 491.递增子序列;46.全排列;47.全排列 II

文章目录 ❇️Day 29 第七章 回溯算法 part05✴️今日内容❇️491.递增子序列自己的思路随想录思路自己的代码 ❇️46.全排列思路代码流程 ❇️47.全排列 II思路代码 ❇️Day 29 第七章 回溯算法 part05 ✴️今日内容 491.递增子序列46.全排列47.全排列 II ❇️491.递增子序…

【性能测试】Jmeter+InfluxDB+Grafana 搭建性能监控平台

一、背景 为什么要搭建性能监控平台? 在用 Jmeter 获取性能测试结果的时候,Jmeter自带的测试报告如下: 这个报告有几个很明显的缺点: 只能自己看,无法实时共享;报告信息的展示比较简陋单一,不…

在外包公司搞了2年,出来技术都没了...

先说情况,大专毕业,18年通过校招进入湖南某软件公司,干了接近6年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了2年的的功能…

网络工程师笔记9

动态路由 RIP路由协议 配置简单 易于维护 适用于小型网络 周期性是30s发一次

MyBatis-Plus如何娴熟运用乐观锁

欢迎来到我的博客,代码的世界里,每一行都是一个故事 MyBatis-Plus如何娴熟运用乐观锁 前言乐观锁的基本概念基本概念和原理:为何乐观锁是解决并发问题的有效手段: MyBatis-Plus中乐观锁的支持1. Version 注解:2. 配置乐…

严刑拷打_微服务

文章详情 :😊 作者:Lion J 💖 主页: https://blog.csdn.net/weixin_69252724 🎉 主题: 微服务相关知识 ⏱️ 创作时间:2024年03月8日 ———————————————— 文章目…

高级语言讲义2014计专(仅高级语言部分)

1. 已知,连续函数在区间[0, 3]有且只有一个实根,编写完整程序,利用二分法计算并输出该实根的近似值,要求结果精确到。 二分法的基本思路是:对于区间[a, b]上的连续函数f(x),若f(a)和f(b)的正负号不同,则该区…

unicloud where 使用

where介绍 在uniCloud中,WHERE是一个用于指定查询条件的关键字。它允许用户根据特定的条件来筛选和查询云数据库中的数据。WHERE语句的基本语法格式是WHERE condition,其中condition表示查询条件,可以是一个或多个逻辑表达式组成的条件。 在…

达梦数据库将DMHR模式下的表(迁移)导出为EXCEL文件

数据库迁移工具(Data Transfer Service)位于/dm8/tool/dts.其中/dm8是数据库安装目录。 在创建数据库时我们如果勾选了 “创建示例库DMHR(R)”,数据库实例中就带有这个数据库。 这里是用MobaXterm客户端远程控制ip地址为192.168.148.130的虚…

【C++】C++11---右值引用和移动语义

目录 1、什么是左值引用和右值引用2、左值引用与右值引用比较3、右值引用使用场景和意义4、右值引用引用左值的分析5、完美转发 1、什么是左值引用和右值引用 传统的C语法中就有引用的语法,而C11中新增了的右值引用语法特性,所以从现在开始我们之前学习…