// !!!echarts需要是5.0.0.版本以上 // 这个示例使用的是graph的拖拽功能 // 1。data必须是draggable // 2. series的layout必须是'force' // 3. 在渲染完后需要把节点设置成固定 const symbol1 = "image://"; const symbol2= 'image://' // 数据里必须设置draggable var data = [ { name: '1', draggable: true, value: { serviceId:'crux-gateway', type: 0,category:0,url:'/crux-appmodule/api/appmodule' },x:0,y:100, draggable: true,fixed:true,symbol: symbol2 }, { name: '2', draggable: true, value: { serviceId:'crux-gateway1', type: 1,category:1,url:'/crux-appmodule/api/appmodule'},x:100,y:100, category: 1, draggable: true,fixed:true,symbol: symbol1 }, { name: '3', draggable: true, value: { serviceId:'crux-gateway2', type: 1,category:1,url:'/crux-appmodule/api/appmodule/2' }, x:200,y:100,category: 1, draggable: true,fixed:true,symbol: symbol1 }, { name: '4', draggable: true, value: { serviceId:'crux-gateway', type: 0,category:0,url:'/crux-appmodule/api/appmodule' },x:300,y:0, draggable: true,fixed:true,symbol: symbol2 }, { name: '5', draggable: true, value: { serviceId:'crux-gateway1', type: 1,category:1,url:'/crux-appmodule/api/appmodule'},x:300,y:100, category: 1, draggable: true,fixed:true,symbol: symbol1 }, { name: '6', draggable: true, value: { serviceId:'crux-gateway2', type: 1,category:1,url:'/crux-appmodule/api/appmodule/2' },x:300,y:200, category: 1, draggable: true,fixed:true,symbol: symbol1 }, ] const legend = { show: true, itemWidth: 20, itemHeight: 20, data: [ { name: '成功', icon: symbol2 }, { name: '失败', icon: symbol1 }, ] } const series = { type: 'graph', roam:true, nodeScaleRatio:0, layout: 'force', // 如果想要使用graph的拖拽功能,layout必须是force autoCurveness:false, scaleLimit:{ min:0.5, max:3 }, symbolSize: 40, categories: [ { name: "成功" }, { name: "失败" }], label: { show: true, position:[-20,40], align: 'center', textStyle: { fontSize: 12, color: '#fff' }, "borderRadius": [ 0, 0, 5, 5 ], formatter: params => { return `{label${params.value.type}|serviceId:}{value|${params.value.serviceId}}\n{label${params.value.type}|url:}{value|${params.value.url}}` }, rich: { "label0": { "backgroundColor": "#00cc66", "color": "#fff", "width": 60, "height": 30, "padding": [ 0, 5, 0, 10 ], "align":'left' }, "label1": { "backgroundColor": "#ff0000", "color": "#fff", "width": 60, "height": 30, "padding": [ 0, 5, 0, 10 ], "align":'left' }, "value": { "color": "#888", "align": "center", "lineHeight": 17, "height": 30, "borderColor": "#eee", "borderWidth": 1, "padding": [ 0, 5, 0, 5 ] } } }, labelLayout: function(param){ return { moveOverlap:true, hideOverlap:true } }, edgeSymbol: ['none', 'arrow'], edgeSymbolSize: [4, 8], data: data, links: [ { source: 0, target: 1, value: '',}, { source: 1, target: 2, value: '', }, { source: 2, target: 3, value: '', }, { source: 2, target: 4, value: '', }, { source: 2, target: 5, value: '', }, ], lineStyle: { opacity: 0.9, width: 2, color: '#333' } } option = { series, legend } setTimeout(function() { // 源码中在dragend里将node设为了unfixed,变成了浮动 // 因此需要增加一下dragend监听,将node设置成固定 var seriesModel = myChart.getModel().getSeriesByIndex(0) seriesModel.getData().graph.eachNode(node=>{ var el = node.getGraphicEl(); var idx = node.dataIndex; var itemModel = node.getModel(); var draggable = itemModel.get('draggable'); if(draggable){ el.on('dragend', function () { var forceLayout = seriesModel.forceLayout; if (forceLayout) { forceLayout.setFixed(idx); } }); } }) }, 10);