如何让飞线同时到达某一点

描述:当前是关于Echarts图表中的 示例。
 
            var colors = ['#ff6801', '#42ca83'];
var centerSymbol = 'image://';
var itemSymbol = 'image://';


var point = [];
/*
* 求圆周上等分点的坐标
* ox,oy为圆心坐标
* r为半径
* count为等分个数
*/
function getPoint(r, ox, oy, count) {
    var radians = (Math.PI / 180) * Math.round(360 / count), //弧度
        i = 0;
    for (; i < count; i++) {
        var x = ox + r * Math.sin(radians * i),
            y = oy + r * Math.cos(radians * i);

        point.push({ x: Number(x.toFixed(2)), y: Number(y.toFixed(2)) }); //为保持数据顺时针
    }
}

var targetCoord = [0, 0];
var curveness = 0.1;

//数据中心
var item;
item = {
    name: "数据中心",
    value: targetCoord,
    symbol: centerSymbol,
    symbolSize: 94,
    label: {
        normal: {
            color: '#fff',
            fontSize: '14'
        }
    }
}

var r = 0.5,
    ox = targetCoord[0],
    oy = targetCoord[1];

// lengend
var categories = [{
    name: '发送数据量(条)',
    icon: centerSymbol,
    textStyle: {
        fontSize: '14'
    }
}, {
    name: '接收数据量(条)',
    icon: itemSymbol,
    textStyle: {
        fontSize: '14'
    }
},
{
    name: '交换数据量(条)',
    icon: 'image://',
    textStyle: {
        fontSize: '14'
    }
}]

//原始数据
var orignData;

//获取平台原始数据
function getOrignData() {
    orignData = {
        items: [
            {
                name: "子平台1",
                input: Math.round(Math.random()*1000),
                output: Math.round(Math.random()*1000),
                inputIncrement: true,
                onputIncrement: true,
                speed: '50kb/s'
            },
            {
                name: "子平台2",
                input: 100,
                output: 100,
                inputIncrement: Boolean(Math.round(Math.random())),
                onputIncrement: Boolean(Math.round(Math.random())),
                speed: '50kb/s'
            },
            {
                name: "子平台3",
                input: 100,
                output: 100,
                inputIncrement: Boolean(Math.round(Math.random())),
                onputIncrement: Boolean(Math.round(Math.random())),
                speed: '50kb/s'
            },
            {
                name: "子平台4",
                input: 100,
                output: 100,
                inputIncrement: Boolean(Math.round(Math.random())),
                onputIncrement: Boolean(Math.round(Math.random())),
                speed: '50kb/s'
            },
            {
                name: "子平台5",
                input: 100,
                output: 100,
                inputIncrement: Boolean(Math.round(Math.random())),
                onputIncrement: Boolean(Math.round(Math.random())),
                speed: '50kb/s'
            }, {
                name: "子平台6",
                input: 100,
                output: 100,
                inputIncrement: Boolean(Math.round(Math.random())),
                onputIncrement: Boolean(Math.round(Math.random())),
                speed: '50kb/s'
            }, {
                name: "子平台7",
                input: 100,
                output: 100,
                inputIncrement: Boolean(Math.round(Math.random())),
                onputIncrement: Boolean(Math.round(Math.random())),
                speed: '50kb/s'
            }, {
                name: "子平台8",
                input: 100,
                output: 100,
                inputIncrement: Boolean(Math.round(Math.random())),
                onputIncrement: Boolean(Math.round(Math.random())),
                speed: '50kb/s'
            }]
    }
}


// 初始化各个平台
var items;
var data;
function initItems() {
    items = orignData.items.map(function (el, index) {
        return {
            name: el.name,
            value: [point[index].x, point[index].y],
            symbol: itemSymbol,
            symbolSize: 68,
            input:el.input,
            output:el.output,
            inputIncrement: el.inputIncrement,
            onputIncrement: el.onputIncrement,
            speed: el.speed
        }
    })
    data = items.concat([item]);
}

//关系数据
var links = [];
function initLinks(){
    items.forEach(function (el, index) {
        links.push({
            source: item.name,
            target: el.name,
            speed: el.speed,
            lineStyle: {
                normal: {
                    color: colors[0],
                    curveness: curveness,
                }
            }
        });
        links.push({
            source: el.name,
            target: item.name,
            speed: el.speed,
            lineStyle: {
                normal: {
                    color: colors[1],
                    curveness: curveness,
                }
            }
        });
    })
}

var linesData = [];
//流动数据绘制
function linesUpdate(){
    linesData = [];
    items.forEach(function (el) {
        if (el.inputIncrement && el.onputIncrement) {
            linesData.push({
                lineStyle: {
                    normal: {
                        color: colors[0]
                    }
                },
                coords: [
                    targetCoord,
                    el.value
                ]
            })
            linesData.push({
                lineStyle: {
                    normal: {
                        color: colors[1]
                    }
                },
                coords: [
                    el.value,
                    targetCoord
                ]
            })
        }
        else if (el.inputIncrement && !el.onputIncrement) {
            linesData.push({
                lineStyle: {
                    normal: {
                        color: colors[0]
                    }
                },
                coords: [
                    targetCoord,
                    el.value
                ]
            })
        }
        else if (!el.inputIncrement && el.onputIncrement) {
            linesData.push({
                lineStyle: {
                    normal: {
                        color: colors[1]
                    }
                },
                coords: [
                    el.value,
                    targetCoord
                ]
            })
        }
    })
}





//数据显示框
var scatterData = [];
function initScatter() {
    scatterData = orignData.items.map(function (item, index) {
        var x = point[index].x,
            y = point[index].y;
        return [x, y].concat([item.input, item.output]);
    })
}

//配置项
        var option = {
            legend: [{
                zlevel:1,
                selectedMode: false,
                right: 0,
                bottom: 20,
                itemHeight: 25,
                orient: 'vertical',
                textStyle: {
                    color: '#fff'
                },
                data: categories
            }],
            xAxis: {
                show: false,
                type: 'value'
            },
            yAxis: {
                show: false,
                type: 'value'
            },
            series: [
                {
                    name: 'center',
                    type: 'graph',
                    layout: 'none',
                    zlevel: 3,
                    coordinateSystem: 'cartesian2d',
                    z: 3,
                    edgeLabel: {
                        normal: {
                            show: true,
                            textStyle: {
                                fontSize: 14
                            },
                            formatter: function (params) {
                                let txt = ''
                                if (params.data.speed !== undefined) {
                                    txt = params.data.speed
                                }
                                return txt
                            },
                        }
                    },
                    label: {
                        normal: {
                            position: 'bottom',
                            show: true,
                            textStyle: {
                                color: 'white'
                            }
                        }
                    },
                    data: data,
                    links: links,
                    categories: categories
                },
                {
                    name: 'lines',
                    type: 'lines',
                    coordinateSystem: 'cartesian2d',
                    zlevel: 4,
                    effect: {
                        show: true,
                        smooth:true,
                        delay:100,
                        trailLength: 0.05,
                        symbol: "arrow",
                        period: 0.85,
                        symbolSize: 7,
                        loop:true
                    },
                    lineStyle: {
                        normal: {
                            color: colors[0],
                            width: 2,
                            opacity: 1,
                            curveness: curveness//贝塞尔曲线度
                        }
                    },
                    animation:true,
                    data: linesData
                },
                {
                    name: '数字',
                    type: 'scatter',
                    zlevel: 3,
                    coordinateSystem: 'cartesian2d',
                    symbolSize: [94, 64],
                    symbolOffset: ['50%', '-50%'],
                    label: {
                        normal: {
                            formatter: function (params) {
                                var str = '';
                                str += '{a|' + params.value[2] + '}';
                                str += '{b|\n' + params.value[3] + '}';
                                return str;
                            },
                            rich: {
                                a: {
                                    color: colors[0],
                                    fontFamily: 'myFont',
                                    fontSize: 20
                                },
                                b: {
                                    color: colors[1],
                                    fontFamily: 'myFont',
                                    fontSize: 20
                                }
                            },
                            color: '#fff',//此行代码为了解决labelformater字体描边问题
                            show: true
                        }
                    },
                    hoverAnimation: true,
                    symbol: 'image://',
                    data: scatterData,
                }
            ]
        }

        var timmer = null,
            speed=1000;
            //获取原始数据
            getOrignData();
            //等分圆
            getPoint(r, ox, oy, orignData.items.length);
            //格式化各个平台
            initItems();
            //初始化关系
            initLinks();
             //流动数据绘制
             linesUpdate();
            //数据显示框
            initScatter();
            console.log(linesData);
            option.series[0].data = data;
            option.series[0].links = links;
            option.series[1].data = linesData;
            option.series[2].data = scatterData;
            myChart.setOption(option);
        timmer = setTimeout(function () {
            //获取原始数据
            getOrignData();
            //从新构造点数据
            items = [];
            initItems();
            //流动数据绘制
            linesData=[];
            option.series[1].data = linesData;
            myChart.setOption(option);
            linesUpdate();
            //数据显示框
            initScatter();
            
            option.series[1].data = linesData;
            option.series[2].data = scatterData;

            myChart.setOption(option);
            
            setTimeout(arguments.callee, speed);
        }, speed)