配置项如下
/*
报到状态 isCheckIn
注册状态 isRegistered
缴费状态 isPay
*/
data = {
正常: [
['2019', 'up', '2019-1', {
isCheckIn: 0,
isRegistered: 0,
isPay: 0,
}],
['2019', 'down', '2019-2', {
isCheckIn: 0,
isRegistered: 0,
isPay: 0,
}],
],
异常: [
['2020', 'up', '2020-1', {
isCheckIn: 0,
isRegistered: 1,
isPay: 1,
}],
],
未开始: [
['2020', 'down', '2020-2', {
isCheckIn: 2,
isRegistered: 2,
isPay: 2,
}],
['2021', 'up', '2021-1', {
isCheckIn: 2,
isRegistered: 2,
isPay: 2,
}],
['2021', 'down', '2021-2', {
isCheckIn: 2,
isRegistered: 2,
isPay: 2,
}],
['2022', 'up', '2022-1', {
isCheckIn: 2,
isRegistered: 2,
isPay: 2,
}],
['2022', 'down', '2022-2', {
isCheckIn: 2,
isRegistered: 2,
isPay: 2,
}],
]
}
xdata = [2019, 2020, 2021, 2022]
var markPointData = []
for (var i = 0; i < xdata.length; i++) {
var item = {
name: i,
coord: [i, 'middle']
}
markPointData.push(item)
}
var red = ''
var gray = ''
var green = ''
CheckInList = ['已报到', '未报到', '未开始']
RegisteredList = ['已注册', '未注册', '未开始']
PayList = ['已缴费', '欠费(住宿费未缴纳)', '未开始']
colorArry = [
new echarts.graphic.LinearGradient(1, 0, 0, 0, [{
offset: 0,
color: "#0FB27C"
},
{
offset: 1,
color: "#4BCDA1"
}
]),
new echarts.graphic.LinearGradient(1, 0, 0, 0, [{
offset: 0,
color: "#FF6061"
},
{
offset: 1,
color: "#FF7E7C"
}
]),
'#D8D8D8'
]
let markLineColor = {
type: 'linear',
x: 1,
y: 0,
x2: 0,
y2: 0,
colorStops: [{
offset: 0,
color: 'rgba(32, 200, 144, 0.98)'
}, {
offset: 1,
color: 'rgba(32, 200, 144, 0.11)',
}]
}
let markPointColor = {
type: 'linear',
x: 1,
y: 0,
x2: 0,
y2: 0,
colorStops: [{
offset: 0,
color: 'rgba(32, 200, 144, 0.98)'
}, {
offset: 1,
color: 'rgba(32, 200, 144, 0.11)',
}]
}
option = {
color: colorArry,
tooltip: {
backgroundColor: '#fff',
borderWidth: .5,
borderColor: 'rgba(0, 0, 0, 0.1)',
padding: 10,
formatter: function(parme) {
const {
isCheckIn,
isPay,
isRegistered
} = parme.data[3]
var CheckIn = CheckInList[isCheckIn]
var Pay = PayList[isPay]
var Registered = RegisteredList[isRegistered]
if (isCheckIn === 0) {
CheckIn = '<span style="color:#10AF7A;">' + CheckIn + '</span>'
} else if (isCheckIn === 1) {
CheckIn = '<span style="color:#FF5555;">' + CheckIn + '</span>'
} else {
CheckIn = CheckIn
}
if (isPay === 0) {
Pay = '<span style="color:#10AF7A;">' + Pay + '</span>'
} else if (isPay === 1) {
Pay = '<span style="color:#FF5555;">' + Pay + '</span>'
} else {
Pay = Pay
}
if (isRegistered === 0) {
Registered = '<span style="color:#10AF7A;">' + Registered + '</span>'
} else if (isRegistered === 1) {
Registered = '<span style="color:#FF5555;">' + Registered + '</span>'
} else {
Registered = Registered
}
return '报到状态:' + CheckIn + '</br>' + '注册状态:' + Registered +
'</br>' + '缴费状态:' + Pay
},
textStyle: {
color: '#4E4E4E'
}
},
backgroundColor: '#F4FBFB',
legend: {
data: ['正常', '异常', '未开始'
],
itemWidth: 12,
itemHeight: 12,
icon: 'roundRect',
right: 0,
top: 0,
},
xAxis: {
show: false,
data: xdata
},
yAxis: {
show: false,
inverse: true,
data: ['up', 'middle', 'down'],
},
series: [{
name: '正常',
type: 'scatter',
symbol: 'image://' + green, //'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow'
symbolSize: [85, 30],
label: {
show: true,
position: 'inside',
formatter: function(param) {
return param.data[2];
},
color: '#fff',
fontSize: 16,
fontWeight: 'bold',
verticalAlign: 'middle',
// borderRadius: 4,
// backgroundColor: '#0FB27C',
padding: [10, 12]
},
itemStyle: {
normal: {
color: colorArry[0],
},
emphasis: {
scale: false
}
},
data: data['正常'],
// silent: true,
},
{
name: '异常',
type: 'scatter',
symbol: 'image://' + red, //'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow'
symbolSize: [85, 30],
label: {
show: true,
position: 'inside',
formatter: function(param) {
return param.data[2];
},
color: '#fff',
fontSize: 16,
fontWeight: 'bold',
verticalAlign: 'middle',
// borderRadius: 4,
// backgroundColor: '#FF6061',
// padding: 10
},
itemStyle: {
normal: {
color: colorArry[1],
}
},
data: data['异常'],
// silent: true,
},
{
name: '未开始',
type: 'scatter',
symbol: 'image://' + gray, //'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow'
symbolSize: [85, 30],
label: {
show: true,
position: 'inside',
formatter: function(param) {
return param.data[2];
},
color: '#fff',
fontSize: 16,
fontWeight: 'bold',
verticalAlign: 'middle',
// borderRadius: 4,
// backgroundColor: '#D8D8D8',
// padding: 10
},
itemStyle: {
normal: {
color: colorArry[2],
}
},
data: data['未开始'],
// silent: true,
},
// 模拟中线
{
name: '',
type: 'scatter',
symbol: 'rect', //'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow'
symbolSize: 0,
label: {
show: false,
position: 'inside',
formatter: function(param) {
return param.data[2];
},
fontSize: 16,
fontWeight: 'bold',
verticalAlign: 'middle',
borderRadius: 4,
backgroundColor: '#0FB27C',
padding: 10
},
markPoint: {
data: markPointData,
symbol: "circle",
symbolSize: 10,
itemStyle: {
shadowColor: '#13B881',
shadowBlur: 10,
color: '#13B881'
},
tooltip: {
show: false
}
},
markLine: {
symbol: ['none', 'triangle'],
symbolSize: [10, 10],
label: {
show: false
},
data: [{
type: "average"
}],
lineStyle: {
type: "solid",
width: 4,
color: markLineColor
},
tooltip: {
show: false
}
},
itemStyle: {
normal: {
color: 'rgba(32, 200, 144, 0)',
}
},
data: data['正常'],
},
]
};