首页 > 其他分享 >用echarts绘制的相关地图,热力图层,点,背景等都可修改

用echarts绘制的相关地图,热力图层,点,背景等都可修改

时间:2024-12-26 15:30:44浏览次数:7  
标签:鼠标 series 力图 echarts option var 绘制 mapAbout name

实际项目中用echarts绘制的相关地图,热力图层,点,背景等都可修改,点位可点击。

注意事项:

项目中安装的echarts版本必须是4.9.0的,

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

效果如下图所示:

相关完整的组件代码:

<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>

 

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

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

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

 

标签:鼠标,series,力图,echarts,option,var,绘制,mapAbout,name
From: https://www.cnblogs.com/menxiaojin/p/18632982

相关文章

  • 使用 OpenCV 绘制线条和矩形
    OpenCV是一个功能强大的计算机视觉库,它不仅提供了丰富的图像处理功能,还支持图像的绘制。绘制简单的几何图形(如线条和矩形)是OpenCV中常见的操作。在本篇文章中,我们将介绍如何使用OpenCV在图像上绘制线条和矩形。绘制线条在OpenCV中,可以使用cv2.line()函数来绘制直线......
  • HTML画布canvas绘制图形,解决拖影问题
     在使用HTMl画面canvas绘制矩形,圆等图形时,总是出现拖影。解决这个问题有很多中方法:方法一:鼠标移动过程中中不画上去,在释放鼠标的时候绘制上去,这样就看不到拖影,但是看不到绘制过程方法二:在鼠标移动的时候,清除上一次绘制的矩形,然后在画,这样就没有拖影了,但是计算起来麻烦,要多......
  • 在线性坐标系中绘制三角函数图象
    本文记述了用Matplotlib在线性坐标系中绘制三角函数图象的例子。代码主体内容如下:...defmain():fig,axs=plt.subplots(1,3,figsize=(14,4.5))#1axs[0]=configure_axes(axs[0],'TrigonometricFunction\t\t\t'+r'$sine$',2*np.pi,1,n......
  • 【安全就业】2024年网络安全技术技能人才职业能力图谱+电子数据取证
    电子数据取证,是指利用科学和法律方法对电子设备中的数据进行搜集、分析、保存和报告的过程,以确保这些信息在法律程序中能够作为线索或证据使用。电子数据取证工作,一般需要取证人员具备电子数据提取、电子数据恢复、数据库系统取证、电子数据治理、程序功能分析、现场勘查、案件支......
  • openlayers 6/7 绘制自定义圆 渐变圆
    openlayers绘制自定义圆渐变圆效果图目录openlayers绘制自定义圆渐变圆效果图简介主要特点使用场景示例js部分定义中心点修改中心点为圆心点创建圆自定义圆样式绘制圆添加圆到图层线上示例简介OpenLayers是一个开源的JavaSc......
  • Python绘制图表
    Python提供了多种可视化库,常用的有matplotlib、seaborn和plotly等。这些库可以用于绘制各种类型的图表,如折线图、散点图、柱状图、饼图等。下面是一个使用matplotlib绘制折线图的示例:```pythonimportmatplotlib.pyplotasplt#准备数据x=[1,2,3,4,5]y=[2,4,6......
  • 使用CSS3+SVG绘制一只哆啦a梦机器猫头像
    创建一个哆啦A梦(Doraemon)的头像使用CSS3和SVG是一个有趣且具有挑战性的任务。由于哆啦A梦的形象相对复杂,完全使用CSS3来绘制可能会相当困难,但我们可以结合SVG来更好地完成这个任务。以下是一个简化的示例,展示如何使用CSS3和SVG来绘制哆啦A梦的头像:HTML结构:<!DOCTYPEhtml><h......
  • 使用CSS3绘制一杯冒热气的咖啡动画
    在前端开发中,使用CSS3来绘制一杯冒热气的咖啡动画是一个有趣且富有挑战性的任务。以下是一个简单的示例,说明如何使用HTML和CSS3来创建这样的动画。首先,我们需要创建HTML结构来表示咖啡杯和热气:<divclass="coffee-cup"><divclass="steam"></div><divclass="steam"></div......
  • 使用CSS3+SVG绘制沿固定路径飞行的纸飞机
    在前端开发中,要使用CSS3和SVG来创建一个沿固定路径飞行的纸飞机效果,我们可以通过几个步骤来实现。请注意,这个例子将使用SVG动画(特别是<animateMotion>元素)来沿预定路径移动纸飞机。步骤1:创建SVG元素和路径首先,在HTML文件中添加一个SVG元素,并定义一个路径,纸飞机将沿着这个路径......
  • 使用HTML5绘制一个发光的灯泡
    在HTML5中,你可以使用<canvas>元素与JavaScript来绘制一个发光的灯泡。下面是一个简单的示例,展示了如何创建一个基础的发光灯泡效果:HTML结构:<!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><metaname="viewport"content="......