function setDataTransfer(id) {
var chart = echarts.init(document.getElementById(id));
var items = [{
level: 1,
name: "传感器",
label: 'beijing',
value: [20, 10],
symbol: "",
symbolSize: [30, 30]
},
{
level: 1,
symbol: "",
name: "物联中心",
category: 0,
active: true,
speed: 6,
value: [60, 35],
belong:'传感器',
},
{
level: 1,
symbol: "",
name: "处理器",
category: 0,
active: true,
speed: 6,
value: [20, 35],
belong:'物联中心',
symbolSize: [30, 30]
}
,
{
level: 1,
symbol: "",
name: "GPS",
category: 0,
active: false,
speed: 6,
value: [60, 55],
belong:'处理器',
symbolSize: [15, 15]
},
{
level: 1,
symbol: "",
name: "数据中心",
category: 0,
active: true,
speed: 6,
value: [20, 60],
belong:'GPS',
symbolSize: [30, 30]
},
{
level: 1,
symbol: "",
name: "应用系统",
category: 0,
active: true,
speed: 6,
value: [20, 80],
belong:'数据中心',
symbolSize: [20, 20]
},
{
level: 1,
symbol: "",
name: "app",
category: 0,
active: true,
speed: 6,
value: [70, 80],
belong:'数据中心',
symbolSize: [20, 20]
}
];
var lineColor = [
'#fff',
'#f6fb05',
'#00fcff'
];
var symbolList = [
"image://",
"image://"];
var pointSymbol = [
"image://",
"image://"];
items.forEach(el => {
el.symbol = symbolList[el.level - 1];
});
const curveness = -0.2;
var dataArr = [
[],
[],
[]
]
items.forEach(el => {
if (el.belong) {
items.forEach(element =>{
if(el.belong == element.name){
dataArr[el.level - 1].push([{
coord: element.value,
},
{
coord: el.value
}
])
}
})
}
})
var seriesOne = [{
type: "effectScatter",
layout: "none",
coordinateSystem: "cartesian2d",
symbolSize: [20, 20],
symbolOffset: [0, -10],
z: 3,
circular: {
rotateLabel: true
},
label: {
normal: {
show: true,
position: 'bottom',
formatter: '{b}',
fontSize: 10,
color: "#fff",
textBorderColor: "#2aa4e8",
offset: [0, 20],
}
},
itemStyle: {
normal: {
shadowColor: "none"
}
},
data: items
}, ]
var lineSeries = []
dataArr.forEach((el, index) => {
lineSeries.push({
name: "",
type: "lines",
coordinateSystem: "cartesian2d",
z: 1,
effect: {
show: true,
smooth: false,
trailLength: 0,
symbol: pointSymbol[index],
symbolSize: [5, 10],
period: 1
},
lineStyle: {
width: 2,
color: lineColor[index],
curveness: curveness
},
data: el
})
})
var seriesData = seriesOne.concat(lineSeries)
option = {
backgroundColor:'transparent',
legend: [],
grid: {
top: '0%',
bottom: '15%',
left: '0%',
right: '-20%'
},
xAxis: {
show: false,
type: "value",
max: 100,
min: 0
},
yAxis: {
show: false,
type: "value",
max: 100,
min: 0
},
series: seriesData
};
chart.setOption(option);
}