bigemap地图下载器 百度离线地图API接口文档及接口调用实例——鼠标绘制点线面类参考

本文主要是介绍bigemap地图下载器 百度离线地图API接口文档及接口调用实例——鼠标绘制点线面类参考,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

类 BMapLib.DrawingManager

鼠标绘制管理类,实现鼠标绘制管理的入口。 实例化该类后,即可调用该类提供的open 方法开启绘制模式状态。 也可加入工具栏进行选择操作。 
源文件: DrawingManager.js.

描述

BMapLib.DrawingManager(map, opts)

DrawingManager类的构造函数

方法

方法返回值描述

close()

 

关闭地图的绘制状态

disableCalculate()

 

关闭距离或面积计算

enableCalculate()

 

打开距离或面积计算

getDrawingMode()

DrawingType

获取当前的绘制模式

open()

 

开启地图的绘制模式

setDrawingMode(DrawingType)

Boolean

设置当前的绘制模式,参数DrawingType,为5个可选常量: 
BMAP_DRAWING_MARKER 画点 
BMAP_DRAWING_CIRCLE 画圆 
BMAP_DRAWING_POLYLINE 画线 
BMAP_DRAWING_POLYGON 画多边形 
BMAP_DRAWING_RECTANGLE 画矩形

事件

事件参数描述

circlecomplete(overlay)

{Circle}

绘制圆完成后,派发的事件接口

markercomplete(overlay)

{Marker}

绘制点完成后,派发的事件接口

overlaycomplete(e)

{Event Object}

鼠标绘制完成后,派发总事件的接口

polygoncomplete(overlay)

{Polygon}

绘制多边形完成后,派发的事件接口

polylinecomplete(overlay)

{Polyline}

绘制线完成后,派发的事件接口

rectanglecomplete(overlay)

{Polygon}

绘制矩形完成后,派发的事件接口

BMapLib.DrawingManager(map, opts)

DrawingManager类的构造函数

var map = new BMap.Map("container");
map.centerAndZoom(new BMap.Point(116.404, 39.915), 15);
var myDrawingManagerObject = new BMapLib.DrawingManager(map, {isOpen: true, drawingType: BMAP_DRAWING_MARKER, enableDrawingTool: true,enableCalculate: false,drawingToolOptions: {anchor: BMAP_ANCHOR_TOP_LEFT,offset: new BMap.Size(5, 5),drawingTypes : [BMAP_DRAWING_MARKER,BMAP_DRAWING_CIRCLE,BMAP_DRAWING_POLYLINE,BMAP_DRAWING_POLYGON,BMAP_DRAWING_RECTANGLE ]},polylineOptions: {strokeColor: "#333"});
  • 参数:

  • {Map} map

  • Baidu map的实例对象

  • {Json Object} opts

  • 可选的输入参数,非必填项。可输入选项包括:
    {"isOpen" : {Boolean} 是否开启绘制模式 
    "enableDrawingTool" : {Boolean} 是否添加绘制工具栏控件,默认不添加 
    "drawingToolOptions" : {Json Object} 可选的输入参数,非必填项。可输入选项包括 
    "anchor" : {ControlAnchor} 停靠位置、默认左上角 
    "offset" : {Size} 偏移值。 
    "scale" : {Number} 工具栏的缩放比例,默认为1 
    "drawingModes" : {DrawingType} 工具栏上可以选择出现的绘制模式,将需要显示的DrawingType以数组型形式传入,如[BMAP_DRAWING_MARKER, BMAP_DRAWING_CIRCLE] 将只显示画点和画圆的选项 
    "enableCalculate" : {Boolean} 绘制是否进行测距(画线时候)、测面(画圆、多边形、矩形) 
    "markerOptions" : {CircleOptions} 所画的点的可选参数,参考api中的对应类 
    "circleOptions" : {CircleOptions} 所画的圆的可选参数,参考api中的对应类 
    "polylineOptions" : {CircleOptions} 所画的线的可选参数,参考api中的对应类 
    "polygonOptions" : {PolygonOptions} 所画的多边形的可选参数,参考api中的对应类 
    "rectangleOptions" : {PolygonOptions} 所画的矩形的可选参数,参考api中的对应类

方法详述

close()

关闭地图的绘制状态

myDrawingManagerObject.close();

disableCalculate()

关闭距离或面积计算

myDrawingManagerObject.disableCalculate();

enableCalculate()

打开距离或面积计算

myDrawingManagerObject.enableCalculate();

{DrawingType} getDrawingMode()

获取当前的绘制模式

alert(myDrawingManagerObject.getDrawingMode());
  • 返回值:

  • {DrawingType} 绘制的模式


open()

开启地图的绘制模式

myDrawingManagerObject.open();

{Boolean} setDrawingMode(DrawingType)

设置当前的绘制模式,参数DrawingType,为5个可选常量: 
BMAP_DRAWING_MARKER 画点 
BMAP_DRAWING_CIRCLE 画圆 
BMAP_DRAWING_POLYLINE 画线 
BMAP_DRAWING_POLYGON 画多边形 
BMAP_DRAWING_RECTANGLE 画矩形

 

myDrawingManagerObject.setDrawingMode(BMAP_DRAWING_POLYLINE);

  • 参数:

  • {DrawingType} DrawingType

  •  

  • 返回值:

  • {Boolean}

事件详述

circlecomplete(overlay)

绘制圆完成后,派发的事件接口

  • 参数:

  • {Circle} overlay

  • 回调函数会返回相应的覆盖物, 
    {"overlay : {Circle}


markercomplete(overlay)

绘制点完成后,派发的事件接口

 

参考示例:myDrawingManagerObject.addEventListener("circlecomplete", function(e, overlay) {
    alert(overlay);
});

  • 参数:

  • {Marker} overlay

  • 回调函数会返回相应的覆盖物, 
    {"overlay : {Marker}


overlaycomplete(e)

鼠标绘制完成后,派发总事件的接口

 

参考示例:myDrawingManagerObject.addEventListener("overlaycomplete", function(e) {
    alert(e.drawingMode);
    alert(e.overlay);
    alert(e.calculate);
    alert(e.label);
});

  • 参数:

  • {Event Object} e

  • 回调函数会返回event参数,包括以下返回值: 
    {"drawingMode : {DrawingType} 当前的绘制模式 
    "overlay:{Marker||Polyline||Polygon||Circle} 对应的绘制模式返回对应的覆盖物 
    "calculate:{Number} 需要开启计算模式才会返回这个值,当绘制线的时候返回距离、绘制多边形、圆、矩形时候返回面积,单位为米, 
    "label:{Label} 计算面积时候出现在Map上的Label对象


polygoncomplete(overlay)

绘制多边形完成后,派发的事件接口

  • 参数:

  • {Polygon} overlay

  • 回调函数会返回相应的覆盖物, 
    {"overlay : {Polygon}


polylinecomplete(overlay)

绘制线完成后,派发的事件接口

  • 参数:

  • {Polyline} overlay

  • 回调函数会返回相应的覆盖物, 
    {"overlay : {Polyline}


rectanglecomplete(overlay)

绘制矩形完成后,派发的事件接口

  • 参数:

  • {Polygon} overlay

  • 回调函数会返回相应的覆盖物, 
    {"overlay : {Polygon}

这篇关于bigemap地图下载器 百度离线地图API接口文档及接口调用实例——鼠标绘制点线面类参考的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SQL server数据库如何下载和安装

《SQLserver数据库如何下载和安装》本文指导如何下载安装SQLServer2022评估版及SSMS工具,涵盖安装配置、连接字符串设置、C#连接数据库方法和安全注意事项,如混合验证、参数化查... 目录第一步:打开官网下载对应文件第二步:程序安装配置第三部:安装工具SQL Server Manageme

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Java中调用数据库存储过程的示例代码

《Java中调用数据库存储过程的示例代码》本文介绍Java通过JDBC调用数据库存储过程的方法,涵盖参数类型、执行步骤及数据库差异,需注意异常处理与资源管理,以优化性能并实现复杂业务逻辑,感兴趣的朋友... 目录一、存储过程概述二、Java调用存储过程的基本javascript步骤三、Java调用存储过程示

使用Python绘制3D堆叠条形图全解析

《使用Python绘制3D堆叠条形图全解析》在数据可视化的工具箱里,3D图表总能带来眼前一亮的效果,本文就来和大家聊聊如何使用Python实现绘制3D堆叠条形图,感兴趣的小伙伴可以了解下... 目录为什么选择 3D 堆叠条形图代码实现:从数据到 3D 世界的搭建核心代码逐行解析细节优化应用场景:3D 堆叠图

java向微信服务号发送消息的完整步骤实例

《java向微信服务号发送消息的完整步骤实例》:本文主要介绍java向微信服务号发送消息的相关资料,包括申请测试号获取appID/appsecret、关注公众号获取openID、配置消息模板及代码... 目录步骤1. 申请测试系统2. 公众号账号信息3. 关注测试号二维码4. 消息模板接口5. Java测试

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到