使用百度echarts仿雪球分时图(二)
上一章简单的介绍了一下分时图的构成,其实就是折线图跟柱状图的组成。本来这章打算是把分时图做完,然后再写一章来进行美化和总结,但是仔细观察了一下,发现其实东西还是有点多的。分时图的图表做完后,还要去美化,调整分数图的各种提示信息,比如鼠标放进去的时候会有一个十字,一个信息框,以及各个刻度的详细刻度值,等等。所以这章我们要的是把分时图图表全部画出来,美化、提示信息则放到接下来的章节。开始写代码。
一.使用echarts的grid属性,把多个图表整合成一个图表。上一章末尾,我们用PS工具把两个图表放在一起,形成了一个初步的分时图的样子,这次我们用代码来把多个图表整合到一块,这就要使用到echarts的grid属性了。 echarts的grid属性,官方文档是这么写的:直角坐标系内绘图网格,单个 grid 内最多可以放置上下两个 X 轴,左右两个 Y 轴。可以在网格上绘制折线图,柱状图,散点图(气泡图)。也就是说我们可以把一个大的图表拆成多个图表来进行组合,每一个grid就是一个单独图表,而我们的分时图恰好是多个图表组成,所以非常适合使用grid来实现。

如图,我们把分时图拆成4个grid来实现,为什么是4个grid,后面会提到。(提示:grid可以根据个人习惯来放置)
二.我们先使用上一节的折线图、柱状图例子,来生成4个grid,并且把它们组合到一起。grid属性可以是一个对象,也可以是一个数组,因为我们有4个图表,所以使用数组的方式来实现。
// echarts折线图的配置项
var option = {
// grid
grid:[
// 第一个grid
{
top:10,// 图表的外边距
height:200,// 图表的高度
width:'50%',//因为是左右各一个图表,使用百分比的方式显得更方便,
},
// 第二个grid,第二个图表是在第一个图表的下方,所以要把它定位到底部
{
top:210,//设置上方的外边距是第一个图表的高度再加10,使用top是方便我们调整下方grid的高度
width:'50%',// 宽度与第一个图表一个大
height:100
}
],
// 多个图表则会存在对个x轴y轴,所以这里的配置我们也换成数组的方式
// x轴配置,
xAxis:[
// 第一个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:0,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第二个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:1,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
}
],
// y轴配置
yAxis: [
// 第一个grid的y轴属性
{
gridIndex:0,
type: 'value'
},
// 第二个grid的y轴属性
{
gridIndex:1,
type: 'value'
}
],
// 数据可以通过xAxisIndex,yAxisIndex属性,来指定是哪个grid的数据
series: [{
xAxisIndex:0,
yAxisIndex:0,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'line'
},{
xAxisIndex:1,
yAxisIndex:1,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'bar'
}]
};
这是效果图
这个是2个grid的组成,同理我们复制一下grid,修改一下配置,就可以变成4个grid的组合。
// echarts折线图的配置项
var option = {
// grid
grid:[
// 第一个grid
{
top:10,// 图表的外边距
height:200,// 图表的高度
left:0,
width:'50%',//因为是左右各一个图表,使用百分比的方式显得更方便,
},
// 第二个grid,第二个图表是在第一个图表的下方,所以要把它定位到底部
{
top:210,//设置上方的外边距是第一个图表的高度再加10,使用top是方便我们调整下方grid的高度
left:0,
width:'50%',// 宽度与第一个图表一个大
height:100
},
// 第三个grid,第三个图表是在第一个图表的右方,所以要把它定位到右方
{
top:10,// 图表的外边距
left:'50%',//设置右边图表的左边距是第一个图表的大小,达到定位右边的效果
width:'50%',// 宽度与第一个图表一个大
height:200
},
// 第四个grid,第四个图表是在第三个图表的下方,所以要把它定位到底部
{
top:210,//设置上方的外边距是第三个图表的高度再加10,使用top是方便我们调整下方grid的高度
left:'50%',//设置右边图表的左边距是第三个图表的大小,达到定位右边的效果
width:'50%',// 宽度与第一个图表一个大
height:100
}
],
// 多个图表则会存在对个x轴y轴,所以这里的配置我们也换成数组的方式
// x轴配置,
xAxis:[
// 第一个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:0,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第二个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:1,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第三个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:2,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第三个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:3,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
}
],
// y轴配置
yAxis: [
// 第一个grid的y轴属性
{
gridIndex:0,
type: 'value'
},
// 第二个grid的y轴属性
{
gridIndex:1,
type: 'value'
},
// 第三个grid的y轴属性
{
gridIndex:2,
type: 'value'
},
// 第四个grid的y轴属性
{
gridIndex:3,
type: 'value'
}
],
// 数据可以通过xAxisIndex,yAxisIndex属性,来指定是哪个grid的数据
series: [{
xAxisIndex:0,
yAxisIndex:0,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'line'
},{
xAxisIndex:1,
yAxisIndex:1,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'bar'
},{
xAxisIndex:2,
yAxisIndex:2,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'line'
},{
xAxisIndex:3,
yAxisIndex:3,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'bar'
}]
};
效果图
到这一步,4个grid已经全部出来了,接下来就是要去调整图表的样式了。
三.现在我们看到左边的刻度值是不见了的,图形的第一个点和边框是有一定的距离,右边图表的刻度值应该是要显示在右边的,而且上方的两个折线图图表的x轴刻度是不应该显示的,所以我们先调整一下。
调整这个样式,主要是针对x轴y轴的属性进行调整。
1.左边的刻度不显示,是因为我们把grid的left值设置成了0,没有留给刻度值显示的位置,所以把左边图表的left值设置得大一些。left值变大后,会发现右边的图表跟左边的图表重叠了,因为右边的图表的left值是第一个图表的宽度,但是图表的宽度不包括刻度值的宽度,这两个是独立的,所以右边图表的left值,应该是 第一个图表的width+第一个图表的left值,为了方便,我们把第一个图表的left修改成10%,宽度是40%,这样一来,右边的图表的left值就可以是50%了,但是宽度要修改成40%,(个人建议:使用图表div的宽度,来计算各个图表的left值,width值,而不是使用百分比)。
// grid
grid:[
// 第一个grid
{
top:10,// 图表的外边距
height:200,// 图表的高度
left:'10%',
width:'40%',//因为是左右各一个图表,使用百分比的方式显得更方便,
},
// 第二个grid,第二个图表是在第一个图表的下方,所以要把它定位到底部
{
top:210,//设置上方的外边距是第一个图表的高度再加10,使用top是方便我们调整下方grid的高度
left:'10%',
width:'40%',// 宽度与第一个图表一个大
height:100
},
// 第三个grid,第三个图表是在第一个图表的右方,所以要把它定位到右方
{
top:10,// 图表的外边距
left:'50%',//设置右边图表的左边距是第一个图表的大小,达到定位右边的效果
width:'40%',// 宽度与第一个图表一个大
height:200
},
// 第四个grid,第四个图表是在第三个图表的下方,所以要把它定位到底部
{
top:210,//设置上方的外边距是第三个图表的高度再加10,使用top是方便我们调整下方grid的高度
left:'50%',//设置右边图表的左边距是第三个图表的大小,达到定位右边的效果
width:'40%',// 宽度与第一个图表一个大
height:100
}
],
效果图
这样左边的刻度就出来了。接下来我们把右边图表的刻度,换到右边来显示,x轴y轴有一个postion属性,x轴的postion属性可以设置x轴显示在下方还是上方,y轴的position属性可以设置y轴显示在左边还是右边;上方的折线图的x轴刻度,是不需要显示的,x轴的axisTick,axisLabel属性是配置刻度的,把这两个属性show属性设置成false即可,所以修改代码。
// 多个图表则会存在对个x轴y轴,所以这里的配置我们也换成数组的方式
// x轴配置,
xAxis:[
// 第一个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:0,
// x轴的刻度
axisTick:{show:false},
// x轴的刻度值
axisLabel:{show:false},
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第二个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:1,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第三个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:2,
// x轴的刻度
axisTick:{show:false},
// x轴的刻度值
axisLabel:{show:false},
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第三个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:3,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
}
],
// y轴配置
yAxis: [
// 第一个grid的y轴属性
{
gridIndex:0,
type: 'value'
},
// 第二个grid的y轴属性
{
gridIndex:1,
type: 'value'
},
// 第三个grid的y轴属性
{
position:'right',
gridIndex:2,
type: 'value'
},
// 第四个grid的y轴属性
{
position:'right',
gridIndex:3,
type: 'value'
}
],
效果图
接下来,我们把再进行一些美化,图形的第一个图形跟左边边框是有空隙的,要把这个空隙给取消掉,使用x轴的属性boundaryGap来配置是否留有空隙;底部的柱状图也要往下移一移,将top值加大,使用barWidth属性,设置柱状图的柱子也要变得苗条一些;折线图的颜色要统一起来,把线条上的圆点去掉,而且线条看起来很僵硬,要设置得顺滑一些。修改后的代码如下:
// echarts折线图的配置项
var option = {
// grid
grid:[
// 第一个grid
{
top:10,// 图表的外边距
height:200,// 图表的高度
left:'10%',
width:'40%',//因为是左右各一个图表,使用百分比的方式显得更方便,
},
// 第二个grid,第二个图表是在第一个图表的下方,所以要把它定位到底部
{
top:240,//设置上方的外边距是第一个图表的高度再加10,使用top是方便我们调整下方grid的高度
left:'10%',
width:'40%',// 宽度与第一个图表一个大
height:100
},
// 第三个grid,第三个图表是在第一个图表的右方,所以要把它定位到右方
{
top:10,// 图表的外边距
left:'50%',//设置右边图表的左边距是第一个图表的大小,达到定位右边的效果
width:'40%',// 宽度与第一个图表一个大
height:200
},
// 第四个grid,第四个图表是在第三个图表的下方,所以要把它定位到底部
{
top:240,//设置上方的外边距是第三个图表的高度再加10,使用top是方便我们调整下方grid的高度
left:'50%',//设置右边图表的左边距是第三个图表的大小,达到定位右边的效果
width:'40%',// 宽度与第一个图表一个大
height:100
}
],
// 多个图表则会存在对个x轴y轴,所以这里的配置我们也换成数组的方式
// x轴配置,
xAxis:[
// 第一个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:0,
// 坐标轴是否留白
boundaryGap:false,
// x轴的刻度
axisTick:{show:false},
// x轴的刻度值
axisLabel:{show:false},
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第二个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:1,
// 坐标轴是否留白
boundaryGap:false,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第三个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:2,
// 坐标轴是否留白
boundaryGap:false,
// x轴的刻度
axisTick:{show:false},
// x轴的刻度值
axisLabel:{show:false},
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
},
// 第三个grid的x轴属性
{
// 告诉echarts,这个第一个grid的x轴
gridIndex:3,
// 坐标轴是否留白
boundaryGap:false,
type: 'category',
// x轴显示的数据
data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
}
],
// y轴配置
yAxis: [
// 第一个grid的y轴属性
{
gridIndex:0,
type: 'value'
},
// 第二个grid的y轴属性
{
gridIndex:1,
type: 'value'
},
// 第三个grid的y轴属性
{
position:'right',
gridIndex:2,
type: 'value'
},
// 第四个grid的y轴属性
{
position:'right',
gridIndex:3,
type: 'value'
}
],
// 数据可以通过xAxisIndex,yAxisIndex属性,来指定是哪个grid的数据
series: [
// 第一个图表的数据
{
// 平滑曲线
smooth:true,
// 是否显示折线上的圆点
symbol:'none',
// 线条颜色
lineStyle:{
color:"#0983F8"
},
xAxisIndex:0,
yAxisIndex:0,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'line'
},
// 第二个图表的数据
{
xAxisIndex:1,
yAxisIndex:1,
// 柱状图柱子宽度
barWidth:5,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'bar'
},
// 第三个图表的数据
{
// 平滑曲线
smooth:true,
// 是否显示折线上的圆点
symbol:'none',
// 线条颜色
lineStyle:{
color:"#0983F8"
},
xAxisIndex:2,
yAxisIndex:2,
data: [4, 5, 5, 8, 2, 9, 4],
type: 'line'
},
// 第四个图表的数据
{
xAxisIndex:3,
yAxisIndex:3,
// 柱状图柱子宽度
barWidth:5,
data: [1, 5, 5, 8, 2, 9, 4],
type: 'bar'
}
]
};
效果图

本章节先到这里吧,这次我们用grid属性把4个grid组合成了一个大的图表,分时图已经基本成型,接下来的章节将对分时图进行全面的美化,并使用网络上的真实数据来展示我们的分时图。
使用百度echarts仿雪球分时图(二)的更多相关文章
- 使用百度echarts仿雪球分时图(四)
这章节来收拾一下一些小BUG,顺便把各个小提示信息也补上,分时图也就完成了. 上章节末尾提到的一个bug,就是第一个grid跟第三个grid之间是断开的,折线并没有连在一起,所以先来收拾这个问题.没有 ...
- 使用百度echarts仿雪球分时图(一)
第一次写技术博客,有不足的地方希望大家指证出来,我再加以改正,谢谢大家. 之前一直没有找到一个合适的分时图项目,所以决定自己动手撸一个.接触的图表框架不多,在网上看到不少人推荐使用echarts,看了 ...
- 使用百度echarts仿雪球分时图(三)
这章节将完成我们的分时图,并使用真实的数据来进行展示分时图. 一天的交易时间段分为上午的09:30~11:30,下午的13:00~15:00两个时间段,因为分时间段的关系,数据是不连续的,所以会先分为 ...
- 使用百度Echarts制作力导向图
最近项目需求制作一个力导向图来展示企业的画像等关系信息,故想到了百度Echarts的关系图,在这使用Echarts3.0版本来实现.先上效果图,再看代吗 哎,本来想整个工程扔出来,发现好像没地方上传附 ...
- WPF仿百度Echarts人口迁移图
GitHub地址:https://github.com/ptddqr/wpf-echarts-map/tree/master 关于大名鼎鼎的百度Echarts我就不多说了 不了解的朋友直接看官方的例子 ...
- C#+JQuery+.Ashx+百度Echarts实现全国省市地图和饼状图动态数据图形报表的统计
在目前的一个项目中,需要用到报表表现数据,这些数据有多个维度,需要同时表现出来,同时可能会有大量数据呈现的需求,经过几轮挑选,最终选择了百度的echarts作为报表基础类库.echarts功能强大,界 ...
- 百度echarts可以做什么
百度echarts可以做什么 一.总结 一句话总结:可视化做的很好,各种图都有.而且支持动态数据. 二.百度eCharts体验 前言 从昨天开始给项目里添加一些图表对比功能,上一个项目里使用的是Hig ...
- ECharts使用心得总结(二)
Echarts使用心得总结(二) 前言: 前一段时间一直都挺忙的,各种事,也没来得及每周的总结,趁着晚上的一点时间把项目中用的Echart中常用的各种图表给抽象总结了一下,趁着周末跟大家分享一下.之前 ...
- iOS-Andriod百度地图仿百度外卖-饿了么-选择我的地址-POI检索/
http://zanderzhang.gitcafe.io/2015/09/19/iOS-Andriod百度地图仿百度外卖-饿了么-选择我的地址-POI检索/ 百度外卖选择送货地址: 饿了么选择送货地 ...
随机推荐
- laydate V5-0-8动态设置min值
laydate通过设置min,max值来对用户输入的时间做约束 laydate v1.0版本 //日期插件 var start={ elem:"#start", format:&q ...
- Windows Bat 之For 循环
Windows Bat 之For 循环 1. For 循环基本用法. 1.1 格式 在cmd窗口中: FOR %variable IN (set) DO command [command-pa ...
- Qt编写自定义控件22-蚂蚁线
一.前言 关于蚂蚁线控件,相信很多用过PS的人都知道,在选中某个区域以后,边上的线条会有一种动态流动的效果,这种效果就叫做蚂蚁线,百科的解释是:动物的一种本能现象,领头的蚂蚁以随机的路线走向食物或洞穴 ...
- Linux命令之iptables
从CentOS7开始,系统自带的防火墙更改为firewalld,但同样支持iptables,不过只有iptables命令,如果想要使用iptables服务需要自行安装iptables-server. ...
- C#的String.Format举例
1.格式化货币(跟系统的环境有关,中文系统默认格式化人民币,英文系统格式化美元) string.Format("{0:C}",0.2) 结果为:¥0.20 (英文操作系统结果:$0 ...
- Spring Aop(七)——基于XML配置的Spring Aop
转发:https://www.iteye.com/blog/elim-2396043 7 基于XML配置的Spring AOP 基于XML配置的Spring AOP需要引入AOP配置的Schema,然 ...
- 将SSRF升级为RCE(AWS环境)
原文:https://generaleg0x01.com/2019/03/10/escalating-ssrf-to-rce/ 查找域名范围: 在枚举客户端的子域名时.找到了子域名[docs] 打开这 ...
- Linux生成ssh密钥免密登录,允许/禁止密码登录,允许/禁止root远程登录,更改ssh端口
进入想要使用密钥登录的用户家目录 cd 或 cd ~ 执行密钥创建命令,不行可能需要下载openssh-server与openssh-client ssh-keygen -t rsa -P " ...
- Map对象,Set对象使用(2)
今天重点见一下Set Set 在我印象里它主要就是去重,Set 是一个值的集合,这个集合中所有的值仅出现一次 Set 属性size:和Map的size一样,返回成员的总数 Set的方法: Set.pr ...
- 【DSP开发技术】影响高性能DSP功耗的因素及其优化方法
影响高性能DSP功耗的因素及其优化方法 德州仪器DSP技术应用工程师 冯华亮 摘要 本文讨论影响高性能DSP功耗的因素,介绍一些DSP功耗的优化方法. 随着嵌入式应用需求的不断提高,DSP的速度也不断 ...