【vue+leaflet】vue项目中使用leaflet绘制室内平面图、leaflet.pm在平面图中绘制点、线、面图层(一)

本文主要是介绍【vue+leaflet】vue项目中使用leaflet绘制室内平面图、leaflet.pm在平面图中绘制点、线、面图层(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述
效果图:
在这里插入图片描述

一,插件安装

npm i leaflet --save   // 我的版本^1.9.4
npm i leaflet.pm --save // 我的版本^2.2.0

附官网链接:
leaflet官网: https://leafletjs.com/index.html
leaflet.pm官网: https://www.npmjs.com/package/leaflet.pm?activeTab=readme

二,模块引入

因为我是单个页面需要所有就局部引入了,也可以放全局里面引入

<script>
import 'leaflet/dist/leaflet.css'
import 'leaflet/dist/leaflet'
import 'leaflet/dist/leaflet-src'
import 'leaflet/dist/leaflet-src.esm'
import * as L from 'leaflet'
import icon from 'leaflet/dist/images/marker-icon.png'
import iconShadow from 'leaflet/dist/images/marker-shadow.png'
import 'leaflet.pm'
import 'leaflet.pm/dist/leaflet.pm.css'
const DefaultIcon = L.icon({iconUrl: icon,shadowUrl: iconShadow,
})
L.Marker.prototype.options.icon = DefaultIcon
export default {data() {return {map: null,fillColor: '#2d75ff80',bounds: [[0, 0],[0, 0],], // 平面图大小}}
}
</script>

三,逻辑代码

 <div id="imageMap"></div>......methods: {// 平面图初始化initMap() {this.map = L.map('imageMap', {minZoom: -3,zoom: 5,maxZoom: 4,zoomSnap: 0.1, // 缩放步长attributionControl: false, // 右下角图例控件zoomControl: true, // 缩放控件crs: L.CRS.Simple, // 坐标系center: [0, 0], // 中心点})this.map.pm.setLang('zh') // 控件提示设置中文this.map.pm.addControls({position: 'topleft', // 控件菜单位置drawPolygon: true, //绘制多边形drawMarker: true, //绘制标记点drawCircleMarker: true, //绘制圆形标记drawPolyline: true, //绘制线条drawRectangle: true, //绘制矩形drawCircle: true, //绘制圆圈editMode: true, //编辑多边形dragMode: true, //拖动多边形cutPolygon: true, //添加⼀个按钮以删除多边形⾥⾯的部分内容removalMode: true, //清除多边形})// 全局图层样式this.map.pm.setPathOptions({fillOpacity: 0.5,fillColor: this.fillColor,})},// 地图初始化initDate() {// 获取图片宽高,防止不同尺寸的图片回显在页面上有多余的留白问题let img = new Image()let url = require('../../public/home/bgc4.jpg')img.src = urlimg.onload = () => {let w = img.widthlet h = img.heightthis.bounds = [[0, 0],[h, w],]// 创建地图L.imageOverlay(url, this.bounds).addTo(this.map)// 设置地图图层区域this.map.fitBounds(this.bounds)}// 给地图绑定绘制、删除的事件this.map.on('pm:create', this.createClick)this.map.on('pm:remove', this.removeClick)// 禁止背景图拖拽,默认是可拖拽的this.map.dragging.disable()// 禁止双击缩放,默认是可双击缩放的this.map.doubleClickZoom.disable()// 禁止滚动缩放,默认是可滚动缩放的this.map.scrollWheelZoom.disable()},// 图层绘制完成createClick(e) {// console.log('图层绘制完成', e)// 设置图层样式e.layer.setStyle({fillOpacity: 0.5,fillColor: this.fillColor,// color:线段颜色// weight:线段宽度// opacity:线段透明度// dashArray:虚线间隔// fill:是否填充内部(true/false)// fillColor:内部填充颜色,如不设置,默认为color颜色// fillOpacity:内部填充透明度})// 给图层绑定点击、拖拽、编辑事件e.layer.on('pm:edit', this.editLayClick).on('click', this.layClick).on('pm:dragend', this.dragendLayClick)},// 图层删除removeClick(e) {// console.log('图层删除', e)},// 区域图层点击layClick(e) {// console.log('区域图层点击', e)},// 区域图层拖拽dragendLayClick(e) {// console.log('区域图层拖拽', e)},// 区域图层编辑editLayClick(e) {// console.log('图层编辑', e)},},mounted() {this.initMap()this.initDate()// 窗口缩放,地图自适应缩放window.onresize = () => {this.map.invalidateSize(true)this.map.fitBounds(this.bounds)}},

到这里就可以实现效果图所展示的功能了,下节详细说明各个模块及事件函数的功能.
所有示例代码已上传,点击前往获取
Done

这篇关于【vue+leaflet】vue项目中使用leaflet绘制室内平面图、leaflet.pm在平面图中绘制点、线、面图层(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/726874

相关文章

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Springboot项目启动失败提示找不到dao类的解决

《Springboot项目启动失败提示找不到dao类的解决》SpringBoot启动失败,因ProductServiceImpl未正确注入ProductDao,原因:Dao未注册为Bean,解决:在启... 目录错误描述原因解决方法总结***************************APPLICA编

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

python使用try函数详解

《python使用try函数详解》Pythontry语句用于异常处理,支持捕获特定/多种异常、else/final子句确保资源释放,结合with语句自动清理,可自定义异常及嵌套结构,灵活应对错误场景... 目录try 函数的基本语法捕获特定异常捕获多个异常使用 else 子句使用 finally 子句捕获所

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符