vue 实现地图创建(高德地图)

在vue 项目中,通过代码实现地图的创建

首先引入js文件

import {
    initMap
  } from '../../../../utils/map.js'

map.js文件如下:

/* 引入下载的插件 */
import AMapLoader from "@amap/amap-jsapi-loader";
//抛出initMap初始化方法
export const initMap = () =>
  AMapLoader.load({
    key: "**********", // 申请好的Web端开发者Key,
    /* 首次调用 load 时必填 */
    version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
    plugins: [
      "AMap.PolygonEditor",
      "AMap.MoveAnimation",
      "AMap.PlaceSearch",
      "AMap.AutoComplete",
      "AMap.Geocoder"
    ],
  });

vue 文件

    <div class="map" id="bassMap"></div>
    handleInitMap() {
      initMap().then(async (Amap) => {
        let map = new Amap.Map("bassMap", {
          //地图容器id与盒子id一致
          viewMode: "3D", //是否为3D地图模式
          zoom: 15, //初始缩放比例
          center: [98.51, 39.75], //中心点位置
        })
        let icon = new Amap.Icon({
          // 图标尺寸
          size: new Amap.Size(33, 50),
          // 图标的取图地址
          image: require('../../../../assets/images/address_mark.png'),
          // 图标所用图片大小
          imageSize: new Amap.Size(33, 50),
        })
        var location = this.qyInfo.eiCoordinate;
        if (location == null) {
          return
        }
        var lnglat = location.split(',');
        map.setCenter(lnglat); //设置地图中心点
        let marker = new Amap.Marker({
          position: lnglat,
          icon: icon,
          offset: new AMap.Pixel(0, 0) //设置偏移量
        });
        map.add(marker);
      })
    }
  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Vue项目中创建高德地图热力图,可以按照以下步骤进行: 1. 引入高德地图API 在 `index.html` 文件中引入高德地图API: ```html <script src="https://webapi.amap.com/maps?v=1.4.15&key=您申请的key值"></script> ``` 2. 创建地图Vue 组件中创建地图容器和地图对象: ```html <template> <div id="map-container"></div> </template> <script> export default { mounted() { this.map = new AMap.Map('map-container', { zoom: 10, center: [116.397428, 39.90923] }); } } </script> ``` 3. 加载热力图插件 在 `mounted` 钩子函数中加载热力图插件: ```javascript mounted() { // 创建地图对象 this.map = new AMap.Map('map-container', { zoom: 10, center: [116.397428, 39.90923] }); // 加载热力图插件 AMap.plugin(['AMap.Heatmap'], () => { // 创建热力图对象 this.heatmap = new AMap.Heatmap(this.map, { radius: 25, // 半径 opacity: [0, 0.8], // 透明度 gradient: { 0.5: 'blue', 0.65: 'rgb(117,211,248)', 0.7: 'rgb(0, 255, 0)', 0.9: '#ffea00', 1.0: 'red' } // 渐变色 }); }); } ``` 4. 准备热力图数据 在组件中定义一个数组,用于存储热力图的数据: ```javascript data() { return { heatmapData: [ {lng: 116.191031, lat: 39.988585, count: 10}, {lng: 116.389275, lat: 39.925818, count: 20}, {lng: 116.287444, lat: 39.810742, count: 30}, {lng: 116.481707, lat: 39.940089, count: 40}, {lng: 116.410588, lat: 39.880172, count: 50} ] } } ``` 其中,`lng` 和 `lat` 表示经纬度,`count` 表示热力值。 5. 绑定数据到热力图 在 `mounted` 钩子函数中,将数据绑定到热力图对象: ```javascript this.heatmap.setDataSet({ data: this.heatmapData, max: 100 // 最大值,用于计算渐变色 }); ``` 6. 完整代码 ```html <template> <div id="map-container"></div> </template> <script> export default { data() { return { heatmapData: [ {lng: 116.191031, lat: 39.988585, count: 10}, {lng: 116.389275, lat: 39.925818, count: 20}, {lng: 116.287444, lat: 39.810742, count: 30}, {lng: 116.481707, lat: 39.940089, count: 40}, {lng: 116.410588, lat: 39.880172, count: 50} ] } }, mounted() { // 创建地图对象 this.map = new AMap.Map('map-container', { zoom: 10, center: [116.397428, 39.90923] }); // 加载热力图插件 AMap.plugin(['AMap.Heatmap'], () => { // 创建热力图对象 this.heatmap = new AMap.Heatmap(this.map, { radius: 25, // 半径 opacity: [0, 0.8], // 透明度 gradient: { 0.5: 'blue', 0.65: 'rgb(117,211,248)', 0.7: 'rgb(0, 255, 0)', 0.9: '#ffea00', 1.0: 'red' } // 渐变色 }); // 绑定数据到热力图 this.heatmap.setDataSet({ data: this.heatmapData, max: 100 // 最大值,用于计算渐变色 }); }); } } </script> <style> #map-container { width: 100%; height: 300px; } </style> ``` 以上就是在Vue项目中创建高德地图热力图的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值