Apache ECharts 实现散点图与边缘直方图的组合展示
2025-04-30 07:12:21作者:苗圣禹Peter
echarts
Apache ECharts is a powerful, interactive charting and data visualization library for browser
在数据可视化领域,散点图与边缘直方图的组合(Scatter with Marginal Histogram)是一种经典的多维度数据展示方式。它通过在主图(散点图)的坐标轴边缘叠加直方图,既能展示变量间的相关性,又能直观呈现单变量的分布特征。Apache ECharts 作为强大的可视化库,原生支持通过多坐标系和自定义布局实现这一效果。
核心实现原理
-
多坐标系布局
利用grid配置项划分主图和边缘图的显示区域。例如:- 主散点图占据中心区域(如
grid: {width: '70%', height: '70%'}) - X/Y轴边缘直方图分别通过额外的
grid区域定位(如left: '75%'或top: '75%')
- 主散点图占据中心区域(如
-
数据联动
主散点图与边缘直方图共享同一份数据源,通过dataset实现数据绑定。直方图数据可通过echarts-stat插件或自定义分箱计算生成。 -
视觉对齐
通过调整坐标轴的scale: true和boundaryGap属性,确保主图与边缘图的刻度对齐,避免视觉偏差。
完整实现示例
option = {
dataset: { source: [...] }, // 共享数据源
grid: [
// 主散点图区域
{ left: '10%', right: '20%', bottom: '20%', top: '10%' },
// X轴边缘直方图
{ left: '10%', right: '20%', bottom: '5%', height: '15%' },
// Y轴边缘直方图
{ left: '5%', width: '15%', bottom: '20%', top: '10%' }
],
xAxis: [
// 主图X轴
{ gridIndex: 0, type: 'value' },
// 边缘直方图X轴(隐藏)
{ gridIndex: 1, show: false }
],
yAxis: [
// 主图Y轴
{ gridIndex: 0, type: 'value' },
// 边缘直方图Y轴(隐藏)
{ gridIndex: 2, show: false }
],
series: [
// 主散点图
{ type: 'scatter', xAxisIndex: 0, yAxisIndex: 0 },
// X轴直方图
{ type: 'bar', xAxisIndex: 1, yAxisIndex: 1,
barWidth: '99%', itemStyle: { opacity: 0.6 } },
// Y轴直方图(需转置)
{ type: 'bar', xAxisIndex: 2, yAxisIndex: 2,
barWidth: '99%', itemStyle: { opacity: 0.6 } }
]
};
高级技巧
-
响应式适配
通过resize事件监听动态计算grid尺寸,适配不同屏幕。 -
交互增强
添加brush组件实现联动筛选,或通过dataZoom同步控制显示范围。 -
样式优化
- 使用半透明色避免边缘图遮挡主图
- 为直方图添加渐变填充增强层次感
这种组合图表特别适用于医学统计、金融数据分析等需要同时观察分布特征和相关性的场景。通过 ECharts 灵活的配置体系,开发者可以快速构建出专业级的多维度数据可视化方案。
echarts
Apache ECharts is a powerful, interactive charting and data visualization library for browser
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5-w4a8GLM-5-w4a8基于混合专家架构,专为复杂系统工程与长周期智能体任务设计。支持单/多节点部署,适配Atlas 800T A3,采用w4a8量化技术,结合vLLM推理优化,高效平衡性能与精度,助力智能应用开发Jinja00
jiuwenclawJiuwenClaw 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。Python0193- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
awesome-zig一个关于 Zig 优秀库及资源的协作列表。Makefile00
项目优选
收起
deepin linux kernel
C
27
12
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
601
4.04 K
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
69
21
Ascend Extension for PyTorch
Python
441
531
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
112
170
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.46 K
825
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
922
770
暂无简介
Dart
847
204
React Native鸿蒙化仓库
JavaScript
321
375
openGauss kernel ~ openGauss is an open source relational database management system
C++
174
249