echarts geoJson地图自定义图标

echarts yekong

wanjunshijie 2021-04-18 at 06.47.43@2x

drawechartmap() {
                var car1 = "image://";
                var car2 = "image://";
                var car3 = "image://";
                var jingbao = "image://";
                var myChart = echarts.init(document.getElementById("echartmap"));
                var uploadedDataURL = "js/assets/220000.json";
                var center = {
                    "白城市": [122.68664, 45.397315],
                    "松原市": [124.827743, 45.138656],
                    "长春市": [125.341817, 43.812171],
                    "四平市": [124.366544, 43.166735],
                    "吉林市": [126.558221, 43.836284],
                    "辽源市": [125.15531, 42.887925],
                    "通化市": [125.948047, 41.72714],
                    "白山市": [126.476484, 41.926106],
                    "延边朝鲜族自治州": [129.478809, 42.907925],
                }
                // 检查
                let car = [{
                    name: 'car1',
                    value: [128.278809, 43.407925],
                    type: 'car'
                },]; // 检查
                let datacar2 = [{
                    name: 'car1',
                    value: [129.178809, 43.307925],
                    type: 'car'
                },];
                let datacar3 = [{
                    name: 'car1',
                    value: [127.478809, 42.307925],
                    type: 'car'
                },];
                let datajingbao = [{
                    name: 'car1',
                    value: [129.978809, 43.507925],
                    type: 'car'
                },];
                var option = null;
                $.get(uploadedDataURL, function (json) {
                    echarts.registerMap('js', json);
                    option = {
                        visualMap: {
                            show: false,
                            max: 100,
                            seriesIndex: [3],
                            inRange: {
                                color: ['#A5DCF4', '#006edd']
                            }
                        },
                        geo: [{
                            map: 'js',
                            roam: false, //是否允许缩放
                            zoom: 1.1, //默认显示级别
                            scaleLimit: {
                                min: 0,
                                max: 3
                            }, //缩放级别
                            itemStyle: {
                                normal: {
                                    areaColor: '#013C62',
                                    shadowColor: '#013C62',
                                    shadowBlur: 20,
                                    shadowOffsetX: -5,
                                    shadowOffsetY: 15,
                                }
                            },
                            // tooltip: {
                            //     show: false
                            // },
                            tooltip: {  // 指示器
                                trigger: 'item',
                                formatter: function (params) {
                                    if (typeof (params.value)[1] == "undefined") {
                                        return ` ${params.name}  :  ${params.value} 家 `;
                                    } else {
                                        return `
                    ${params.name}  <br/>
                    产品:${params.data.product} <br/>
                    规模:${params.data.scale} 吨
                `;
                                    }
                                }
                            },
                        }],
                        series: [
                            {
                                type: 'effectScatter',
                                coordinateSystem: 'geo',
                                z: 5,
                                data: [],
                                symbolSize: 14,
                                label: {
                                    normal: {
                                        show: true,
                                        formatter: function (params) {
                                            return '{fline|地点:' + params.data.city + '}\n{tline|' + (params.data.info || '发生xx集件') + '}';
                                        },
                                        position: 'top',
                                        backgroundColor: 'rgba(254,174,33,.8)',
                                        padding: [0, 0],
                                        borderRadius: 3,
                                        lineHeight: 32,
                                        color: '#f7fafb',
                                        rich: {
                                            fline: {
                                                padding: [0, 10, 10, 10],
                                                color: '#ffffff'
                                            },
                                            tline: {
                                                padding: [10, 10, 0, 10],
                                                color: '#ffffff'
                                            }
                                        }
                                    },
                                    emphasis: {
                                        show: true
                                    }
                                },
                                itemStyle: {
                                    color: '#feae21',
                                }
                            },
                            {
                                type: 'effectScatter',
                                coordinateSystem: 'geo',
                                z: 5,
                                data: [],
                                symbolSize: 14,
                                label: {
                                    normal: {
                                        show: true,
                                        formatter: function (params) {
                                            return '{fline|地点:' + params.data.city + '}\n{tline|' + (params.data.info || '发生xx集件') + '}';
                                        },
                                        position: 'top',
                                        backgroundColor: 'rgba(233,63,66,.9)',
                                        padding: [0, 0],
                                        borderRadius: 3,
                                        lineHeight: 32,
                                        color: '#ffffff',
                                        rich: {
                                            fline: {
                                                padding: [0, 10, 10, 10],
                                                color: '#ffffff'
                                            },
                                            tline: {
                                                padding: [10, 10, 0, 10],
                                                color: '#ffffff'
                                            }
                                        }
                                    },
                                    emphasis: {
                                        show: true
                                    }
                                },
                                itemStyle: {
                                    color: '#e93f42',
                                }
                            },
                            {
                                type: 'effectScatter',
                                coordinateSystem: 'geo',
                                z: 5,
                                data: [{
                                    name: '白城市',
                                    value: [122.733435, 45.570352, 280],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '松原市',
                                    value: [123.927743, 44.758656, 280],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '长春市',
                                    value: [125.341817, 44.512171, 280],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '四平市',
                                    value: [123.966544, 43.466735, 280],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '吉林市',
                                    value: [126.558221, 43.536284, 280],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '辽源市',
                                    value: [125.15531, 42.787925, 280],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '通化市',
                                    value: [125.648047, 41.92714, 280],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '白山市',
                                    value: [126.976484, 42.026106],
                                    product: '200',
                                    scale: '20',
                                }, {
                                    name: '延边朝鲜族自治州',
                                    value: [127.978809, 43.107925, 280],
                                    product: '200',
                                    scale: '20',
                                },
                                ],
                                symbolSize: 8,
                                itemStyle: {
                                    color: 'rgba(255, 188, 9, 1.00)',
                                }
                            },
                            //地图
                            {
                                type: 'map',
                                mapType: 'js',
                                geoIndex: -1,
                                zoom: 1.1, //默认显示级别
                                label: {
                                    show: true,
                                    color: '#ffffff',
                                    emphasis: {
                                        color: 'white',
                                        show: false
                                    }
                                },
                                itemStyle: {
                                    normal: {
                                        borderColor: '#2980b9',
                                        borderWidth: 1,
                                        areaColor: '#12235c'
                                    },
                                    emphasis: {
                                        areaColor: '#FA8C16',
                                        borderWidth: 0,
                                        color: 'green'
                                    }
                                },
                                data: Object.keys(center).map(name => {
                                    return {
                                        name: name,
                                        value: Math.random() * 100
                                    }
                                })
                            },
                            {
                                name: '检查',
                                type: 'scatter',
                                coordinateSystem: 'geo',
                                data: car,
                                symbol: car1,
                                symbolSize: 15,
                            }, {
                                name: '检查',
                                type: 'scatter',
                                coordinateSystem: 'geo',
                                data: datacar2,
                                symbol: car2,
                                symbolSize: 15,
                            }, {
                                name: '检查',
                                type: 'scatter',
                                coordinateSystem: 'geo',
                                data: datacar3,
                                symbol: car3,
                                symbolSize: 15,
                            }, {
                                name: '检查',
                                type: 'scatter',
                                coordinateSystem: 'geo',
                                data: datajingbao,
                                symbol: jingbao,
                                symbolSize: 30,
                            },
                        ]
                    };
                    myChart.setOption(option);
                });
            },

实例下载

实例下载

喜欢