OpenLayers实战,OpenLayers画线测量距离和画多边形测量区域面积

132 篇文章 10 订阅 ¥159.90 ¥99.00
121 篇文章 64 订阅 ¥119.90 ¥99.00
53 篇文章 34 订阅 ¥69.90 ¥99.00

专栏目录:
OpenLayers实战进阶专栏目录

前言

本章使用OpenLayers实现画线测量距离和画多边形测量区域面积这两个功能。
本章代码就是通过OpenLayers的图形绘制功能,通过监听绘制事件获取绘制的图形,并进行计算,就可以得到长度和面积。日常开发中比较常用,所以不废话,立刻开始实现。
openlayers

二、依赖和使用

"ol": "^6.15.1"
  1. 使用npm安装依赖
npm install ol@6.15.1
  1. 使用Yarn安装依赖
yarn 
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
在Vue中使用OpenLayers进行面积测量,可以通过以下步骤实现: 1. 首先,在Vue项目中,安装OpenLayers库。可以通过运行以下命令进行安装: ``` npm install ol ``` 2. 在Vue组件中引入OpenLayers库,可以使用`import`语句进行引入: ```javascript import ol from 'ol'; ``` 3. 创建一个Vue组件,并在`mounted`钩子函数中进行OpenLayers地图的初始化。在地图初始化过程中,可以设置视图的初始中心以及缩放级别: ```javascript mounted() { const map = new ol.Map({ target: 'map', view: new ol.View({ center: [0, 0], zoom: 2 }) }); } ``` 4. 在组件的模板中,添加一个具有特定ID的`div`元素,作为地图的容器: ```html <template> <div id="map"></div> </template> ``` 5. 在`mounted`钩子函数中,创建一个用于绘制图形的矢量源和矢量层。可以通过`ol.source.Vector`和`ol.layer.Vector`来实现: ```javascript mounted() { // ...省略地图初始化代码 const vectorSource = new ol.source.Vector(); const vectorLayer = new ol.layer.Vector({ source: vectorSource }); map.addLayer(vectorLayer); } ``` 6. 添加一个测量控件,用于测量面积。可以通过`ol.control.Measure`来实现: ```javascript mounted() { // ...省略地图初始化和添加矢量层代码 const measureControl = new ol.control.Measure({ source: vectorSource, type: 'area', interactionType: 'click' }); map.addControl(measureControl); } ``` 7. 最后,在模板中添加一个按钮或其他元素,用于触发测量功能: ```html <template> <div id="map"> <button @click="startMeasurement">开始测量</button> </div> </template> ``` 8. 在组件的方法中,编写`startMeasurement`方法,用于启动测量功能: ```javascript methods: { startMeasurement() { const measureControl = map.getControls().getArray().find(control => control instanceof ol.control.Measure); measureControl.setActive(true); } } ``` 通过以上步骤,Vue中的OpenLayers地图将具备面积测量功能。用户可以点击“开始测量”按钮,然后在地图上绘制多边形测量结果将以弹窗或其他形式呈现给用户。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

汤姆猫不是猫

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

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

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

打赏作者

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

抵扣说明:

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

余额充值