echarts实现地图

<template>
    <div class="mapchart">
        <div ref="countEchart1" style="height: 100%;"></div>
    </div>
  </template>
  
  <script setup name="SituationTracking">
  import * as echarts from 'echarts';
  import geoJson from './中华人民共和国.json';
  const countEchart1 = ref(null);
  let myChart;
  import { onMounted,onUnmounted } from 'vue';
    import { ref } from 'vue';
  var imgGreen="image://"
  var img2 = 'image://';
    var mapName = 'china';
    var data = [
        { name: '北京', value: 5 },
        { name: '天津', value: 14 },
        { name: '河北', value: 157 },
        { name: '山西', value: 110 },
        { name: '内蒙古', value: 40 },
        { name: '辽宁', value: 40 },
        { name: '吉林', value: 40 },
        { name: '黑龙江', value: 60 },
        { name: '上海', value: 10 },
        { name: '江苏', value: 60 },
        { name: '浙江', value: 50 },
        { name: '安徽', value: 151 },
        { name: '福建', value: 60 },
        { name: '江西', value: 74 },
        { name: '山东', value: 200 },
        { name: '河南', value: 100 },
        { name: '湖北', value: 40 },
        { name: '湖南', value: 50 },
        { name: '重庆', value: 40 },
        { name: '四川', value: 120 },
        { name: '贵州', value: 135 },
        { name: '云南', value: 90 },
        { name: '西藏', value: 25 },
        { name: '陕西', value: 100 },
        { name: '甘肃', value: 60 },
        { name: '青海', value: 20 },
        { name: '宁夏', value: 110 },
        { name: '新疆', value: 32 },
        { name: '广东', value: 10 },
        { name: '广西', value: 100 },
        { name: '海南', value: 40 },
    ];
    let yellow=[
        {
            name: '西安',
            value: 5,
        },
        {
            name: '重庆',
            value: 3,
        },
    ]
    let red=[
        {
            name: '贵阳',
            value: 35,
           
        },
    ]
    var toolTipData = [
        
        {
            name: '成都',
            value: 13,
           
        },
        
    ];
    var geoCoordMap = {
        '黑龙江': [127.9688, 45.368],
        '内蒙古': [110.3467, 41.4899],
        "吉林": [125.8154, 44.2584],
        '北京市': [116.4551, 40.2539],
        "辽宁": [123.1238, 42.1216],
        "河北": [114.4995, 38.1006],
        "天津": [117.4219, 39.4189],
        "山西": [112.3352, 37.9413],
        "陕西": [109.1162, 34.2004],
        "甘肃": [103.5901, 36.3043],
        "宁夏": [106.3586, 38.1775],
        "青海": [101.4038, 36.8207],
        "新疆": [87.611053, 43.828171],
        "西藏": [91.117212, 29.646922],
        "四川": [103.9526, 30.7617],
        "重庆": [108.384366, 30.439702],
        "山东": [117.1582, 36.8701],
        "河南": [113.4668, 34.6234],
        "江苏": [118.8062, 31.9208],
        "安徽": [117.29, 32.0581],
        "湖北": [114.3896, 30.6628],
        "浙江": [119.5313, 29.8773],
        "福建": [119.4543, 25.9222],
        "江西": [116.0046, 28.6633],
        "湖南": [113.0823, 28.2568],
        "贵州": [106.6992, 26.7682],
        "云南": [102.9199, 25.4663],
        "广东": [113.12244, 23.009505],
        "广西": [108.479, 23.1152],
        "海南": [110.3893, 19.8516],
        "台湾": [120.702967, 24.123621],
        '上海': [121.4648, 31.2891],
        
        '贵阳':[106.71347,26.578343],
        '成都': [104.065719,30.572269],
        '西安':[108.948024,34.263161]

    };
    /*获取地图数据*/
    // countEchart1.showLoading();
    var mapFeatures = geoJson.features;
    // countEchart1.hideLoading();
    mapFeatures.forEach(function (v) {
        // 地区名称
        var name = v.properties.name;
        // 地区经纬度
        geoCoordMap[name] = v.properties.cp;
    });

    var convertData = function (data) {
        var res = [];
        for (var i = 0; i < data.length; i++) {
            var geoCoord = geoCoordMap[data[i].name];
            if (geoCoord) {
                res.push({
                    name: data[i].name,
                    value: geoCoord.concat(data[i].value),
                });
            }
        }
        return res;
    };
    // 柱状体的主干
    function lineData() {
        return toolTipData.map((item) => {
            return {
                coords: [geoCoordMap[item.name], [geoCoordMap[item.name][0], geoCoordMap[item.name][1] + 1.5]]
            }
        })
    }
// 柱状体的顶部
    function scatterData(data) {
            return data.map((item) => {
                return [geoCoordMap[item.name][0], geoCoordMap[item.name][1] + 2, item]
        })
    }
    let option = {
        backgroundColor: 'rgba(0, 0, 0, 0)',
        // title: {
        //     show: true,
        //     text: "项目分布图",
        //     x: 'center',
        //     top: "10",
        //     textStyle: {
        //         color: "#fff",
        //         fontFamily: "等线",
        //         fontSize: 18,
        //     },
        // },
        legend: {
            data: [{
                name: '风险等级高',
               // 强制设置图形为圆。
               icon: 'rect',
               // 设置文本为红色
               textStyle: {
                  color: '#fff'
               },
               itemStyle:{
                  color:'#E25937',
               
               },
            },
            {
                name: '风险等级中',
               // 强制设置图形为圆。
               icon: 'rect',
               // 设置文本为红色
               textStyle: {
                  color: '#fff'
               },
               itemStyle:{
                  color:'#FFC271',
               
               },
            },{
                name: '风险等级低',
               // 强制设置图形为圆。
               icon: 'rect',
               // 设置文本为红色
               textStyle: {
                  color: '#fff'
               },
               itemStyle:{
                  color:'#71FF9B',
               
               },
            }
            ],
            // top: "4%",
            orient: 'vertical',
            left: '20%',
            top: '75%',
            y: "center",
            itemWidth: 7,
            itemHeight: 7,
            itemGap: 15,
            icon: 'square',
            textStyle: {
               fontSize: 10,
               color: "#FFFFFF",
               padding: [0, 0, 0, 6],
            },
         },
        tooltip: {
            // show:false,
            // trigger: 'none',
            formatter: function (params) {
                // console.log(params);
                if (typeof params.value[2] == 'undefined') {
                    var toolTiphtml = '';
                    for (var i = 0; i < toolTipData.length; i++) {
                        if (params.name == toolTipData[i].name) {
                            toolTiphtml += toolTipData[i].name + ":" + toolTipData[i].value;
                        }
                    }
                    // console.log(toolTiphtml);
                    // console.log(convertData(data))
                    return toolTiphtml;
                    // return 111111
                } else {
                    var toolTiphtml = '';
                    for (var i = 0; i < toolTipData.length; i++) {
                        if (params.name == toolTipData[i].name) {
                            toolTiphtml += toolTipData[i].name + ":" + toolTipData[i].value;
                        }
                    }
                    console.log(toolTiphtml);

                    return toolTiphtml;
                }
            },
            backgroundColor: "pink",
            borderColor: "#333",
            padding: [5, 10],
            textStyle: {
                color: "#333",
                fontSize: "16"
            }
        },
        //坐标系
        geo: [{
            layoutCenter: ['50%', '60%'],//位置
            layoutSize: '180%',//大小
            show: true,
            map: mapName,
            roam: false,
            zoom: 0.75,
            aspectScale: 1,
            label: {
                normal: {
                    show: false,
                    textStyle: {
                        color: '#fff'
                    }
                },
                emphasis: {
                    show: true,
                    textStyle: {
                        color: '#fff'
                    }
                }
            },
            itemStyle: {
                normal: {
                    areaColor: {
                        type: "linear",
                        x: 1200,
                        y: 0,
                        x2: 0,
                        y2: 0,
                        colorStops: [{
                            offset: 0,
                            color: "rgba(3,27,78,0.75)", // 0% 处的颜色
                        }, {
                            offset: 1,
                            color: "rgba(58,149,253,0.75)", // 50% 处的颜色
                        },],
                        global: true, // 缺省为 false
                    },
                    borderColor: "#8fe1f8",
                    borderWidth: 1.5,
                    shadowColor: "#3985de",
                    shadowOffsetY: 10,
                    shadowBlur: 120,
                },
                emphasis: {
                    areaColor: "rgba(0,254,233,0.6)",
                    // borderWidth: 0
                }
            }
        }, {
            type: "map",
            map: mapName,
            zlevel: -1,
            aspectScale: 1,
            zoom: 0.75,
            layoutCenter: ["50%", "61%"],
            layoutSize: "180%",
            roam: false,
            silent: true,
            itemStyle: {
                normal: {
                    borderWidth: 1,
                    // borderColor:"rgba(17, 149, 216,0.6)",
                    borderColor: "rgba(58,149,253,0.8)",
                    shadowColor: "rgba(172, 122, 255,0.5)",
                    shadowOffsetY: 5,
                    shadowBlur: 15,
                    areaColor: "rgba(5,21,35,0.1)",
                },
            },
        }, {
            type: "map",
            map: mapName,
            zlevel: -2,
            aspectScale: 1,
            zoom: 0.75,
            layoutCenter: ["50%", "62%"],
            layoutSize: "180%",
            roam: false,
            silent: true,
            itemStyle: {
                normal: {
                    borderWidth: 1,
                    // borderColor: "rgba(57, 132, 188,0.4)",
                    borderColor: "rgba(58,149,253,0.6)",
                    shadowColor: "rgba(65, 214, 255,1)",
                    shadowOffsetY: 5,
                    shadowBlur: 15,
                    areaColor: "transpercent",
                },
            },
        }, {
            type: "map",
            map: mapName,
            zlevel: -3,
            aspectScale: 1,
            zoom: 0.75,
            layoutCenter: ["50%", "63%"],
            layoutSize: "180%",
            roam: false,
            silent: true,
            itemStyle: {
                normal: {
                    borderWidth: 1,
                    // borderColor: "rgba(11, 43, 97,0.8)",
                    borderColor: "rgba(58,149,253,0.4)",
                    shadowColor: "rgba(58,149,253,1)",
                    shadowOffsetY: 15,
                    shadowBlur: 10,
                    areaColor: "transpercent",
                },
            },
        }, {
            type: "map",
            map: mapName,
            zlevel: -4,
            aspectScale: 1,
            zoom: 0.75,
            layoutCenter: ["50%", "64%"],
            layoutSize: "180%",
            roam: false,
            silent: true,
            itemStyle: {
                normal: {
                    borderWidth: 5,
                    // borderColor: "rgba(11, 43, 97,0.8)",
                    borderColor: "rgba(5,9,57,0.8)",
                    shadowColor: "rgba(29, 111, 165,0.8)",
                    shadowOffsetY: 15,
                    shadowBlur: 10,
                    areaColor: "rgba(5,21,35,0.1)",
                },
            },
        },],
        series: [
            {
                type: 'map',
                map: mapName,
                geoIndex: 0,
                aspectScale: 1, //长宽比
                zoom: 0.65,
                showLegendSymbol: true,
                roam: true,
                label: {
                    normal: {
                        show: true,
                        textStyle: {
                            color: "#fff",
                            fontSize: "120%"
                        },
                    },
                    emphasis: {
                        // show: false,
                    },
                },
                itemStyle: {
                    normal: {
                        areaColor: {
                            type: "linear",
                            x: 1200,
                            y: 0,
                            x2: 0,
                            y2: 0,
                            colorStops: [{
                                offset: 0,
                                color: "rgba(3,27,78,0.75)", // 0% 处的颜色
                            }, {
                                offset: 1,
                                color: "rgba(58,149,253,0.75)", // 50% 处的颜色
                            },],
                            global: true, // 缺省为 false
                        },
                        borderColor: "#fff",
                        borderWidth: 0.2,
                    },
                },
                layoutCenter: ["50%", "50%"],
                layoutSize: "180%",
                animation: false,
                markPoint: {
                    symbol: "none"
                },
                data: data,
            },
//             {
//                 type: 'scatter',
//                 coordinateSystem: 'geo',
//                 data: [
//                 {
//                     name: '绿色定位',
//                     value: [117.1582, 36.8701],
//                     symbol:""
// ,
//                     symbolSize: [100, 50]
//                 }
//                 ]
//             },
            //柱状体的主干
            // {
            //     type: 'lines',
            //     zlevel: 5,
            //     effect: {
            //         show: false,
            //         symbolSize: 5 // 图标大小
            //     },
            //     lineStyle: {
            //         width: 6, // 尾迹线条宽度
            //         color: 'rgba(249, 105, 13, .6)',
            //         opacity: 1, // 尾迹线条透明度
            //         curveness: 0 // 尾迹线条曲直度
            //     },
            //     label: {
            //         show: 0,
            //         position: 'end',
            //         formatter: '245'
            //     },
            //     silent: true,
            //     data: lineData()
            // },
            // 柱状体的顶部
            {
                name: '风险等级高',
                type: 'scatter',
                coordinateSystem: 'geo',
                geoIndex: 0,
                zlevel: 5,
                label: {
                    normal: {
                        show: false,
                        formatter: function (params) {
                            var name = params.data[2].name
                            var value = params.data[2].value
                            // var text = `{tline|${name}} : {fline|${value}}个`
                            var text = `{tline|${name}} `
                            // var text = `{tline|项目个数} : {fline|${value}}`
                            return text;
                        },
                        color: '#fff',
                        rich: {
                            fline: {
                                // padding: [0, 25],
                                color: '#fff',
                                fontSize: 14,
                                fontWeight: 600
                            },
                            tline: {
                                // padding: [0, 27],
                                color: '#ABF8FF',
                                fontSize: 12,
                            },
                        }
                    },
                    emphasis: {
                        show: true
                    }
                },
                itemStyle: {
                    color: '#00FFF6',
                    opacity: 1
                },
                symbol: 'image://',
                symbolSize: [25, 30],
                symbolOffset: [5,5],
                z: 999,
                data: scatterData(toolTipData),
            },
            {
                name: '风险等级高',
                type: 'scatter',
                coordinateSystem: 'geo',
                geoIndex: 0,
                zlevel: 5,
                label: {
                    normal: {
                        show: true,
                        formatter: function (params) {
                            var name = params.data[2].name
                            var value = params.data[2].value
                            // var text = `{tline|${name}} : {fline|${value}}个`
                            var text = `{tline|${name}} `
                            // var text = `{tline|项目个数} : {fline|${value}}`
                            return text;
                        },
                        color: '#fff',
                        rich: {
                            fline: {
                                // padding: [0, 25],
                                color: '#fff',
                                fontSize: 14,
                                fontWeight: 600
                            },
                            tline: {
                                // padding: [0, 27],
                                color: '#ABF8FF',
                                fontSize: 12,
                            },
                        }
                    },
                    emphasis: {
                        show: true
                    }
                },
                itemStyle: {
                    color: '#00FFF6',
                    opacity: 1
                },
                symbol:img2,
                symbolSize: [45, 23],
                symbolOffset: [-25,10],
                z: 999,
                data: scatterData(toolTipData),
            },
            {
                name: '风险等级中',
                type: 'scatter',
                coordinateSystem: 'geo',
                geoIndex: 0,
                zlevel: 5,
                label: {
                    normal: {
                        show: false,
                        formatter: function (params) {
                            var name = params.data[2].name
                            var value = params.data[2].value
                            // var text = `{tline|${name}} : {fline|${value}}个`
                            var text = `{tline|${name}} `
                            // var text = `{tline|项目个数} : {fline|${value}}`
                            return text;
                        },
                        color: '#fff',
                        rich: {
                            fline: {
                                // padding: [0, 25],
                                color: '#fff',
                                fontSize: 14,
                                fontWeight: 600
                            },
                            tline: {
                                // padding: [0, 27],
                                color: '#ABF8FF',
                                fontSize: 12,
                            },
                        }
                    },
                    emphasis: {
                        show: true
                    }
                },
                itemStyle: {
                    color: '#00FFF6',
                    opacity: 1
                },
                symbol: 'image://',
                symbolSize: [25, 30],
                symbolOffset: [-5,10],
                z: 999,
                data: scatterData(yellow),
            },
            {
                name: '风险等级中',
                type: 'scatter',
                coordinateSystem: 'geo',
                geoIndex: 0,
                zlevel: 5,
                label: {
                    normal: {
                        show: true,
                        formatter: function (params) {
                            var name = params.data[2].name
                            var value = params.data[2].value
                            // var text = `{tline|${name}} : {fline|${value}}个`
                            var text = `{tline|${name}} `
                            // var text = `{tline|项目个数} : {fline|${value}}`
                            return text;
                        },
                        color: '#fff',
                        rich: {
                            fline: {
                                // padding: [0, 25],
                                color: '#fff',
                                fontSize: 14,
                                fontWeight: 600
                            },
                            tline: {
                                // padding: [0, 27],
                                color: '#ABF8FF',
                                fontSize: 12,
                            },
                        }
                    },
                    emphasis: {
                        show: true
                    }
                },
                itemStyle: {
                    color: '#00FFF6',
                    opacity: 1
                },
                symbol:img2,
                symbolSize: [45, 23],
                symbolOffset: [25,10],
                z: 999,
                data: scatterData(yellow),
            },
            {
                name: '风险等级低',
                type: 'scatter',
                coordinateSystem: 'geo',
                geoIndex: 0,
                zlevel: 5,
                label: {
                    normal: {
                        show: false,
                        formatter: function (params) {
                            var name = params.data[2].name
                            var value = params.data[2].value
                            // var text = `{tline|${name}} : {fline|${value}}个`
                            var text = `{tline|${name}} `
                            // var text = `{tline|项目个数} : {fline|${value}}`
                            return text;
                        },
                        color: '#fff',
                        rich: {
                            fline: {
                                // padding: [0, 25],
                                color: '#fff',
                                fontSize: 14,
                                fontWeight: 600
                            },
                            tline: {
                                // padding: [0, 27],
                                color: '#ABF8FF',
                                fontSize: 12,
                            },
                        }
                    },
                    emphasis: {
                        show: true
                    }
                },
                itemStyle: {
                    color: '#00FFF6',
                    opacity: 1
                },

                symbol: 'image://',
                symbolSize: [25, 30],
                symbolOffset: [-10,10],
                z: 999,
                data: scatterData(red),
            },
            {
                name: '风险等级低',
                type: 'scatter',
                coordinateSystem: 'geo',
                geoIndex: 0,
                zlevel: 5,
                label: {
                    normal: {
                        show: true,
                        formatter: function (params) {
                            var name = params.data[2].name
                            var value = params.data[2].value
                            // var text = `{tline|${name}} : {fline|${value}}个`
                            var text = `{tline|${name}} `
                            // var text = `{tline|项目个数} : {fline|${value}}`
                            return text;
                        },
                        color: '#fff',
                        rich: {
                            fline: {
                                // padding: [0, 25],
                                color: '#fff',
                                fontSize: 14,
                                fontWeight: 600
                            },
                            tline: {
                                // padding: [0, 27],
                                color: '#ABF8FF',
                                fontSize: 12,
                            },
                        }
                    },
                    emphasis: {
                        show: true
                    }
                },
                itemStyle: {
                    color: '#00FFF6',
                    opacity: 1
                },
                symbol:img2,
                symbolSize: [45, 23],
                symbolOffset: [25,10],
                z: 999,
                data: scatterData(red),
            },
            // {
            //     name: 'Top 5',
            //     type: 'effectScatter',
            //     coordinateSystem: 'geo',
            //     data: convertData(toolTipData),
            //     showEffectOn: 'render',
            //     itemStyle: {
            //         normal: {
            //             color: '#00FFFF',
            //         }
            //     },
            //     rippleEffect: {
            //         scale: 5,
            //         brushType: 'stroke',
            //     },
            //     label: {
            //         normal: {
            //             formatter: '{b}',
            //             position: 'bottom',
            //             show: false,
            //             color: "#fff",
            //             distance: 10,
            //         },
            //     },
            //     symbol: 'circle',
            //     symbolSize: [20, 10],
            //     itemStyle: {
            //         normal: {
            //             color: '#16ffff',
            //             shadowBlur: 10,
            //             shadowColor: '#16ffff',
            //         },
            //         opacity: 1
            //     },
            //     zlevel: 4,
            // },
        ],
    };
    const initCountEchart = () => {
    const conutEchart1Ins = echarts.init(countEchart1.value);
    echarts.registerMap('china', geoJson);
    conutEchart1Ins.setOption(option);
        // 监听地图点击事件
    conutEchart1Ins.on('click', (params) => {
        console.log('点击的地区:', params.name);
    });
    myChart = conutEchart1Ins;
    };
    onMounted(() => {
        initCountEchart();
        window.addEventListener('resize', handleResize);
        
    });
    onUnmounted(() => {
        window.removeEventListener('resize', handleResize);
        });
    const handleResize = () => {
        if (myChart) {
            myChart.resize();
        }
    };
  </script>
  <style scoped lang="scss">
    .mapchart{
        box-sizing: border-box;
        width: 100%;
        height: 100%;
        background-color: transparent;
    }

</style>
  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值