echarts 绘制垂直滚动热力图

问题1:提示功能无效
问题2:值筛选无效

  • 效果 在线浏览
    在这里插入图片描述

  • 下载echarts官网例子(heatmap Examples - Apache ECharts)
    稍作改动:

    • generateData 入参改为长度和宽度
    • noise.perlin2(i / 40, j / 20) + Math.random() * 5
    • y轴倒置
    • 指定zlevel为2
  • 通过定时器绘制第一行数据,并将绘制前的图像内容拷贝并下移一个单位

          const loop = (layers) => {// 计算每个像素的大小, 代码来自node_modules\echarts\lib\chart\heatmap\HeatmapView.js->_renderOnCartesianAndCalendarconst coordSys = myChart._chartsViews[0].__model.coordinateSystem;var xAxis = coordSys.getAxis("x");var yAxis = coordSys.getAxis("y");// 图表图形区域一个单位像素的长宽let pWidth = xAxis.getBandWidth() + 0.5;let pHeight = yAxis.getBandWidth() + 0.5;// y轴倒置;左上角0,0;右下角199,99const ltP = myChart.convertToPixel({ seriesIndex: 0 }, [0, 0]);const rbP = myChart.convertToPixel({ seriesIndex: 0 }, [199, 99]);// 下移时的第一个单位像素(pixel为其中心,故需要修复)const insertP = myChart.convertToPixel({ seriesIndex: 0 }, [0, 1]);const width = rbP[0] - ltP[0] + pWidth;// const height = rbP[1] - ltP[1] + pHeight;const height = rbP[1] - ltP[1]; // 整体下移一行,舍去最后一行数据,故不加pHeightconst imgData = getImgData(layers,width,height,ltP[0] - pWidth / 2, // 中点修复ltP[1] - pHeight / 2, // 中点修复pHeight);// 创建一行数据const data = generateData(200, 1);myChart.setOption({ series: [{ data }] });myChart._zr.painter._layers[layers.at(-1)].dom.getContext("2d").putImageData(imgData,insertP[0] - pWidth / 2,insertP[1] - pHeight / 2);// [2,2.001] 2为zlevel数值,2.001应该为首次绘制创建的图层(首次绘制之后,数据更新会在2图层进行渲染;因此选择2.001作为每次旧数据渲染的图层)setTimeout(loop, 1000, [2, 2.001]);};const getImgData = (layers, width, height, offsetX, offsetY, pHeight) => {const canvas = document.createElement("canvas");canvas.height = height;canvas.width = width;const ctx = canvas.getContext("2d", { willReadFrequently: true });layers.forEach((it, i) => {const ctxTemp = myChart._zr.painter._layers[it].dom.getContext("2d");const da = ctxTemp.getImageData(offsetX,offsetY + pHeight * i,width,height - pHeight * i);ctx.putImageData(da, 0, pHeight * i);});return ctx.getImageData(0, 0, width, height);};// 启动定时器;第一次只截2.001图层的图片setTimeout(loop, 1000, [2.001]);
    

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

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

相关文章

SpringMVC-文件上传与下载

文章目录 文件上传与下载1.下载2.上传 文件上传与下载 1.下载 RequestMapping("/testDown")public ResponseEntity<byte[]> testResponseEntity(HttpSession session) throws IOException {//获取servletcontext对象ServletContext servletcontextsession.get…

蓝桥杯备战——7.DS18B20温度传感器

1.分析原理图 通过上图我们可以看到DS18B20通过单总线接到了单片机的P14上。 2.查阅DS18B20使用手册 比赛的时候是会提供DS18B20单总线通讯协议的代码&#xff0c;但是没有提供读取温度数据的代码&#xff0c;所以还是需要我们去查看手册&#xff0c;我只把重要部分截下来了 …

将Android APP安装到sm8550 HDK的NVMe SSD

APP存储路径 在Android中&#xff0c;App在运行过程中主要访问的数据路径通常包括以下几个方面&#xff1a; 内部存储&#xff08;Internal Storage&#xff09;&#xff1a;App会访问其私有的内部存储空间&#xff0c;这个空间通常位于&#xff1a; /data/data/<package…

python-自动篇-运维-根据计算机硬盘、主板、CPU生成注册信息

文章目录 准备代码效果 准备 本实例需要使用WMI模块&#xff0c;所以需要安装WMI模块。在安装WMI模块之前&#xff0c;先要安装pywin32模块&#xff0c;WMI模块需要win32api的支持。使用pip安装pywin32模块和WMI模块的代码如下&#xff1a; pip install win32com pip install …

Ubuntu 22.04 安装tomcat

tomcat是常用的Java服务容器,这篇文章我们就来讲讲如何安装它。 更新软件包 首先是更新软件包,这是最常规的操作 sudo apt update 然后是开始安装,不多一会就可以安装好了 sudo apt install tomcat9 然后看一下状态 sudo systemctl status tomcat9 发现虽然启动了,但…

openssl3.2/test/certs - 053 - Name constraints subordinate CA. Adds

文章目录 openssl3.2/test/certs - 053 - Name constraints subordinate CA. Adds概述笔记END openssl3.2/test/certs - 053 - Name constraints subordinate CA. Adds 概述 openssl3.2 - 官方demo学习 - test - certs 笔记 /*! * \file D:\my_dev\my_local_git_prj\study\…

Python第十一章(推导式)

一。列表推导式&#xff1a;目的化简代码&#xff0c;可以改变数据 例句1&#xff1a;如果while循环继续创建序列累加 例句2&#xff1a;如果for循环进行列表累加 1.循环列表推导式进行累加&#xff1a; 注释&#xff1a;第一个i表示的是返回的数据于列表&#xff0c;for后面内…

windows上使用anconda安装tensorrt环境

windows上使用anconda安装tensorrt环境 1 安装tensorrt1.1 下载最新的稳定的tensorrt 8.6.1(tensorrt对应的cuda、cudnn等版本是参考链接4)1.2 将tensorrt添加到环境变量1.3 安装tensorrt依赖1.4 安装Pycuda1.5 安装pytorch 2 测试2.1 测试TensorRT 样例(这个测试主要来源于参考…

【Python】01快速上手爬虫案例一:搞定豆瓣读书

文章目录 前言一、VSCodePython环境搭建二、爬虫案例一1、爬取第一页数据2、爬取所有页数据3、格式化html数据4、导出excel文件 前言 实战是最好的老师&#xff0c;直接案例操作&#xff0c;快速上手。 案例一&#xff0c;爬取数据&#xff0c;最终效果图&#xff1a; 一、VS…

docker生命周期管理命令

文章目录 前言1、docker create2、docker run2.1、常用选项2.2、系统2.3、网络2.4、健康检查 3、docker start/stop/restart4、docker kill5、docker rm6、docker pause/unpause总结 前言 在云原生时代&#xff0c;Docker已成为必不可少的容器管理工具。通过掌握Docker常用的容…

uniCloud发行部署H5进行网页托管

生成文件&#xff0c;生成文件这个和我们平时用uniapp 生成H5的时候是一样的&#xff0c;我们可以选择hash 或者history 模式&#xff0c;默认的这是显示的根目录&#xff0c;如果我们在根目录下建立了H5目录&#xff0c;那么我们在发布H5的时候&#xff0c;是需要在manifest.j…

数据恢复与硬盘修理

目录 第1章 基础知识 1.1 数据恢复技术的发展和研究现状 1.2 数据恢复技术的层次与体系 1&#xff0e;网络层 2&#xff0e;网络存储层 DAS NAS 3&#xff0e;磁盘阵列层 4&#xff0e;磁盘层 5&#xff0e;文件系统层 6&#xff0e;文件层 7&#xff0e;覆盖恢复…

php 源码加密保护 bease方案

推荐使用 php-bease 这个免费开源方案。 有一说一&#xff0c;这个项目上次更新时间是2021年… 多好的项目呀。 作者说在 php5.1 ~ php7.2 上都测试过。 源码地址&#xff1a; C源码&#xff1a; https://github.com/liexusong/php-beast dll版&#xff1a; https://github…

越活越“老“越值钱——来喝了这碗孟婆汤吧

目录 一、背景介绍二、思路&方案三、过程1.开头先从小编的行业说起2.扩展到各行各业&#xff0c;从小编的视角和认知的对比3.纵观人类发展和科技发展的对比4.我身边就有越活越"老"越值钱的人5.如何做到这一点的基本逻辑 四、总结 一、背景介绍 对于自己的未来&a…

Java强训day4(选择题编程题)

选择题 接口中的方法是为了让重写编程题 题目 import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int a_b sc.nextInt();int b_c sc.nextInt();int ab sc.nextInt();int bc sc.nextInt();for(in…

mysql索引失效

索引失效 1.违反最左前缀法则 查询要从索引的最左前列开始&#xff0c;不能跳过索引中的列 没有违反 违反 部分违反&#xff0c;只有最左边的命中索引 2.查询右边范围的列&#xff0c;不能使用索引 范维列不满足最左前缀 3.索引列上进行运算&#xff0c;索引会失效 改变…

假期刷题打卡--Day15

1、MT1152韩信又生气了 韩信点兵(大于10人)&#xff0c;三个三个一排少1个人&#xff0c;五个五个一排又少1个人&#xff0c;七个七个一排还少1个人。韩信生气了&#xff0c;从别的队伍里调来一个人!这样不管是三个一排五个一排还是七个一排都完美了。问原本最少应该有多少人。…

【python】程序的流程控制

程序的流程控制 程序的描述方式程序的组织结构顺序结构选择/分支结构单分支if语法结构双分支if...else...结构多分支结构选择结构循环结构for与while程序跳转语句break和continuepass空语句程序的描述方式 自然语言:使用人类语言,直接描述程序 inputprocessoutput流程图:用…

每日一练 | 华为认证真题练习Day172

1、关于OSPF的ASBR-SUMMARY-LSA中LSA头部他、信息描述错误的是 A. LINK STATE ID表示ASBR的ROUTER ID B. ADVERTISING ROUTER表示该ABR的ROUTER ID C. ADVERTISING ROUTER字段永远不会改变 D. METRIC表示该ABR到达ASBR的OSPF开销 2、关于OSPF外部路由种类描述错误的是 A. …

神经网络进一步学习

一、代价函数 首先引入一些便于稍后讨论的新标记方法&#xff1a;假设神经网络的训练样本有m个&#xff0c;每个包含一组输入x和一组输出y&#xff0c;L表示神经网络层数&#xff0c;表示该层的神经元个数&#xff0c;将神经网络的分类定义为两种情况&#xff1a;二类分类和多类…