• 百度地图 JavaScript api 2.0之类 BMapLib.DrawingManager


    百度地图API示例:http://lbsyun.baidu.com/jsdemo.htm#a5_2

    来源 http://api.map.baidu.com/library/DrawingManager/1.4/docs/symbols/BMapLib.DrawingManager.html

    类 BMapLib.DrawingManager

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

    描述
    DrawingManager类的构造函数

    方法

    方法 返回值 描述
     
    关闭地图的绘制状态
     
    关闭距离或面积计算
     
    打开距离或面积计算
    DrawingType
    获取当前的绘制模式
     
    开启地图的绘制模式
    setDrawingMode(DrawingType)
    Boolean
    设置当前的绘制模式,参数DrawingType,为5个可选常量:
    BMAP_DRAWING_MARKER 画点
    BMAP_DRAWING_CIRCLE 画圆
    BMAP_DRAWING_POLYLINE 画线
    BMAP_DRAWING_POLYGON 画多边形
    BMAP_DRAWING_RECTANGLE 画矩形

    事件

    事件 参数 描述
    {Circle}
    绘制圆完成后,派发的事件接口
    {Marker}
    绘制点完成后,派发的事件接口
    {Event Object}
    鼠标绘制完成后,派发总事件的接口
    {Polygon}
    绘制多边形完成后,派发的事件接口
    {Polyline}
    绘制线完成后,派发的事件接口
    {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}
  • 相关阅读:
    【Linux 内核网络协议栈源码剖析】数据包发送
    【Linux 内核网络协议栈源码剖析】connect 函数剖析(一)
    【Henu ACM Round#14 C】Duff and Weight Lifting
    【Henu ACM Round#14 B】Duff in Love
    【Henu ACM Round#14 A】Vitaly and Night
    【Henu ACM Round #13 E】Spy Syndrome 2
    【Henu ACM Round #13 F】Fibonacci-ish
    【Henu ACM Round #13 D】A Trivial Problem
    【Henu ACM Round #13 C】 Ebony and Ivory
    【Henu ACM Round #13 B】Spider Man
  • 原文地址:https://www.cnblogs.com/zouhao/p/12902248.html
Copyright © 2020-2023  润新知