echarts中视觉映射器(visualMap)与时间轴(timeline)混用的实现方法
1、简述
echarts中的 timeline 组件,提供了在多个 ECharts option 间进行切换、播放等操作的功能。
与其他组件些不同,它需要操作『多个option』。 所以除了基准的baseOption外,我们还需要设置一个原子option和多个原子option的复合option。
2. baseOption实现方式如下(以石家庄市地图为例):
var mapDataByAreaTest = [ //各区域初始值
{name: '长安区', value: 12},
{name: '辛集市', value: 0},
{name: '无极县', value: 0},
{name: '赵县', value: 0},
{name: '平山县', value: 0},
{name: '元氏县', value: 0},
{name: '灵寿县', value: 0},
{name: '赞皇县', value: 0},
{name: '深泽县', value: 0},
{name: '高邑县', value: 0},
{name: '新华区', value: 34},
{name: '井陉县', value: 0},
{name: '行唐县', value: 0},
{name: '正定县', value: 31},
{name: '桥西区', value: 5},
{name: '栾城区', value: 21},
{name: '鹿泉区', value: 25},
{name: '藁城区', value: 30},
{name: '裕华区', value: 7},
{name: '井陉矿区', value: 45},
{name: '晋州市', value: 0},
{name: '新乐市', value: 0}
];
var timeByMonth = ['1月','2月','3月','4月','5月','6月','7月','8月','9月','10月','11月','12月'];//timeline初始值
var baseOption = {
timeline: {
show: true,
axisType: 'category',
autoPlay: true,
currentIndex: 5,
playInterval: 5000,
symbolSize: 12,
checkpointStyle: {
symbol: 'circle',
symbolSize: 18,
color: '#00d3e7',
borderWidth: 2,
borderColor: "#00d3e7"
},
label: {
normal: {
show: true,
textStyle: {
fontSize: '14',
color:'#fff'
}
},
emphasis:{
textStyle: {
fontSize: '18',
color:'#00d3e7'
}
}
},
data: timeByMonth
},
visualMap: {
min: 0,
max: 50,
left: '16%',
top: '68%',
text: ['高','低'],
calculable: true,
itemWidth: 30,
inRange: {
color: ['#56c5d0','#eac736','#d94e5d']
},
textStyle: {
fontSize: '16',
color:'#fff'
}
},
series: [{
name: '',
type: 'map',
mapType: 'sjz',
itemStyle:{
normal:{label:{show:true}},
emphasis:{label:{show:true}}
},
roam: false,
label: {
normal: {
show: true,
textStyle: {
fontSize: '14',
color:'#fff'
}
},
emphasis: {
show: true
}
},
data:mapDataByAreaTest
}]
};
3. options实现方式如下:
varar options = [];
var mapOption = {};
for(var i=0;i<timeByMonth.length;i++){
options.push({
series: baseOption.series//此处可以根据实际情况循环放置每个option的series对应的data值
});
}
mapOption.baseOption = baseOption;
mapOption.options = options;
4. 页面地图绘制:
$.get('/data/sjz_map.json', function (data) {
echarts.registerMap('sjz', data);
var myChart = echarts.init(document.getElementById('sjz_map'));
myChart.setOption(mapOption);
myChart.on("timelinechanged", function(param){
/ /TODO DO SOMETING ELSE HERE
myChart.setOption(mapOption);
});
});
echarts中视觉映射器(visualMap)与时间轴(timeline)混用的实现方法的更多相关文章
- 时间轴 timeline
时间轴 timeline https://www.helloweba.net/javascript/285.html https://www.helloweba.net/demo/v_timeline ...
- SSM-SpringMVC-07:SpringMVC中处理器映射器
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- BeanNameUrlHandlerMapping和SimpleUrlHandlerMapping BeanN ...
- 关于QtCharts中的映射器与模型的使用
简述 本文章基于博主在使用QtCharts中一些经验总结,相关了Qt类有QVXYModelMapper,CustomTableModel(一个继承了QAbstractTableModel的类,用于实现 ...
- SharePoint 中时间轴 Timeline的实现
客户需要在OA中实现每日动态功能,能够记录每一位员工的每天的工作动态,我很快想到了时间轴,因为时间轴能很直观的现实员工每一刻的动态.就像Facebook的Timeline效果(点击查看). 尝试着搜索 ...
- echarts使用结合时间轴timeline动态刷新案例
1.echarts简介 ECharts,一个使用 JavaScript 实现的开源可视化库,可以流畅的运行在 PC 和移动设备上,兼容当前绝大部分浏览器(IE8/9/10/11,Chrome,Fire ...
- Alamofire源码解读系列(十二)之时间轴(Timeline)
本篇带来Alamofire中关于Timeline的一些思路 前言 Timeline翻译后的意思是时间轴,可以表示一个事件从开始到结束的时间节点.时间轴的概念能够应用在很多地方,比如说微博的主页就是一个 ...
- 横向、纵向时间轴timeline系列
近期移动端项目用到了很多时间轴.纵向的.开始可以实现,但是不利于维护.整理下, 以作为备份留存学习参考.子元素的 标签的 :before实现圆点,:after实现边线border纵向时间轴,单一右边内 ...
- 超酷的JavaScript叙事性时间轴(Timeline)类库
在线演示 Timeline 是我见过的最酷的展示事件随时间发展的javascript实现.你可以基于时间使用讲故事的方式来创建时间轴特效,整个时间轴以幻灯的方式来展示,你可以穿插图片,视频或者是网站, ...
- JQuery时间轴timeline插件的学习-Lateral On-Scroll Sliding with jQuery+technotarek / timeliner
一.Lateral On-Scroll Sliding with jQuery的使用 View demo Download source 1. HTML结构 <div id=" ...
随机推荐
- ASP.NET Core Razor中处理Ajax请求
如何ASP.NET Core Razor中处理Ajax请求 在ASP.NET Core Razor(以下简称Razor)刚出来的时候,看了一下官方的文档,一直没怎么用过.今天闲来无事,准备用Rozor ...
- JavaScript 模块化历程
这是一篇关于js模块化历程的长长的流水账,记录js模块化思想的诞生与变迁,展望ES6模块化标准的未来.经历过这段历史的人或许会感到沧桑,没经历过的人也应该知道这段历史. 无模块时代 在ajax还未提出 ...
- CTF---Web入门第八题 Guess Next Session
Guess Next Session分值:10 来源: iFurySt 难度:易 参与人数:3870人 Get Flag:1672人 答题人数:1690人 解题通过率:99% 写个算法没准就算出来了, ...
- Wannafly模拟赛 A.矩阵(二分答案+hash)
矩阵 时间限制:1秒 空间限制:131072K 题目描述 给出一个n * m的矩阵.让你从中发现一个最大的正方形.使得这样子的正方形在矩阵中出现了至少两次.输出最大正方形的边长. 输入描述: 第一行两 ...
- 【Java学习笔记之十三】初探Java面向对象的过程及代码实现
理解Java面向对象的重要知识点: 一. 类,对象 类?首先举一个例子:小李设计了一张汽车设计图,然后交给生产车间来生产汽车,有黑色的.红色的.白色的... 这里,汽车设计图就是我们说的类(class ...
- hdu_1014(竟然真的还有更水的)
注意输出就没了... #include<cstdio> #include<cstring> using namespace std; int gcd(int a, int b) ...
- 线段树入门HDU_1754
题目链接:点击打开链接 I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- mysql 恢复数据
前提:保存了需要恢复数据库的文件 .frm 和 .ibd 文件 条件:InnoDB 类型的 恢复表结构1.新建一个数据库--新建一个表,表名和列数和需要恢复数据库相同2.停止mysql服务器 serv ...
- PHPStorm+PHPStudy配置XDebug
img { max-width: 100% } 上一节里面从PHPStudy+PHPStorm的配置,到最后发布,PHPStorm只是承担了编辑器和发布站点的任务,但是还没有办法像Visual Stu ...
- php短信接口代码
这篇文章主要为大家详细介绍了php短信接口代码,php短信发送.php批量发送.php获取余额等代码,感兴趣的小伙伴们可以参考一下 本文实例为大家分享了几个常用的php短信接口代码,供大家参考,具体内 ...