likes
comments
collection
share

Vue2项目使用高德地图

作者站长头像
站长
· 阅读数 53

一、账号准备

1.注册账号

首先,注册开发者账号,成为高德开放平台开发者 console.amap.com/dev/index

2.获取key

登录高德开放平台后,进入左侧边栏应用管理-我的应用,右上角创建新应用,应用名称与应用类型任意填写

Vue2项目使用高德地图

选择添加key后,填写表单,注意key名称的命名规范

Vue2项目使用高德地图

提交成功后,就可以看到我们申请的key了


二、快速上手

1.安装

npm i @amap/amap-jsapi-loader --save

2.创建地图

首先,我们需要在main.js中引入高德地图,

import AMapLoader from "@amap/amap-jsapi-loader";

AMapLoader.load({
  'key': '申请的key值',           
  'version': '2.0',   // 指定要加载的 JSAPI 的版本,缺少时默认为 1.4.15
  'plugins': ['AMap.Scale','AMap.GeoJSON']           // 需要使用的的插件列表,如比例尺'AMap.Scale'等,更多插件请看官方文档
}).then((AMap) => {
  Vue.use(AMap)
})

创建div标签作为地图容器,并设置id,一定要设置宽度和高度

 <div id="container"></div>
 ...
 #container{
	 width: 1600px;
	 height: 700px;
 }

声明map对象,注意:此处声明map对象时,vue2和vue3的用法有区别,不能混合使用,否则会出现较多问题 此处只展示在Vue2中的使用

<script>

//map对象应该在此处采用非响应式的普通对象声明,而不是在data函数中,否则地图会很卡
	var map = {};
	
	export default {
	  data() {
	  //map:{}
	  },
	}
	
</script>

接下来,定义创建地图的函数,并在mounted中调用,地图的更多参数请看官方文档

mounted() {
	this.createMap()
},

methods: {
	createMap(){
		//填入地图容器div的id
		map = new AMap.Map('container', {
			zoom: 13,	//设置地图的缩放级别
			zooms: [8, 20],	//设置地图的缩放级别区间
			center: [113.22, 22.93],	//设置地图中心点坐标
			mapStyle: 'amap://styles/darkblue',		//设置地图的显示样式,更改darkblue为你想要的样式
			features: ['road','point']	//设置地图的底图元素,缺少则显示全部元素,bg区域面、point兴趣点、road道路及道路标注、building建筑物
		});
	}
}

Vue2项目使用高德地图

完成以上步骤,一张简单的地图就做好了

Vue2项目使用高德地图

3.点标记

当我们需要给地图添加一些点标记时,可以使用Marker来实现,数据量在500以内推荐使用

// 创建一个 Marker 实例:
var marker = new AMap.Marker({
	position: [113.0, 23.15],   // 经纬度
	//创建一个自定义图标实例
	icon: new AMap.Icon({
		size: new AMap.Size(27, 30),    // 图标尺寸
		image: '//vdata.amap.com/icons/b18/1/2.png',  // 自定义图像的url
		imageSize: new AMap.Size(27, 30)   // 根据所设置的大小拉伸或压缩图片
	}),
	title: '广东佛山'	//当鼠标悬浮在标记上时,会显示该内容
});

//将点标记添加至地图
map.add(marker)

//将该点标记删除
map.remove(marker)

//删除多个点标记
map.remove(markerList)

Vue2项目使用高德地图

另外,高德地图还提供了圆形标记 CircleMarker、灵活点标记 ElasticMarker、文本标记 Text,其用法都是大同小异

4.海量点标记

当需要给地图添加千级以上甚至万级的点标记时,LabelMarker 是更好的选择,LabelMarker 在万级以上数据也具有较好的性能,配置也更加灵活,另外,还支持避让功能

      var labelMarker = new AMap.LabelMarker({
        name: '标注1',	// 此属性并不会绘制在地图上,只是作为该点的id使用
        position: [113.0, 23.15],
        opacity:0.8,	//标注层透明度
        icon: {
          type: 'image',	// 图标类型,现阶段只支持 image 类型
          image: '//vdata.amap.com/icons/b18/1/2.png',	// 图片 url
          size: [30, 30],	// 图片尺寸
          anchor: 'center',		// 图片相对 position 的锚点,默认为 bottom-center
        },
        text: {
          content: 'labelMarker',	// 要展示的文字内容
          direction: 'right',	// 文字方向,有 icon 时为围绕文字的方向,没有 icon 时,则为相对 position 的位置
          offset: [0, 0],	// 在 direction 基础上的偏移量
          style: {
            fontSize: 12,	// 字体大小
            fillColor: '#22886f',	// 字体颜色
            strokeWidth: 2,	// 描边宽度
          },
        }
      });
	//将点标记添加至地图
	map.add(labelMarker)

Vue2项目使用高德地图

当数据量达到十万以内并需要较好的性能时,可以使用MassMarks ,目前仅适用于html5浏览器,用的比较少

5.简易行政区图

当我们需要基于行政区块的数据可视化、行政区边界展示时,可以通过DistrictLayer插件实现,不过我个人更推荐使用下文的GeoJSON

名称适用范围
AMap.DistrictLayer.World世界全部国家和地区的区域面和边界一并展示,可分别配置各国区域面的颜色,统一配置国界线、海岸线的颜色
AMap.DistrictLayer.Country单独展示某个国家或地区的所有省级行政区域,可配置国界颜色、分别配置各省区域的面填充色和边界颜色;中国支持全部地级市一级的展示,可配置国界颜色、省界线、市界限颜色和省、市区域的面填充色
AMap.DistrictLayer.Province单独展示一个或者组合展示多个中国行政区的区域,支持展示省级、市级、县级。可配置各省、市、县的边界颜色和面填充色
    //绘制广东省区域
    var disProvince = new AMap.DistrictLayer.Province({
        zIndex: 10,
        adcode: ['440000'],//地址码
        depth: 1,
        styles: {
          'fill': 'rgba(255,255,255,0.4)', 	//设置背景颜色
          'province-stroke': 'cornflowerblue',	//边界线颜色
          'city-stroke': 'red',		//当depth>0时,设置市级边界线
        }
      })
      disProvince.setMap(map)

Vue2项目使用高德地图

6. GeoJSON

当需要绘制区域覆盖物群组时,GeoJSON是不错的选择 首先我们可以去阿里云提供的地理小工具中获取GeoJSON,在左侧地图选择需要的区域后,右侧有多种方式可以获取到json

Vue2项目使用高德地图

//创建GeoJson实例
     var geoJson = new AMap.GeoJSON({
        geoJSON: '填入获取的json',   // GeoJSON对象
        getPolygon: function (geojson, lnglats) {
          return new AMap.Polygon({
            path: lnglats,
            strokeColor: 'rgb(255,192,0)',	//设置区域边界线
            fillColor: 'rgb(255,255,255)',	//设置区域背景颜色
            fillOpacity: 0.1,
          });
        }
      });
      map.add(geoJson);

Vue2项目使用高德地图

三、绑定事件

1.点击事件

以上只是地图的展示,实际开发中,对地图进行操作的各种交互事件是必不可少的,事件绑定的方式都一样,以下内容就给大家介绍地图的点击事件

mounted() {
  this.createMap()
},
methods: {
  createMap() {
    //创建地图
    map = new AMap.Map('container', {
      zoom: 13,  
      zooms: [8, 20], 
      center: [113.22, 22.93],
    });
    //当地图创建完后,我们可以为地图添加点击事件,并绑定到一个函数中
    map.on('click', this.getLngLat)
  },
  //当地图被点击时,会执行该函数,返回的参数是点击的地图信息
  getLngLat(data) {
    console.log(data)
  },
}

Vue2项目使用高德地图

2.事件传值

单单给地图添加点击事件并不能满足我们的需求,我们更希望给地图上的自定义标点添加点击事件,并将自定义标点上的值传递给触发的点击事件

    //此时有一条地址数据,需要在地图上生成标记,并且点击该标记要将该地址的id和address传递到触发的方法中
    let city = {id: 1, address: '广东佛山', lnglat: [113.0, 23.15]}
    var marker = new AMap.Marker({
      position: city.lnglat,
      icon: new AMap.Icon({
        size: new AMap.Size(27, 30),
        image: '//vdata.amap.com/icons/b18/1/2.png',
        imageSize: new AMap.Size(27, 30)
      }),
    });
    //此时,我们可以将需要的数据传递到extData中
    marker.setExtData({id: city.id, address: city.address})
    marker.on('click', this.getAddressInfo)
    map.add(marker)
.....
//当我们点击标记时,会返回改标点的地图信息,同时我们也可以获取到自己传入的信息
getAddressInfo(e) {
  console.log(e.target.getExtData())
},

Vue2项目使用高德地图

3.自定义窗体

当我们经过一些标记点时,想要能快速预览一些基础信息,这个时候我们可以用 mouseover事件搭配自定义窗体,在鼠标经过时弹出一些预览信息

//此时有一条地址数据,需要在地图上生成标记,并且在鼠标经过时,需要查看他的address和id
let city = {id: 1, address: '广东佛山', lnglat: [113.0, 23.15]}
let marker = new AMap.Marker({
  position: city.lnglat,
  icon: new AMap.Icon({
    size: new AMap.Size(27, 30),
    image: '//vdata.amap.com/icons/b18/1/2.png',
    imageSize: new AMap.Size(27, 30)
  }),
});
let infoWindow = new AMap.InfoWindow({
  isCustom: true, //使用自定义窗体
  content: ["<div style='background-color: rgb(255,0,0,0.6);color: white;padding: 5px;'>" +
  "id:" + city.id + "<br>" +
  "地址:" + city.address +
  "</div>"],
  offset: new AMap.Pixel(-15, -25),//窗体基于经纬度的偏移量
});
marker.on('mouseover', (e) => {
  infoWindow.open(map, e.lnglat); //后面的参数指的是经纬度,在此显示窗口
});
marker.on('mouseout', () => {
  infoWindow.close();
});
map.add(marker)

Vue2项目使用高德地图

总结

这篇文章主要是展示了一些高德地图api简单且常用的功能,希望能给第一次使用高德地图api的朋友带来一些帮助。

转载自:https://juejin.cn/post/7231070518224912444
评论
请登录