气泡

描述:当前是关于Echarts图表中的 散点图 示例。
 
            //数据
var data = [{
        "name": "IT人员",
        "value": 300
    },
    {
        "name": "医务人员",
        "value": 106
    },
    {
        "name": "教师工作人员",
        "value": 210
    },
    {
        "name": "精神病障碍患者",
        "value": 320
    },
    {
        "name": "快递人员",
        "value": 490
    },
    {
        "name": "银行人员",
        "value": 150
    },

    {
        "name": "犀利的危险人员",
        "value": 302
    }
];
//图片
var img = "";
//控制每行字符个数

var xData = [],
    yData = [],
    Datas = [];
data.map(function(a, b) {
    xData.push(a.name);
    yData.push(a.value);
    Datas.push([a.name, a.value])
    // if (a.value === 0) {
    //     yData.push(a.value + min);
    // } else {
    //     yData.push(a.value);
    // }
    // yData.push((Math.random(0,1) * 100).toFixed(0));
});
//找出最大值,判断缩放比
let max = 0;
let len = data.length;
let scale = 1;
for (let i = 0; i < len; i++) {
    if (data[i].value > max) {
        max = data[i].value;
    }
}
if (max > 0 && max < 100) {
    scale = 0.2;
} else if (max > 100 && max < 500) {
    scale = 0.3;
} else if (max > 500 && max < 1000) {
    scale = 0.5;
} else if (max > 1000 && max < 5000) {
    scale = 2;
} else if (max > 5000) {
    scale = 5;
}
var option = {
    tooltip: {},
    backgroundColor: '#0e2147',
    grid: {
        left: '8%',
        bottom: '26%',
        top: '20%',
        width: '89%'
    },
    xAxis: {
        type: 'category',
        data: xData,
        splitLine: {
            show: false
        }, //去除网格线
        axisTick: {
            alignWithLabel: true
        },
        axisLine: {
            lineStyle: {
                color: '#4073b2',
                width: 2,
            }
        },
        axisLabel: {
            interval: 0,
            textStyle: {
                fontSize: 14,
                color: '#fff',
            },
            formatter: function(value) {
                var ret = ""; //拼接加\n返回的类目项
                var maxLength = 3; //每项显示文字个数
                var valLength = value.length; //X轴类目项的文字个数
                var rowN = Math.ceil(valLength / maxLength); //类目项需要换行的行数
                if (rowN > 1) //如果类目项的文字大于3,
                {
                    for (var i = 0; i < rowN; i++) {
                        var temp = ""; //每次截取的字符串
                        var start = i * maxLength; //开始截取的位置
                        var end = start + maxLength; //结束截取的位置
                        //这里也可以加一个是否是最后一行的判断,但是不加也没有影响,那就不加吧
                        temp = value.substring(start, end) + "\n";
                        ret += temp; //凭借最终的字符串
                    }
                    return ret;
                } else {
                    return value;
                }
            }
        }
    },
    yAxis: {
        type: 'value',
        name: '人数',
        nameTextStyle: {
            color: "#fff",
            fontSize: 14,
            margin: 2,
        },
        splitLine: {
            show: false
        }, //去除网格线
        axisLine: {
            lineStyle: {
                color: '#4073b2',
                width: 2,
            }
        },
        axisLabel: {
            formatter: '{value}',
            textStyle: {
                fontSize: 12,
                color: '#fff'
            }
        }
    },
    series: [{
        name: '',
        type: 'scatter',
        data: Datas,
        symbol: `image://${img}`,
        symbolSize: function(data) {
            // console.log('sadf1211221',data[1]);
            if (data[1] < 5) {
                return Math.sqrt(data[1]) / 0.17;
            }
            return Math.sqrt(data[1]) / scale;
        },
        animationDurationUpdate: 8000,
        animationEasingUpdate: 8000,
        animationDelay: function(idx) {
            // 越往后的数据延迟越大
            return idx * 400;
        },
        label: {
            normal: {
                show: true,
                position: 'top',
                // distance: 16,
                formatter: function(params) {
                    return params.value[1]
                },
                color: '#fff',
                fontSize: 14
            }

        }
    }]
};