154.Vue3 + OpenLayers + Turf.js 实现椭圆形绘制功能

🧭 效果演示图

页面加载后,展示地图并提供按钮操作,点击按钮即可在地图上绘制一个椭圆形,并支持清除图层。


🧱 一、项目背景

在 WebGIS 地图可视化场景中,我们经常需要在地图上绘制规则图形(如圆形、椭圆、多边形等),而这些图形往往具备地理意义。

本示例基于:

  • 🌐 OpenLayers:用于地图容器与图层渲染

  • 🧮 Turf.js:地理空间分析库,用于生成地理椭圆图形

  • 🧩 Vue3 + Composition API:现代化前端组件开发范式


📦 二、安装依赖

使用 npm 安装相关依赖:

npm install ol @turf/turf

✨ 三、功能说明

  • 使用 turf.ellipse(center, xSemiAxis, ySemiAxis) 创建符合 GeoJSON 标准的椭圆形数据

  • 使用 ol.format.GeoJSON 解析数据并在地图上渲染

  • 提供按钮点击交互功能:绘制、清除图层


💻 四、完整代码实现

🔧 1. EllipticMap.vue

<!--
 * @Author: 彭麒
 * @Date: 2025/7/15
 * @Email: 1062470959@qq.com
 * @Description: 此源码版权归吉檀迦俐所有,可供学习和借鉴或商用。
 -->
<template>
  <div class="container">
    <div class="w-full flex justify-center flex-wrap">
      <div class="font-bold text-[24px]">
        Vue3中使用OpenLayers+Turf 绘制椭圆形
      </div>
    </div>
    <h4>
      <el-button type="primary" size="small" @click="ellipse">绘制椭圆形</el-button>
      <el-button type="danger" size="small" @click="clearSource">清除图层</el-button>
    </h4>
    <div id="vue-openlayers"></div>
  </div>
</template>
<script lang="ts" setup>
import { onMounted, ref } from 'vue'
import 'ol/ol.css'
import Map from 'ol/Map'
import View from 'ol/View'
import TileLayer from 'ol/layer/Tile'
import VectorLayer from 'ol/layer/Vector'
import VectorSource from 'ol/source/Vector'
import XYZ from 'ol/source/XYZ'
import { fromLonLat } from 'ol/proj'
import { Style, Fill, Stroke } from 'ol/style'
import GeoJSON from 'ol/format/GeoJSON'
import * as turf from '@turf/turf'

// 地图实例
const map = ref<Map | null>(null)

// 矢量数据源
const turfSource = new VectorSource({
  wrapX: false
})

// 显示 GeoJSON 数据
const show = (geojsonData: GeoJSON.FeatureCollection) => {
  const features = new GeoJSON().readFeatures(geojsonData, {
    dataProjection: 'EPSG:4326',
    featureProjection: 'EPSG:3857'
  })
  turfSource.addFeatures(features)
}

// 清除图层
const clearSource = () => {
  turfSource.clear()
}

// 绘制椭圆
const ellipse = () => {
  const center = [-75, 40]
  const xSemiAxis = 15
  const ySemiAxis = 10
  const ellipseFeature = turf.ellipse(center, xSemiAxis, ySemiAxis)
  show(ellipseFeature as turf.FeatureCollection)
}

// 初始化地图
const initMap = () => {
  const gaodeLayer = new TileLayer({
    source: new XYZ({
      url: 'http://wprd0{1-4}.is.autonavi.com/appmaptile?x={x}&y={y}&z={z}&lang=en&size=1&scl=1&style=7'
    })
  })

  const turfLayer = new VectorLayer({
    source: turfSource,
    style: new Style({
      fill: new Fill({
        color: 'rgba(255, 0, 0, 0.2)'
      }),
      stroke: new Stroke({
        width: 2,
        color: 'blue'
      })
    })
  })

  map.value = new Map({
    target: 'vue-openlayers',
    layers: [gaodeLayer, turfLayer],
    view: new View({
      projection: 'EPSG:3857',
      center: fromLonLat([-75, 40]),
      zoom: 8
    })
  })
}

// 组件挂载时初始化地图
onMounted(() => {
  initMap()
})
</script>



<style scoped>
.container {
  width: 840px;
  height: 570px;
  margin: 50px auto;
  border: 1px solid #42B983;
}

#vue-openlayers {
  width: 800px;
  height: 400px;
  margin: 0 auto;
  border: 1px solid #42B983;
  position: relative;
}
</style>

🧠 五、进阶建议

  1. ✅ 支持用户交互选择椭圆中心点绘制

  2. ✅ 支持设置旋转角度、单位(米、千米、英里)

  3. ✅ 支持导出为 GeoJSON 文件供后端或 GIS 软件使用

  4. ✅ 多图层管理、多种样式配置


🔚 六、总结

本示例完整展示了如何在 Vue3 项目中,结合 Turf.js 与 OpenLayers 实现一个地理意义下的椭圆图形绘制功能。

你可以以此为基础,继续构建更复杂的图形绘制分析工具,服务于地块管理、资源调度、应急预案等系统开发场景。


如你有任何问题或想进一步优化,欢迎在评论区交流!

如果觉得有帮助,记得 👍点赞 + ❤️收藏 + 💬留言支持我持续更新~

### 回答1: Vue3是最新版本的Vue.js框架,是一种现代的JavaScript框架,用于构建交互式和响应式的应用程序。OpenLayers是一个很受欢迎的用于Web地图应用程序的JavaScript库。 Vue3OpenLayers两者结合使用可以创建出高级的Web地图应用程序,因为Vue3拥有丰富的生态系统和丰富的组件库,能够轻松地集成OpenLayers功能和样式。Vue3非常适合用于开发Web应用程序,因为它提供了许多工具和功能来优化应用程序的性能和开发体验。 通过Vue3,您可以轻松地将OpenLayers与其他Vue组件集成在一起,以创建具有高级功能交互性的地图应用程序。Vue3的响应式数据绑定特性可以轻松地更新OpenLayers的图层和标记等地图元素。Vue3还提供了一种方便的方法来管理地图事件,您可以方便地为每个地图事件创建自定义处理程序和生命周期钩子。 总之,Vue3OpenLayers的结合使用可以为您带来一个强大的Web地图应用程序框架,提高开发和设计的效率,并在可扩展性和性能方面提供更好的解决方案。 ### 回答2: Vue3是一种现代web应用程序框架,可以用于构建基于数据驱动的单页面应用程序。OpenLayers则是一种开源JavaScript库,用于在Web上呈现交互式地图和地理空间数据。 Vue3OpenLayers的结合可以为开发人员提供一种强大的工具,用于构建可视化地图和地理空间数据的应用程序。Vue3可以通过其组件系统便于地组织代码和数据,并且可以使用其响应式数据绑定来更新UI。OpenLayers可以允许开发人员轻松地创建交互式地图,并使用其丰富的API来操作地图的样式和数据。 与以前版本的Vue相比,Vue3的主要优势是其重新设计的响应式API。Vue3的响应式API更加高效和灵活,使得开发人员可以更轻松地处理大量数据的更改。在开发地图应用程序时,这非常重要,因为大量的地理空间数据会随时间而变化。Vue3的新特性还包括更简单的编译器、更好的渲染性能和更好的TypeScript支持。 熟练使用Vue3OpenLayers可以使开发人员轻松构建功能强大且可定制的地图应用程序。使用组件化的方法来管理应用程序代码,可以使应用程序更容易维护和扩展。OpenLayers强大的功能可以使开发人员制定定制的地图风格和数据显示,从而为用户提供更丰富的交互体验。总而言之,Vue3OpenLayers的结合是开发地图应用程序的绝佳选择。 ### 回答3Vue3-OpenLayers是基于Vue3框架的客户端Web地图库。该库结合了Vue3的响应式数据流和OpenLayers的强大地图功能,提供了一个简单易用、灵活可定制的地图开发框架。通过Vue3-OpenLayers开发者可以较为轻松地搭建起自己的地图应用,实现各种地图需求。 Vue3-OpenLayers库的主要特点包括: 1. 基于Vue3响应式系统,便于数据更新和管理; 2. 提供了完整的OpenLayers组件库,如地图、图层、控件、交互等,方便使用; 3. 支持灵活的地图样式配置和自定义功能开发; 4. 支持OpenLayers的各种地图源,如瓦片图、WMS、WMTS等等。 Vue3-OpenLayers库的使用对于有Vue3开发经验的开发者而言较为友好,借助Vue3的响应式能力,实现地图数据和业务逻辑的跟随变化响应,并且组件化的设计模式方便了多层级嵌套的地图应用开发。同时,开发者还可以利用Vue3提供的组件化构建特性,设计出符合自己需求的定制化地图组件。 总之,Vue3-OpenLayers是一款强大的地图库,它将Vue3OpenLayers优势结合起来,为地图应用开发者提供了更为简单、灵活的地图开发解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

吉檀迦俐

你的鼓励奖是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值