leaflet 地图简笔画 -- leaflet-freedraw 的使用

        以前,在地图上画多边形一直使用的是Leaflet.draw这个组件,中规中矩的,使用起来也是挺不错的,后来发现了leaflet-freedraw,这个组件是在地图上进行一笔画,一笔下来就可以完成一个多边形,用起来更流畅,和Leaflet.draw各有千秋,今天主要说一下leaflet-freedraw的使用方法,关于leaflet-freedraw的详细信息,可以搞GitHub上查看。

一、安装组件

npm i leaflet-freedraw

yarn add leaflet-freedraw

二、使用组件

1、在使用页面引入

import FreeDraw, { CREATE, EDIT, APPEND, NONE } from "leaflet-freedraw";

2、相关代码

<div class="map" id="mapContainer" @keydown.space="onKeyDown" @keyup.space="onKeyUp"></div>
   //按下空格键,设置mode为none,可拖动地图
    onKeyDown() {
      this.freeDraw && this.freeDraw.mode(NONE);
    },
    //松开空格键,重新设置mode,即可再次画图
    onKeyUp() {
      this.freeDraw && this.freeDraw.mode(CREATE | EDIT | APPEND);
    },
    //清除
    clearFreeDraw() {
      if (this.freeDraw) {
        this.freeDraw.mode(NONE);
        this.freeDraw.clear();
      }
    },
    /**
     * 初始化
     */
    initFreeDraw() {
      if (this.freeDraw) {
        this.freeDraw.mode(CREATE | EDIT | APPEND);
      } else {
        this.freeDraw = new FreeDraw({
          maximumPolygons: 1,//最多可以画几个多边形
          mode: CREATE | EDIT | APPEND,//类型
          strokeWidth:3,//线的宽度
        });
        this.map.addLayer(this.freeDraw);
        this.freeDraw.on("markers", (event) => {
          if (event.latLngs.length > 0) {
            //这里可以获取到所画图形的坐标点集合
            this.clearFreeDraw();
          }
        });
      }
    },

3、效果如下:

e6c94272ff0d4cee8eb5883571a9981d.png

这个组件用法相对简单,还有一些其他的配置,大家可以到leaflet-freedraw文档中查看

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

travel_wsy

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

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

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

打赏作者

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

抵扣说明:

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

余额充值