tooltip数据颜色会随数据变化而变色。
配置项如下
option = {
数据节点1: 30,
数据节点2: 80,
backgroundColor: "#0a1216",
color: ['rgba(218, 52, 110,', 'rgba(255, 234, 56,', 'rgba(63, 212, 255,'],
dataset: {
"source": [
["product", "data1", "data2", "data3"],
["休闲", "57", "56", "86"],
["运动", "23", "57", "77"],
["商务", "68", "42", "88", ],
["户外", "50", "57", "75"],
["童装", "42", "23", "81"],
]
},
tooltip: {
trigger: "axis",
axisPointer: {
type: 'line', //默认为line,line直线,cross十字准星,shadow阴影
crossStyle: {
color: '#fff'
}
},
borderWidth: 1,
borderColor: "rgba(63, 212, 255, 1)",
backgroundColor: "#16244b",
formatter: function formatter(params) {
var colorList1 = "#fff";
let num1 = option.数据节点1
let num2 = option.数据节点2
if (params[0].data[3] < num1) {
colorList1 = "#da346e"
}
if (params[0].data[3] >= num1 && params[0].data[3] <= num2) {
colorList1 = "#ffea38"
}
if (params[0].data[3] > num2) {
colorList1 = "#3fd4ff"
}
let html = params[0].name + "<br/>";
html += "<span>目标:" + params[0].value[1].toLocaleString() + "%</span><br/><span style=color:#3fd4ff>实际:" + params[0].value[2].toLocaleString() + "%</span><br/><span style=color:" + colorList1 + ">完成率:" + params[0].value[3].toLocaleString() + "%</span>";
return html;
},
textStyle: {
rich: {
word1: {
color: "#fff",
fontSize: 16,
padding: [0, 50]
},
word2: {
color: function(params) {
let color = option.color[0] + "1)"
},
fontSize: 30,
fontFamily: "DIN"
},
word3: {
color: function(params) {
let color = option.color[1] + "1)"
},
fontSize: 30,
fontFamily: "DIN"
},
word4: {
color: function(params) {
let color = option.color[2] + "1)"
},
fontSize: 30,
fontFamily: "DIN"
}
}
},
extraCssText: "z-index:96"
},
xAxis: {
type: "category",
position: "top",
show: false,
axisTick: {
show: false
},
axisLine: {
show: false
},
splitLine: {
show: false
},
axisLabel: {
color: "#fff",
interval: "0",
formatter: function(params) {
return "{kuang|" + params + "}"
},
rich: {
"kuang": {
color: "#fff",
align: "center",
verticalAlign: "middle",
width: "15",
height: "30",
backgroundColor: {
image: ""
}
}
},
}
},
yAxis: {
type: "value",
axisTick: {
show: false
},
axisLine: {
show: false
},
splitLine: {
show: false
},
axisLabel: {
show: false
}
},
series: [{
type: "bar",
barWidth: "3%",
showBackground: true,
backgroundStyle: {
color: "rgba(14, 248, 254,.01)",
borderColor: "rgba(14, 248, 254,.05)",
borderWidth: 30,
},
itemStyle: {
color: function(params) {
//console.log(params)
var colorList = []
let num1 = option.数据节点1
let num2 = option.数据节点2
let odd = params.dataIndex % 2;
if (odd == 0) {
colorList[params.dataIndex] = option.color[2] + ".4)"
} else {
colorList[params.dataIndex] = option.color[0] + ".4)"
}
// if (params.data[1] < num1) {
// colorList[params.dataIndex] = option.color[0] + ".4)"
// }
// if (params.data[1] >= num1 && params.data[1] < num2) {
// colorList[params.dataIndex] = option.color[1] + ".4)"
// }
// if (params.data[1] >= num2) {
// colorList[params.dataIndex] = option.color[2] + ".4)"
// }
return colorList[params.dataIndex];
},
},
label: {
show: true,
distance: 20,
position: "bottom",
formatter: function(params) {
return "{kuang|" + params.data[0] + "}"
},
rich: {
"kuang": {
width: "4",
height: "30",
fontSize: 10,
color: "#fff",
align: "center",
verticalAlign: "middle",
backgroundColor: {
image: ""
}
}
},
},
"encode": {
"y": "data1"
}
},
{
type: "pictorialBar",
symbol: "path://M341.3,682.7C152.8,682.7,0,529.8,0,341.3C0,152.8,152.8,0,341.3,0c188.5,0,341.3,152.8,341.3,341.3 C682.7,529.8,529.8,682.7,341.3,682.7L341.3,682.7z M341.3,51.2c-160.2,0-290.1,129.9-290.1,290.1c0,160.2,129.9,290.1,290.1,290.1 c160.2,0,290.1-129.9,290.1-290.1C631.5,181.1,501.6,51.2,341.3,51.2L341.3,51.2z M341.3,496.3c-85.6,0-155-69.4-155-155 c0-85.6,69.4-155,155-155c85.6,0,155,69.4,155,155c0,41.1-16.3,80.5-45.4,109.6C421.9,480,382.4,496.3,341.3,496.3L341.3,496.3z M341.3,496.3",
symbolSize: ["20", "20"],
symbolPosition: "end",
symbolOffset: [0, -10],
itemStyle: {
color: function(params) {
var colorList = []
let num1 = option.数据节点1
let num2 = option.数据节点2
let odd = params.dataIndex % 2;
if (odd == 0) {
colorList[params.dataIndex] = option.color[2] + "1)"
} else {
colorList[params.dataIndex] = option.color[0] + "1)"
}
// if (params.data[1] < num1) {
// colorList[params.dataIndex] = option.color[0] + "1)"
// }
// if (params.data[1] >= num1 && params.data[1] < num2) {
// colorList[params.dataIndex] = option.color[1] + "1)"
// }
// if (params.data[1] >= num2) {
// colorList[params.dataIndex] = option.color[2] + "1)"
// }
return colorList[params.dataIndex];
},
},
label: {
show: false,
position: "top",
formatter: function(params) {
return params.data[1] + "%"
},
fontFamily: "DIN",
fontSize: 15
}
},
{
name: "达成率",
type: "line",
"encode": {
"y": "data3"
},
smooth: false,
showAllSymbol: true,
// symbol: 'image://./static/images/guang-circle.png',
symbol: 'circle',
symbolSize: 10,
itemStyle: {
color: 'rgba(63, 212, 255,1)',
},
lineStyle: {
show: true,
normal: {
color: 'rgba(63, 212, 255,0.4)',
width: 3,
}
}
}
]
};