用echarts绘制的相关地图,热力图层,点,背景等都可修改,demo平台首页地图:


注意事项:
项目中安装的echarts版本必须是4.9.0

"echarts": "^4.9.0",
"echarts-countries-js": "^1.0.5",
"echarts-gl": "^1.1.2",

展示的相关区县官方json文件的获取方法:
打开:

http://datav.aliyun.com/portal/school/atlas/area_selector#&lat=37.549487261960266&lng=118.69568449999997&zoom=9.5

然后输入相关的市的展示,点击其他类型的下载或粘贴即可获取相对应的json

相关完整的组件代码:

<template>
  <!-- 地图 -->
  <div style="width: 100%; position: relative" :style="{ height: height }">
    <div id="main"  :style="{ height: height,width:width }"></div>
  </div>
</template>
<script type="text/ecmascript-6">
    let bdJson;
    export default {
        props:{
            height:{
                type:String,
                default:'550px'
            },
            width:{
                type:String,
                default:'100%'
            },
            MapBtnNum:{
                type:Number,
                default:0
            },
            pointList:{    //相关标记点的数组
                type:Array,
                default:()=>[
                    {
                        name: '业委会一',
                        value: [117.253931,34.870574],
                        datas: 1354,
                        message:'这里展示的相关待定的信息',
                        img : 'image://'
                    },{
                        name: '业委会二',
                        value: [117.697883,34.695889],
                        datas: 1354,
                        message:'这里展示的相关待定的信息',
                        img : 'image://'
                    },{
                        name: '业委会三',
                        value: [117.487563,35.132384],
                        datas: 1354,
                        message:'这里展示的相关待定的信息',
                        img : 'image://'
                    }
                ]
            },
            heatList:{   //热力地图标记展示的数组
                type:Array,
                default:()=>[
                    {
                        name:'点一',
                        coor:[117.463632,35.11275],
                        value:10
                    },{
                        name:'点二',
                        coor:[117.464495,35.108587],
                        value:450
                    },{
                        name:'点三',
                        coor:[117.458566,35.110742],
                        value:110
                    },{
                        name:'点四',
                        coor:[117.457632,35.113784],
                        value:1100
                    },{
                        name:'点五',
                        coor:[117.572337,34.872095],
                        value:1100
                    }
                ]
            },
            mapAbout:{     //map的相关属性的设置
                type:Object,
                default:()=>{
                    return{
                        mapBg:require('../../../assets/indexNormal/mapBg.jpg'),  //地图的覆盖图片
                        mapHoverBg:require('../../../assets/indexNormal/mapBg.jpg'),
                        visualMapMax:100,    //这是热力地图展示的最大值,用来控制颜色的展示
                        inRangeColor:['#D14137','#E7CF1A','#22B536','#047ACF'],   //这是展示的颜色,顺序依次为从大到小
                        geoAspectScale:0.75,   //这里是贴图与背景展示的关系
                        geoLeft:'19%',  //控制贴图的位置'
                        geoLayoutSize:'88%',   //这个控制贴图大小
                        geoSilent: true,  //图形是否不响应和触发鼠标事件,默认为 false,即响应和触发鼠标事件。
                        geoRoam: true,  //是否开启鼠标缩放和平移漫游
                        geoScaleMin:1.1,//滚轮缩放的最小值
                        geoScaleMax:2.2,//滚轮缩放的最大值
                        geoZoom:1.1,  //这是底部背景的大小
                        mapAreaColor: '#0DD3E4',  //这是底下偏移的柱子的颜色
                        mapShadowColor: 'RGBA(13, 211, 228, 0.9)',   //外发光的颜色
                        mapShadowBlur: 20,  //外发光的距离
                        mapShadowOffsetX: 0,
                        mapShadowOffsetY: 0,
                        mapBorderColor: 'rgba(0, 0, 0, 0.7)',   //底下地图描边的颜色
                        mapBorderWidth: 0,      //底下地图描边的大小
                    }
                }
            },
            series:{         //series的相关树形设置
                type:Object,
                default:()=>{
                    return{
                        labelShow:true,   //文字是否展示
                        labelColor:'#ffffff',  //文字展示的颜色
                        labelHoverColor:'#ffffff',   //鼠标滑过文字展示的颜色
                        mapBorderColor: '#2ab8ff',  //这个是各个区域描边的线
                        mapBorderWidth: 1,   //区域描边的大小
                        mapShadowColor: 'rgba(0, 0, 0, 0.5)', //描边的的shadow
                        mapShadowBlur: 0,   //描边的的shadow的发光
                        mapShadowOffsetX: 0,
                        mapShadowOffsetY: 1,
                        mapHoverBorderColor: '#2ab8ff',   //鼠标滑过的描边的颜色
                        mapHoverBorderWidth: 1,   //鼠标滑过的描边的带线啊哦
                        mapHoverShadowColor: 'rgba(0, 255, 255, 0.7)',   //鼠标滑过的阴影的颜色
                        mapHoverShadowBlur: 10,    //鼠标滑过的阴影的发光的大小
                        mapHoverShadowOffsetX: 0,
                        mapHoverShadowOffsetY: 1,
                        zoom:1.06,  //展示在屏幕上合适的大小
                        roam: true,  //是否开启鼠标缩放和平移漫游
                        left:'19%',   //调整展示距离
                        min:1.06,   //最小
                        max:2.2,    //最大
                        symbolSize: [20, 24],   //点的大小
                        symbolOffset: [0, -20],   //点移动的距离
                    }
                }
            },
        },
        data() {
            return {
                indexMap: '',
            }
        },
        created(){
            bdJson = require('../../../assets/json/bd.json')
        },
        methods: {
            initMap() {
                let that = this;
                var myChart = that.$echarts.init(document.getElementById('main'));
                that.indexMap = myChart
                var bd = bdJson;
                var mapname = bd;
                var mapDate = this.pointList
                //这是相关热力地图的数组数据start
                var heatList = this.heatList
                var geoCoordMap = {}
                heatList.map(item => {
                    geoCoordMap[item.name] = item.coor // 根据自己需求可以拼接
                })
                var convertData = function (data) {
                    var res = [];
                    for (var i = 0; i < data.length; i++) {
                        var geoCoord = geoCoordMap[data[i].name];
                        if (geoCoord) {
                            res.push(geoCoord.concat(data[i].value));
                        }
                    }
                    return res;
                };

                //热力图end
                //标注的点的base64的图片
                var domImg = document.createElement('img');
                domImg.style.height = domImg.height = domImg.width = domImg.style.width = '500px';
                domImg.src = that.mapAbout.mapBg

                var domImgHover = document.createElement('img');
                domImgHover.style.height = domImgHover.height = domImgHover.width = domImgHover.style.width = '8px';
                domImgHover.src = that.mapAbout.mapHoverBg
                myChart.showLoading('default', {
                    text: '加载中...',
                    maskColor: 'rgba(0,0,0,0)',
                    textColor: '#fff',
                });

                myChart.on('click', function (e) {
                    mapDate.forEach(item=>{
                        if(e.name == item.name){
                            //这里是点的标注的点击事件,根据实际情况来
                            // that.$emit('showInfo',item)
                        }
                    })
                });
                setTimeout(function () {
                    mapInit();
                }, 1000);
                var mapInit = () => {
                    that.$echarts.registerMap('bd', mapname);
                    that.indexMap.hideLoading();
                    that.indexMap.setOption({
                        //热力地图展示
                        visualMap: {
                            min: 0,
                            max: that.mapAbout.visualMapMax,
                            splitNumber: 4,
                            inRange: {
                                color: that.mapAbout.inRangeColor.reverse()
                            },
                            // textStyle: {
                            //     color: '#fff'
                            // },
                            show:false,
                        },
                        //TODO  geo  展示的点
                        geo: {
                            map: 'bd',
                            aspectScale: that.mapAbout.geoAspectScale,
                            left: that.mapAbout.geoLeft,
                            layoutSize:  that.mapAbout.geoLayoutSize,
                            silent:  that.mapAbout.geoSilent,  //图形是否不响应和触发鼠标事件,默认为 false,即响应和触发鼠标事件。
                            roam:  that.mapAbout.geoRoam,  //是否开启鼠标缩放和平移漫游
                            scaleLimit:{  //滚轮缩放的极限控制
                                min:that.mapAbout.geoScaleMin,
                                max:that.mapAbout.geoScaleMax
                            },
                            z: 0,
                            zoom: that.mapAbout.geoZoom,
                            itemStyle: {
                                areaColor:that.mapAbout.mapAreaColor,  //这是底下偏移的柱子的颜色
                                shadowColor: that.mapAbout.mapShadowColor,   //外发光的颜色
                                shadowBlur: that.mapAbout.mapShadowBlur,  //外发光的距离
                                shadowOffsetX: that.mapAbout.mapShadowOffsetX,
                                shadowOffsetY: that.mapAbout.mapShadowOffsetY,
                                borderColor: that.mapAbout.mapBorderColor,   //底下地图描边的颜色
                                borderWidth: that.mapAbout.mapBorderWidth,      //底下地图描边的大小
                            },
                        },
                        series: [
                            {
                                name:'覆盖图层',
                                type: 'map',
                                label: {
                                    show: that.series.labelShow,
                                    textStyle: {
                                        color: that.series.labelColor,
                                    },
                                    emphasis: {
                                        textStyle: {
                                            color: that.series.labelHoverColor,
                                        },
                                    },
                                },
                                itemStyle: {
                                    borderColor: that.series.mapBorderColor,  //这个是各个区域描边的线
                                    borderWidth: that.series.mapBorderWidth,
                                    areaColor: {
                                        image: domImg,
                                        repeat: 'repeat',
                                    },
                                    shadowColor: that.series.mapShadowColor, //描边的的shadow
                                    shadowBlur: that.series.mapShadowBlur,
                                    shadowOffsetX: that.series.mapShadowOffsetX,
                                    shadowOffsetY: that.series.mapShadowOffsetY,
                                    emphasis: {    //这是鼠标划上的高亮的显示的样式
                                        areaColor: {
                                            image: domImgHover,
                                            repeat: 'repeat',
                                        },
                                        borderColor: that.series.mapHoverBorderColor,
                                        borderWidth: that.series.mapHoverBorderWidth,
                                        shadowColor: that.series.mapHoverShadowColor,
                                        shadowBlur: that.series.mapHoverShadowBlur,
                                        shadowOffsetX: that.series.mapHoverShadowOffsetX,
                                        shadowOffsetY: that.series.mapHoverShadowOffsetY,
                                        label: {
                                            show: false,
                                        },
                                    },
                                },
                                zoom: that.series.zoom,
                                // silent: false,  //图形是否不响应和触发鼠标事件,默认为 false,即响应和触发鼠标事件。
                                roam: that.series.roam,
                                left:that.series.left,
                                scaleLimit:{
                                    min:that.series.min,
                                    max:that.series.max
                                },
                                map: 'bd',
                            },

                            //坐标点
                            {
                                name:'点标注',
                                coordinateSystem: 'geo',
                                itemStyle: {
                                    color: 'rgba(0,0,0,1)',
                                },
                                // symbol: pointImg,
                                symbol: function (value, params) {
                                    return params.data.img;
                                },
                                symbolSize: that.series.symbolSize,
                                symbolOffset: that.series.symbolOffset,
                                z: 9999,
                                data: mapDate,
                                type:'effectScatter',  //动效展示
                                rippleEffect: {
                                    scale: 3,
                                    brushType: 'stroke',
                                },
                            },
                            {
                                name: '热力图层',
                                type: 'heatmap',
                                coordinateSystem: 'geo',
                                data: convertData(that.heatList),
                                z: 3,
                                silent: false,  //图形是否不响应和触发鼠标事件,默认为 false,即响应和触发鼠标事件。
                                roam: false,
                            },
                        ],
                    });
                };
                //两层一起滚动拖拽
                that.indexMap.on('georoam',function(params){
                    var option = that.indexMap.getOption();//获得option对象
                    if(params.zoom!=null&&params.zoom!=undefined){ //捕捉到缩放时
                        option.geo[0].zoom=option.series[0].zoom;//下层geo的缩放等级跟着上层的geo一起改变
                        option.geo[0].center=option.series[0].center;//下层的geo的中心位置随着上层geo一起改变
                    }else{//捕捉到拖曳时
                    if(option.geo[0].center!=null&&option.geo[0].center!=undefined){
                        option.series[0].center = option.geo[0].center
                    }else{
                        option.geo[0].center = option.series[0].center
                    }
                    }
                    that.indexMap.setOption(option);//设置option
                });

            },
        },
        mounted() {
            var that = this
            // 新建一个promise对象
            let newPromise = new Promise((resolve) => {
                resolve()
            })
            //然后异步执行echarts的初始化函数
            newPromise.then(() => {
                that.initMap()
            })

        },
    }
</script>
<style scoped lang="scss">
.indexMapBack{
    width: 70px;
    height: 73px;
    position: absolute;
    top:20px;
    left: 20px;
    cursor: pointer;
}
.centerRight {
  width: 260px;
  height: 200px;
  background: url("../../../assets/indexNormal/mapShow.png") no-repeat;
  background-size: 100% 100%;
  position: absolute;
  top: 0px;
  right: 0px;
  .title {
    font-size: 18px;
    color: #ffffff;
    text-align: center;
    padding-top: 30px;
  }
  .message {
    font-size: 14px;
    color: #ccefff;
    padding: 5px 10px 5px 15px;
    span {
      color: #ffc106;
    }
  }
  .closeRight {
    position: absolute;
    top: -2px;
    right: 7px;
    font-size: 20px;
    color: #ffffff;
    cursor: pointer;
  }
}

</style>
<style>
.anchorBL {
  display: none;
}
</style>
posted @ 2024-01-29 10:51  xuelin  阅读(248)  评论(0编辑  收藏  举报