高德地图海量点

1.先建个js文件

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

const initMap = async (config) => {

return new Promise((resolve, reject) => {

AMapLoader.load({

key: "0650fbe85c708dc3388fe803d0e5d861",

// key: config.key,

version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15

plugins: [],

Loca: {

// 是否加载 Loca, 缺省不加载

version: "2.0.0", // Loca 版本,缺省 1.3.2

},

}).then((AMap) => {

resolve(AMap)

}).catch(err => {

reject(err)

})

})

}

export default initMap

2. vue组件

复制代码
<template>
  <div class="box">
    <div :id="id" class="container" ref="container"></div>
  </div>
</template>

<script>
import initMap from "../../utils/initMap";
export default {
  data() {
    return {
      id: "maps",
      mapsFlag: false,
      markerList: [],
      aMap: null,
      url1: require("../../assets/img/background_img/bg_nav.png"),
      url2: require("../../assets/img/background_img/bg_header.png")
    };
  },
  /* 必传
    id
    center
  */
  props: {
    center: {
      type: Array,
      default: () => []
    },
    mapStyle: {
      type: String,
      // default: "amap://styles/ebfa0ae6f5c3e8c2f7c1b31f3912c232",
      default: "amap://styles/835378d49c95f3bb1522a957afdad78c"
    },
    // 拖拽
    dragEnable: {
      type: Boolean,
      default: false
    },
    // 缩放
    zoomEnable: {
      type: Boolean,
      default: false
    },
    // 双击变大
    doubleClickZoom: {
      type: Boolean,
      default: false
    },
    // ctrl
    keyboardEnable: {
      type: Boolean,
      default: false
    }
  },
  watch: {
    flyingLineObj: {
      handler(newName, oldName) {
        setTimeout(() => {
          this.init();
        }, 1000);
      },
      deep: true
    }
  },
  methods: {
    async init() {
      let that = this;
      initMap()
        .then(AMap => {
          this.aMap = new AMap.Map(this.id, {
            zoom: 5,
            viewMode: "3D",
            pitch: 48,
            center: this.center,
            mapStyle: this.mapStyle,
            dragEnable: this.dragEnable,
            zoomEnable: this.zoomEnable,
            doubleClickZoom: this.doubleClickZoom,
            keyboardEnable: this.keyboardEnable
          });

          // 创建 Loca 实例
          var loca = new Loca.Container({
            map: this.aMap
          });
          // 创建数据源
          let events = [
            {
              type: "Feature",
              properties: {},
              geometry: {
                type: "Point",
                coordinates: [lon, lat]
              }
            },
            {
              type: "Feature",
              properties: {},
              geometry: {
                type: "Point",
                coordinates: [lon, lat]
              }
            },
            {
              type: "Feature",
              properties: {},
              geometry: {
                type: "Point",
                coordinates: [lon, lat]
              }
            }
          ];
          // 图层的数据源
          var dataSource = new Loca.GeoJSONSource({
            data: {
              type: "FeatureCollection",
              features: events
            }
          });
          // 创建圆点图层
          var pointLayer = new Loca.PointLayer({
            zIndex: 10,
            opacity: 1,
            visible: true,
            blend: "lighter"
          });
          // 图层添加数据
          pointLayer.setSource(dataSource);

          // 设置样式
          pointLayer.setStyle({
            radius: 30,
            color: "red",
            borderWidth: 10,
            borderColor: "#fff",
            unit: "px"
          });
          // 添加到地图上
          loca.add(pointLayer);
        })
        .catch(e => {
          console.log(e);
        });
    }
  },
  components: {}
};
</script>

<style scoped>
.box {
  width: 100%;
  height: 1000px;
  border-radius: 12px;
  background: rgb(8, 34, 97);
}
.container {
  width: 100%;
  height: 100%;
  background: rgb(8, 34, 97);
}
::v-deep .amap-logo {
  display: none;
  opacity: 0 !important;
}
::v-deep .amap-copyright {
  opacity: 0;
}
</style>
相关推荐
全栈前端老曹3 分钟前
【前端路由】Vue Router 嵌套路由 - 配置父子级路由、命名视图、动态路径匹配
前端·javascript·vue.js·node.js·ecmascript·vue-router·前端路由
龘龍龙5 分钟前
Python基础(九)
android·开发语言·python
电摇小人8 分钟前
我的“C++之旅”(博客之星主题作文)
java·开发语言
资生算法程序员_畅想家_剑魔9 分钟前
Java常见技术分享-23-多线程安全-总结
java·开发语言
EndingCoder11 分钟前
安装和设置 TypeScript 开发环境
前端·javascript·typescript
ytttr87316 分钟前
MATLAB中CVX凸优化工具箱的使用指南
开发语言·matlab
萧曵 丶26 分钟前
ArrayList 和 HashMap 自动扩容机制详解
java·开发语言·面试
这是程序猿44 分钟前
基于java的ssm框架学生作业管理系统
java·开发语言·spring boot·spring·学生作业管理系统
张雨zy1 小时前
Vue 项目管理数据时,Cookie、Pinia 和 LocalStorage 三种常见的工具的选择
前端·javascript·vue.js
五月君_1 小时前
Nuxt UI v4.3 发布:原生 AI 富文本编辑器来了,Vue 生态又添一员猛将!
前端·javascript·vue.js·人工智能·ui