天地图开发实战:Vue结合OpenLayers实现动态点位地图

news2025/1/4 20:49:40

在Web开发中,地图功能是一个常见的需求,尤其是在需要展示地理位置信息的应用程序中。OpenLayers(简称OL)是一个强大的JavaScript库,用于创建交互式地图。本文将介绍如何利用OpenLayers和天地图API,实现一个地图组件,该组件可以渲染点位图标,并允许用户通过点击地图来实时获取和更新点位的经纬度。

效果图

准备工作

在开始之前,确保你已经安装了Node.js和npm,并且已经创建了一个Vue项目。此外,需要安装OpenLayers库:

npm install ol

创建地图组件

1. 父组件集成

在父组件中,我们使用Element UI的<el-dialog>组件作为地图的容器,并动态绑定dialogFormVisible来控制对话框的显示与隐藏。

<!-- 父组件模板 -->
<el-dialog title="修改" :visible.sync="dialogFormVisible" width="1200px" append-to-body>
  <div style="height: 550px; overflow: auto">
    <el-form :model="form" label-position="right" label-width="130px">
      <el-form-item label="经纬度:">
        <div style="margin-bottom: 10px">
          {{ form.longitude }}{{ form.longitude ? ',' : '' }}{{ form.latitude }}
        </div>
        <!-- 条件性渲染地图组件 -->
        <div style="width: 100%; height: 600px" v-if="dialogFormVisible">
          <mapDiv :formData="form"></mapDiv>
        </div>
      </el-form-item>
    </el-form>
  </div>
  <div slot="footer" class="dialog-footer">
    <el-button type="primary" @click="save()">确 定</el-button>
    <el-button @click="dialogFormVisible = false">取 消</el-button>
  </div>
</el-dialog>

import mapDiv from './mapDiv.vue'

components: { mapDiv},

2. 地图组件实现

模板部分

地图组件的模板非常简单,只有一个用于承载地图的div

<!-- mapDiv.vue -->
<template>
  <div id="mapDiv" style="height: 100%; width: 100%"></div>
</template>
脚本部分

导入必要的OpenLayers库和样式,创建地图组件类。在initMap方法中,我们设置地图的视图、图层,并添加点位图标。

<script>
import 'ol/ol.css'
import { Map, View, Feature } from 'ol'
import { defaults as defaultControls } from 'ol/control'
import { Tile, Vector as VectorLayer } from 'ol/layer'
import { XYZ, Vector as VectorSource } from 'ol/source'
import { fromLonLat, toLonLat } from 'ol/proj'
import { Style, Icon } from 'ol/style'
import { Point } from 'ol/geom'
import logoSrc from './mark.png'

export default {
  name: 'MapWithPoint',
  // 定义组件属性,formData接收父组件的传值
  props: {
    formData: {
      type: Object,
      default: {},
    },
  },
  computed: {},
  data() {
    return {
      map: null, // 地图实例
      pointFeature: null, // 点Feature实例
      vectorLayer: null, // 矢量图层实例
      center: [109.50726084078906, 36.587110167350126], // 默认地图中心点坐标
    }
  },
  // 在组件销毁前执行的方法,用于清理资源
  beforeDestroy() {
      // 检查地图实例是否存在,并进行销毁
      // 重置组件状态,确保所有相关变量为null
  },
  // 组件挂载后执行的钩子函数,用于初始化地图
  mounted() {
    this.initMap()
  },
  methods: {
    // 初始化地图的方法
    initMap() {
      // 创建地图视图,设置中心点坐标和缩放级别
        const view = new View({
          center: fromLonLat(this.center), // 地图初始中心点的经纬度坐标
          zoom: 9, // 初始缩放级别
          maxZoom: 18,
          // minZoom: 9,
        })
      // 初始化地图实例,配置地图容器、控件、图层和视图
      // 创建点Feature并定义其图标样式
      // 创建矢量图层,将点Feature添加到其中
      // 将矢量图层添加到地图实例
      // 为地图添加点击事件监听
    },
    // 地图点击事件处理函数
    mouseClick(event) {
      // 处理地图点击事件,获取点击位置的投影坐标和经纬度坐标
      // 更新组件属性 formData 中的经纬度数据
        const latLonCoord = toLonLat(projectedCoord)
        console.log(latLonCoord, '点击的经纬度坐标')
      // 更新点Feature的坐标位置
      // 刷新矢量图层以显示新的点Feature
      // 平滑移动地图视图到点击的位置
    },
  },
}
</script>

这段脚本定义了一个Vue组件,该组件集成了OpenLayers地图,并添加了点击地图更新点位图标和经纬度信息的功能。组件接收一个formData对象作为属性,其中包含点位的经纬度信息。组件挂载后会初始化地图,并在地图上添加一个点位图标。当用户点击地图时,会更新点位图标的位置和formData中的经纬度信息,并且平滑地移动地图视图到点击的位置。

样式

为地图容器添加样式,确保地图能够充满整个容器。

<style>
#mapDiv {
  height: 100%;
  width: 100%;
}
</style>
获取完整代码

由于篇幅限制,以上展示的代码省略了大部分的实现逻辑和数据结构定义。如需获取完整的组件代码,请访问我的个人主页-资源库下载。

总结

通过上述步骤,我们完成了一个基于Vue和OpenLayers的天地图组件,该组件不仅能够展示点位图标,还能通过用户交互实时更新点位的经纬度。这为开发涉及地图交互功能的应用提供了一个实用的示例。在未来的开发工作中,我们可以基于此组件进一步扩展更多功能,例如增加地图标记、绘制路线、实现路径规划等。此外,还可以考虑将组件与更多的后端服务集成,实现数据的实时同步和动态交互。

随着Web技术的发展和GIS领域的不断进步,地图组件的应用场景将越来越广泛。希望本篇博客能够为读者提供有价值的参考和启发,帮助大家在地图应用开发的道路上更进一步。让我们期待在未来的项目中,能够创造出更多创新且实用的地图解决方案。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1820722.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

南卡、漫步者和Oladance开放式耳机哪个强!无广甄选测评!

在当前市场上&#xff0c;因为许多质量不行&#xff0c;音质平平的开放式耳机让消费者的选择陷入了困难。这些品质低下的产品既无法提供优秀的音频享受&#xff0c;长期佩戴还可能对使用者的听力健康造成健康问题。 作为一名经验丰富的音频设备评测专家&#xff0c;我建议在选…

音频提取格式转换,一招教你轻松搞定!

在数字化音频的时代&#xff0c;我们经常面临着需要提取音频片段或将音频文件转换为不同格式的任务。无论是创作音乐、编辑声音效果&#xff0c;还是适应不同设备或平台的需求&#xff0c;音频提取格式转换都是音频处理中不可或缺的一环。在本文中&#xff0c;我们将分享一招教…

【HarmonyOS】遇见的问题汇总

一、当前编辑的页面&#xff0c;预览打不开 1、问题说明 当前编辑的页面&#xff0c;预览打不开&#xff0c;日志提示如下&#xff1a; Route information is not configured for the current page. To avoid possible redirection issues, configure route information for…

VScode ssh远程连接代码开发XHR failed

一、问题描述 在vscode下载插件Remote-SSH远程连接进行代码开发时&#xff0c;提示 XHR failed 无法建立连接。 二、解决方案 1. 离线下载vscode-server 第一步&#xff1a;vscode菜单栏----帮助----关于----提交后面的一串数字字母即为vscode的 commit_id 第二步&#xff…

群辉其它方案远程访问(ZeroTier篇)

目录 1、注册ZeroTier 2、创建网络 3、下载安装客户端 (1)Windows (2)移动端 i.Android i.iOS (a)注册新ID (b)登陆苹果应用商店 iii.群辉NAS 4、客户端加入网络 (a)Windows (b)Android (c)群辉NAS 5、使用 群辉的远程访问,最标准的做法就是使用…

31、shell循环

一、循环 循环&#xff1a;循环是一种重复执行一段代码的结构。只要满足循环的条件&#xff0c;会一直执行这个代码。 循环条件&#xff1a;在一定范围之内&#xff0c;按照指定的次数来执行循环。 循环体&#xff1a;在指定的次数内&#xff0c;执行的命令序列。只要条件满…

建筑垃圾/城市固废倾倒转移乱象:青犀AI智能视频监控方案助力城市环保监管

近日有新闻记者报道&#xff0c;中央生态环境保护督察组在上海、浙江、江西、湖北、湖南、重庆、云南7省市督察发现&#xff0c;一些地方建筑垃圾处置工作存在明显短板&#xff0c;乱堆乱倒问题时有发生&#xff0c;比如&#xff0c;江西湘东区在杨家田地块违规设置弃土场&…

看完“土猪拱白菜“的张锡峰,我明白计算机有多难了

计算机有多难&#xff1f; 今天无意中&#xff0c;看到一篇关于「"土猪拱白菜"学霸后悔报考浙大计算机」的文章。 或许会有不少和我刚开始一样懵圈的同学&#xff1a;张锡峰是谁&#xff1f;"土猪拱白菜"又是什么梗&#xff1f; 带着疑惑&#xff0c;我打开…

项目实战--文档搜索引擎

在我们的学习过程中&#xff0c;会阅读很多的文档&#xff0c;例如jdk的API文档&#xff0c;但是在这样的大型文档中&#xff0c;如果没有搜索功能&#xff0c;我们是很难找到我们想查阅的内容的&#xff0c;于是我们可以实现一个搜索引擎来帮助我们阅读文档。 1. 实现思路 1…

《C++程序设计》银行管理系统

莫思身外无穷事 且尽生前有限杯 我们先来看一下项目需求&#xff1a; 【场景】 在日常生活中&#xff0c;我们普遍接触到窗口服务系统&#xff0c;如到银行柜台办理业务、景区现场购买门票等。当需要办理业务的顾客数超过窗口数量时&#xff0c;我们需遵循排队等待原则。 【需…

不想搭集群,直接用spark

为了完成布置的作业&#xff0c;需要用到spark的本地模式&#xff0c;根本用不到集群&#xff0c;就不想搭建虚拟机&#xff0c;hadoop集群啥的&#xff0c;很繁琐&#xff0c;最后写作业还用不到集群&#xff08;感觉搭建集群对于我完成作业来说没有什么意义&#xff09;&…

Eclipse创建Spring项目

第一步&#xff1a;先用Eclipse创建一个tomcat项目 打开eclipse 配置tomcat 这里点击add去添加tomcat 创建项目 写好项目名字&#xff0c;点击next 将这个Deploy path修改一下 配置一下项目&#xff0c;将项目部署到tomcat上面去 写个html测试一下 <html><h1>Hel…

公司活动想找媒体报道宣传怎样邀请媒体?

在当今信息爆炸的时代,对于正处于成长阶段的中小企业而言,有效且成本控制得当的宣传策略是推动品牌发展、扩大市场影响力的关键。尤其是在预算有限的情况下,如何让“好钢用在刀刃上”,实现宣传效果的最大化,成为众多企业共同面临的挑战。在此背景下,智慧软文发布系统网站作为一…

会声会影2023软件:安装包下载 丨不限速下载丨亲测好用

会声会影(Corel VideoStudio)为加拿大Corel公司发布的一款功能丰富的视频编辑软件。 会声会影2023简单易用&#xff0c;具有史无前例的强大功能&#xff0c;拖放式标题、转场、覆叠和滤镜&#xff0c;色彩分级、动态分屏视频和新增强的遮罩创建器&#xff0c;超越基本编辑&…

VR虚拟仿真技术模拟还原给水厂内外部结构

在厂区的外围&#xff0c;我们采用VR全景拍摄加3D开发建模的方式&#xff0c;还原了每一处细节&#xff0c;让你仿佛置身于现场&#xff0c;感受那份宁静与庄重。 当你踏入厂区&#xff0c;我们为你精心策划了一条游览路线&#xff0c;从门口到各个重要场景&#xff0c;一一为…

使用ecal protobuf的时候编译过程中报ArenaString、FileDescriptor等无法解析的外部符号错误

c cmake构建的项目在使用ecal和protobuf的时候编译过程报ArenaString、FileDescriptor等无法解析的外部符号错误 查找了很多官网和github上很多资料都没有提及相关的内容。 在windows编译protobuf后&#xff0c;cmake连接找不到符号 - 简书 上提及要使用config模式 设置了co…

TK防关联引流系统:全球多账号运营,一“键”掌控!

在TikTok的生态系统中&#xff0c;高效管理多个账号对于品牌推广的成功起着决定性的作用。TK防关联引流系统&#xff0c;作为一款专门为TikTok用户打造的强大工具&#xff0c;为全球范围内的多账号运营提供了坚实的支持。 TK防关联引流系统的核心优势体现在以下几个方面&#x…

vue 生命周期 钩子函数 keep-alive activated deactivated

一、activated deactivated 在被keep-alive包含的组件/路由中&#xff0c;会多出两个生命周期的钩子:activated 与 deactivated。在 2.2.0 及其更高版本中&#xff0c;activated 和 deactivated 将会在树内的所有嵌套组件中触发。activated在组件第一次渲染时会被调用&#x…

Linux2-系统自有服务防火墙与计划任务

一、什么是防火墙 防火墙主要用于防范网络攻击&#xff0c;防火墙一般分为软件防火墙、硬件防火墙 1、Windows中的防护墙设置 2、防火墙的作用 3、Linux中的防火墙分类 Centos6、Centos6>防火墙>iptables防火墙 防火墙系统管理工具 Centos7>防火墙>firewalld防火…

SECS/GEM 底层协议解析

SECS是什么&#xff1f; SEMI电子半导体联盟,为实现设备与工厂系统的快速对接数据,状态,配方,程序的标准化协议,SECS具有多个版本,本文主要介绍E5协议 HSMS通信方式,设备端的处理流程(Passive模式)。 SECS关键字 Host 主机一般指向工厂控制系统EQP 单机设备Active 在Tcp通信…