vue openlayer创建地图弹框overlay

背景:

地图上展示一个overlay,使用的技术框架是vue+openlayer

效果展示:

主要是这个地图弹框:

核心代码:

html 复制代码
<template>
<!-- overlay -->
  <div id="overlay" class="ol-popup" @click="closePop_prediction">
    <div class="pop_titleBox">
      <img alt="" src="../assets/img/port.png">
      <h1>{{ routeState.endPoint }}</h1>
    </div>
    <div class="content_prediction">
      <p>
        <span class="label">船舶名称:</span>
        <span v-if="checkboxState.shipName" class="text">
          {{ checkboxState.shipName.cnName || checkboxState.shipName.names || "--" }}
          /
          {{ checkboxState.shipName.mmsi || "--" }}
        </span>
      </p>
      <p>
        <span class="label">总里程:</span>
        <span class="text">
          {{ state2.show_l_data.totalDistance || "--" }}nm
        </span>
      </p>
      <p>
        <span class="label">已行驶里程/时长:</span>
        <span class="text">
          {{ state2.show_l_data.traveledDistance || "--" }}nm/{{ state2.show_l_data.traveledTime || "--" }}h
        </span>
      </p>
      <p>
        <span class="label">剩余里程/时长:</span>
        <span class="text">
          {{ state2.show_l_data.remainingDistance || "--" }}nm/{{ state2.show_l_data.remainingTime || "--" }}h
        </span>
      </p>
      <p>
        <span class="label">进度百分比:</span>
        <span class="text" style="color: #1FC37F">
          {{ Math.ceil(state2.show_l_data.progress * 100) || "--" }}%
        </span>
      </p>
      <p>
        <span class="label">预抵时间:</span>
        <span class="text">
          {{ state2.show_l_data.eta || "--" }}
        </span>
      </p>
    </div>
  </div>
</template>

核心代码逻辑:

javascript 复制代码
<script setup>
import { nearestPointOnLine } from "@turf/nearest-point-on-line";
import { parse } from 'wellknown';
import * as turf from "@turf/turf";
import Overlay from 'ol/Overlay';
import { fromLonLat, transform, toLonLat } from "ol/proj";

// 3.overlay
const getOverlay = (data) => {
  const map = getMap.mapData.GlobalMap;
  state.overlay = new Overlay({
    element: document.getElementById("overlay"),
    positioning: "bottom-center",
    stopEvent: false,
    offset: [0, -40],
    autoPan: false,
    autoPanAnimation: {
      duration: 0
    }
  });
  map.addOverlay(state.overlay);
  const geoJsonFromWKT_point = parse(data.geom);
  const coordinate = geoJsonFromWKT_point.coordinates;
  const transformCoordinate = transform(coordinate, 'EPSG:4326', 'EPSG:3857');
  state.overlay.setPosition(transformCoordinate);
  // map.on("singleclick", (evt) => {
  //   console.log('ddd', evt.coordinate);
  //   const coordinate = evt.coordinate // 获取坐标
  //   state.overlay.setPosition(coordinate)
  // })
}
</script>

写到这儿功能基本就实现了。。。

相关推荐
踩着两条虫6 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
蓝冰凌8 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛8 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js
sp42a8 小时前
在 NativeScript-Vue 中实现流畅的共享元素转场动画
vue.js·nativescript·app 开发
还是大剑师兰特10 小时前
Vue3 中 computed(计算属性)完整使用指南
前端·javascript·vue.js
孜孜不倦不忘初心10 小时前
Ant Design Vue 表格组件空数据统一处理 踩坑
前端·vue.js·ant design
csdn_aspnet10 小时前
查看 vite 与 vue 版本
javascript·vue.js
于先生吖11 小时前
SpringBoot+Vue 前后端分离短剧漫剧系统开发实战
vue.js·spring boot·后端
毕设源码-赖学姐11 小时前
【开题答辩全过程】以 基于VUE的环保网站设计为例,包含答辩的问题和答案
前端·javascript·vue.js