多Y轴+时间轴+缩放+markLine
配置项如下
function timeParse(time, format) {
if (time === "" || time === undefined || time === null) {
return '';
};
var t = new Date(time);
t = t.getFullYear() > 0 ? t : new Date(Date.parse(time.replace(/-/g, "/"))); // Safari 出现日期转换的问题
var tf = function(i) {
return (i < 10 ? '0' : '') + i
};
return format.replace(/yyyy|MM|dd|HH|mm|ss/g, function(a) {
switch (a) {
case 'yyyy':
return tf(t.getFullYear());
case 'MM':
return tf(t.getMonth() + 1);
case 'mm':
return tf(t.getMinutes());
case 'dd':
return tf(t.getDate());
case 'HH':
return tf(t.getHours());
case 'ss':
return tf(t.getSeconds());
}
})
}
let markData = [{
name: "早餐",
xAxis: 1569979320000
}, {
name: "午餐",
xAxis: 1569990120000
}, {
name: "晚餐",
xAxis: 1570016300000
}]
option = {
tooltip: {
trigger: 'item',
axisPointer: {
show: true,
type: 'cross',
lineStyle: {
type: 'dashed',
width: 1
},
label: {
backgroundColor: "rgba(50, 50, 50, 0.8)"
}
},
formatter: function(e) {
let value = e.value;
if (e.seriesIndex === 0) { // 血糖值
return e.marker + "血糖值:" + value[1] + "<br/>时间:" + timeParse(value[0], "MM-dd HH:mm:ss");
} else if (e.seriesIndex === 1) { // 用药记录
return e.marker + "剂量:" + value[1] + "<br/>时间:" + timeParse(value[0], "MM-dd HH:mm:ss");
} else {
return e.marker + "饮食记录:" + value[1] + "<br/>时间:" + timeParse(value[0], "MM-dd HH:mm:ss");
}
}
},
dataZoom: [{
// realtime: false, // 拖动时,是否实时更新系列的视图。如果设置为 false,则只在拖拽结束的时候更新。
startValue: 0,
xAxisIndex: [0, 1],
minValueSpan: 3600 * 24 * 1000,
maxValueSpan: 3600 * 24 * 1000,
top: "51%"
}],
grid: [{
left: '8%',
right: 50,
height: '35%'
}, {
left: '8%',
right: 50,
top: '58%',
height: '35%'
}],
xAxis: [{
type: 'time',
boundaryGap: true,
interval: 3600 * 4 * 1000,
min: 1569945600000,
max: 1570536000000,
splitLine: {
show: false
},
axisLine: {
lineStyle: { // 轴上的线样式
color: '#ccc'
}
},
axisLabel: {
color: "#333"
}
}, {
gridIndex: 1,
type: 'time',
boundaryGap: true,
interval: 3600 * 4 * 1000,
min: 1569945600000,
max: 1570536000000,
axisLine: {
onZero: true
},
splitLine: {
show: false
},
axisTick: {
show: false
},
position: 'bottom',
axisLine: {
lineStyle: { // 轴上的线样式
color: '#ccc'
}
},
axisLabel: {
show: false,
color: "#333"
}
}],
yAxis: [{
name: '血糖(mmol/L)',
nameGap: 40,
nameTextStyle: {
color: "#333"
},
axisTick: {
show: false
},
axisLabel: {
show: true,
color: "#333",
interval: 'auto'
},
axisLine: {
lineStyle: { // 轴上的线样式
color: '#ccc'
}
},
splitLine: {
lineStyle: {
color: '#dedede'
}
}
}, {
name: '', // 隐藏的Y轴
gridIndex: 1,
max: 20,
axisLine: {
show: false
},
axisTick: {
show: false
},
splitLine: {
show: false
},
axisLabel: {
show: false
}
}, {
name: '胰岛素(IU)',
nameGap: 40,
nameTextStyle: {
color: "#333"
},
axisTick: {
show: false
},
axisLabel: {
show: true,
color: "#333",
interval: 'auto'
},
axisLine: {
lineStyle: { // 轴上的线样式
color: '#ccc'
}
},
splitLine: {
show: false
}
}],
series: [{
type: 'line',
yAxisIndex: 0,
color: ['#ED5358'],
smooth: true,
symbol: "roundRect",
symbolSize: 8,
data: [
[1569945600000, 20],
[1569960000000, 31],
[1569974400000, 21],
[1569988800000, 3],
[1570003200000, 1],
[1570017600000, 5],
[1570032000000, 6],
[1570046400000, 2],
[1570060800000, 2],
[1570075200000, 8],
[1570089600000, 1],
[1570104000000, 6],
[1570118400000, 8],
[1570132800000, 5],
[1570147200000, 12],
[1570161600000, 12],
[1570176000000, 0],
[1570190400000, 9],
[1570204800000, 10],
[1570219200000, 5],
[1570233600000, 0],
[1570248000000, 9],
[1570262400000, 22],
[1570276800000, 1],
[1570291200000, 3],
[1570305600000, 9],
[1570320000000, 7],
[1570334400000, 8],
[1570348800000, 14],
[1570363200000, 17],
[1570377600000, 28],
[1570392000000, 11],
[1570406400000, 21],
[1570420800000, 26],
[1570435200000, 12],
[1570449600000, 28],
[1570464000000, 15],
[1570478400000, 28],
[1570492800000, 18],
[1570507200000, 39],
[1570521600000, 1],
[1570536000000, 30]
]
},
{
type: 'scatter',
yAxisIndex: 2,
color: ['#0073cf'],
symbol: "image://",
symbolSize: 25,
data: [
[1569945600000, 1],
[1569960000000, 5],
[1569974400000, 4],
[1569988800000, 8],
[1570003200000, 8],
[1570017600000, 7],
[1570032000000, 2],
[1570046400000, 8],
[1570060800000, 6],
[1570075200000, 4],
[1570089600000, 1],
[1570104000000, 4],
[1570118400000, 6],
[1570132800000, 1],
[1570147200000, 7],
[1570161600000, 3],
[1570176000000, 8],
[1570190400000, 0],
[1570204800000, 5],
[1570219200000, 7],
[1570233600000, 7],
[1570248000000, 4],
[1570262400000, 0],
[1570276800000, 3],
[1570291200000, 8],
[1570305600000, 7],
[1570320000000, 7],
[1570334400000, 6],
[1570348800000, 5],
[1570363200000, 5],
[1570377600000, 3],
[1570392000000, 7],
[1570406400000, 7],
[1570420800000, 8],
[1570435200000, 7],
[1570449600000, 4],
[1570464000000, 2],
[1570478400000, 4],
[1570492800000, 7],
[1570507200000, 7],
[1570521600000, 4],
[1570536000000, 8]
],
markLine: {
silent: true,
symbol: "diamond",
symbolSize: 10,
label: {
color: "#333",
formatter: function(e) {
let item = markData[e.dataIndex];
return `${item.name}\n${timeParse(e.value, 'HH:mm')}\n`; // "早餐\n"+ timeParse(e.value, 'HH:mm')+"\n";
}
},
lineStyle: {
normal: {
color: "#999",
type: 'solid'
}
},
data: markData
}
}, {
name: '表格饮食记录',
type: 'scatter',
xAxisIndex: 1,
yAxisIndex: 1,
animation: false,
symbol: "rect",
symbolSize: [150, 240],
itemStyle: {
color: "transparent"
},
label: {
show: true,
position: "insideTop",
formatter: function(e) {
return [
'{x|x} {a|牛奶牛奶200ml 23:00}',
'{x|x} {a|油条200ml 12:00}',
'{x|x} {a|豆浆100ml 13:00}',
'{x|x} {a|炒粉200k 23:00}',
'{x|x} {a|炒粉200k 23:00}',
'{x|x} {a|炒粉200k 23:00}',
'{x|x} {a|炒粉200k 23:00}',
'{x|x} {a|豆浆100ml 13:00}'
].join('\n')
},
rich: {
a: {
color: "#333",
lineHeight: 29,
verticalAlign: "top",
},
x: {
lineHeight: 29,
verticalAlign: "top",
width: 10,
height: 10,
backgroundColor: '#4D9AFE', // 4D9AFE
borderRadius: 5
}
}
},
markLine: {
silent: true,
symbol: "diamond",
symbolSize: 5,
label: {
color: "#333",
formatter: function(e) {
return "";
}
},
lineStyle: {
normal: {
color: "#ccc",
type: 'solid'
}
},
data: [{
"xAxis": 1569945600000
}, {
"xAxis": 1569960000000
}, {
"xAxis": 1569974400000
}, {
"xAxis": 1569988800000
}, {
"xAxis": 1570003200000
}, {
"xAxis": 1570017600000
}, {
"xAxis": 1570032000000
}, {
"xAxis": 1570046400000
}, {
"xAxis": 1570060800000
}, {
"xAxis": 1570075200000
}, {
"xAxis": 1570089600000
}, {
"xAxis": 1570104000000
}, {
"xAxis": 1570118400000
}, {
"xAxis": 1570132800000
}, {
"xAxis": 1570147200000
}, {
"xAxis": 1570161600000
}, {
"xAxis": 1570176000000
}, {
"xAxis": 1570190400000
}, {
"xAxis": 1570204800000
}, {
"xAxis": 1570219200000
}, {
"xAxis": 1570233600000
}, {
"xAxis": 1570248000000
}, {
"xAxis": 1570262400000
}, {
"xAxis": 1570276800000
}, {
"xAxis": 1570291200000
}, {
"xAxis": 1570305600000
}, {
"xAxis": 1570320000000
}, {
"xAxis": 1570334400000
}, {
"xAxis": 1570348800000
}, {
"xAxis": 1570363200000
}, {
"xAxis": 1570377600000
}, {
"xAxis": 1570392000000
}, {
"xAxis": 1570406400000
}, {
"xAxis": 1570420800000
}, {
"xAxis": 1570435200000
}, {
"xAxis": 1570449600000
}, {
"xAxis": 1570464000000
}, {
"xAxis": 1570478400000
}, {
"xAxis": 1570492800000
}, {
"xAxis": 1570507200000
}, {
"xAxis": 1570521600000
}, {
"xAxis": 1570536000000
}]
},
data: [
[1569952800000, 10],
[1569967200000, 10],
[1569981600000, 10],
[1569996000000, 10],
[1570010400000, 10],
[1570024800000, 10],
[1570039200000, 10],
[1570053600000, 10],
[1570068000000, 10],
[1570082400000, 10],
[1570096800000, 10],
[1570111200000, 10],
[1570125600000, 10],
[1570140000000, 10],
[1570154400000, 10],
[1570168800000, 10],
[1570183200000, 10],
[1570197600000, 10],
[1570212000000, 10],
[1570226400000, 10],
[1570240800000, 10],
[1570255200000, 10],
[1570269600000, 10],
[1570284000000, 10],
[1570298400000, 10],
[1570312800000, 10],
[1570327200000, 10],
[1570341600000, 10],
[1570356000000, 10],
[1570370400000, 10],
[1570384800000, 10],
[1570399200000, 10],
[1570413600000, 10],
[1570428000000, 10],
[1570442400000, 10],
[1570456800000, 10],
[1570471200000, 10],
[1570485600000, 10],
[1570500000000, 10],
[1570514400000, 10],
[1570528800000, 10],
[1570543200000, 10]
]
}
]
};