继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

百度地图调用笔记:javascript版本2

野老盟客
关注TA
已关注
手记 19
粉丝 33
获赞 1498

学完基础的控件类的设置和操作,我觉得有必要对核心类进行一个归类了,可以参考一下的核心类,其中对于Map核心类的某些操作我放到用到的时候在进行:
1.PanOptions类:panBy和panTo方法的可选参数,没有构造函数,通过对象字面量形式表示。

    属性:
    noAnimation:是否在平移过程中禁止动画。(自1.2新增)(Boolean)

2.MapOptions:此类表示Map构造函数的可选参数。它没有构造函数,但可通过对象字面量形式表示。

    属性:
        1.minZoom:地图允许展示的最小级别。(Number)
        2.maxZoom:地图允许展示的最大级别。(Number)
        3.mapType:地图类型,默认为BMAP_NORMAL_MAP。(MapType:参考地图类型类,后面会介绍)
        4.enableHighResolution:是否启用使用高分辨率地图。在iPhone4及其后续设备上,可以通过开启此选项获取更高分辨率的底图,v1.2,v1.3版本默认不开启,v1.4默认为开启状态。(Boolean)
        5.enableAutoResize:是否自动适应地图容器变化,默认启用。(Boolean)
        6.enableMapClick:是否开启底图可点功能,默认启用。(Boolean)

3.Viewport:此类代表视野,不可实例化,通过对象字面量形式表示。(自 1.1 新增)

    属性:
        center:视野中心点。(Point)
        zoom:视野级别。(Number)

4.ViewportOptions:此类作为map.getViewport与map.setViewport方法的可选参数,不可实例化。

    属性:
        1.enableAnimation:是否启用动画效果移动地图,默认为true。当调整后的级别与当前地图级别一致时,将使用动画效果移动地图。(Boolean)
        2.margins:视野调整的预留边距,例如:margins: [30, 20, 0, 20] 表示坐标点会限制在上述区域内。(Array<Number>)
        3.zoomFactor:地图级别的偏移量,您可以在方法得出的结果上增加一个偏移值。例如map.setViewport计算出地图的级别为10,如果zoomFactor为-1,则最终的地图级别为9。(Number)
        4.delay:改变地图视野的延迟执行时间,单位毫秒,默认为200ms。此延时仅针对动画效果有效。(Number)

5.APIVersion:此常量表示API版本号,通过字符串进行描述。

    属性:
        BMAP_API_VERSION:返回当前API版本。例如,1.2版本返回字符串“1.2”。(String)

6.MapStyle:该类用于设置地图样式,使用对象字面量形式表示,不可实例化。

    属性:
        features:设置地图上展示的元素种类,支持point(兴趣点)、road(道路)、water(河流)、land(陆地)、building(建筑物)。(Array)
        style:设置地图底图样式,目前支持normal(默认样式),dark(深色样式),light(浅色样式)三种。(string)

7.Map类:百度地图最核心的一个类,用来实例化一个地图,之所以最后介绍这个,是因为前面基本上是配置信息,只要介绍这个的时候把那写配置信息初始化进去就可以了,这里我不会全部介绍完,因为到了别的类的时候我还是会继续介绍的。

    构造方法:
        Map(container:String|HTMLElement[,opts:MapOptions]):在指定的容器内创建地图实例,之后需要调用Map.centerAndZoom()方法对地图进行初始化。未进行初始化的地图将不能进行任何操作。
        注意,构造方法是百度地图的一切开始,也就是上面写到的
        var mp=new BMap.Map("传入你刚才提供的容器的id");
        方法,只有构造完成一个函数以外,才能够得到百度地图的起点。

    配置方法:
        下面方法基本上是开关方法,或者对等方法,两组一对
        enableDragging():启用地图拖拽,默认启用。
        disableDragging():禁用地图拖拽.

        enableScrollWheelZoom():启用滚轮放大缩小,默认禁用。
        disableScrollWheelZoom():禁用滚轮放大缩小。

        enableDoubleClickZoom():启用双击放大,默认启用。
        disableDoubleClickZoom():禁用双击放大

        enableKeyboard():启用键盘操作,默认禁用。键盘的上、下、左、右键可连续移动地图。同时按下其中两个键可使地图进行对角移动。PgUp、PgDn、Home和End键会使地图平移其1/2的大小。+、-键会使地图放大或缩小一级。
        disableKeyboard():禁用键盘操作。

        enableInertialDragging():启用地图惯性拖拽,默认禁用。
        disableInertialDragging():禁用地图惯性拖拽。

        enableContinuousZoom():启用连续缩放效果,默认禁用。
        disableContinuousZoom():禁用连续缩放效果。

        enablePinchToZoom():启用双指操作缩放,默认启用。
        disablePinchToZoom():禁用双指操作缩放。

        enableAutoResize():启用自动适应容器尺寸变化,默认启用。
        disableAutoResize():禁用自动适应容器尺寸变化。

        下面配置信息是存取方法,取得返回值是存的设置值
        setDefaultCursor(cursor:String):设置地图默认的鼠标指针样式。参数cursor应符合CSS的cursor属性规范。
        getDefaultCursor():返回地图默认的鼠标指针样式。

        setDraggingCursor(cursor:String):设置拖拽地图时的鼠标指针样式。参数cursor应符合CSS的cursor属性规范。
        getDraggingCursor():返回拖拽地图时的鼠标指针样式。

        下面是配置信息是设置方法
        1.setMinZoom(zoom:Number):设置地图允许的最小级别。取值不得小于地图类型所允许的最小级别。
        2.setMaxZoom(zoom:Number):设置地图允许的最大级别。取值不得大于地图类型所允许的最大级别。
        3.setMapStyle(mapStyle:MapStyle):设置地图样式,样式包括地图底图颜色和地图要素是否展示两部分。注意,该类型可以参考上面的MapStyle类
        4.setPanorama(pano:Panorama):将全景实例与Map类进行绑定。注意,该类型可以参考下面的全景类。
        5.disable3DBuilding():禁用地图的3D楼块展现功能。

    状态方法:
        该方法一般具有返回值,请参考()里面的返回值类型
        1.getBounds():返回地图可视区域,以地理坐标表示。(Bounds)返回值参考前面的基础类
        2.getCenter():返回地图当前中心点。(Point)返回值参考前面的基础类
        3.getDistance(start:Point, end:Point)返回两点之间的距离,单位是米。(Number)
        4.getMapType():返回地图类型。(MapTypes)
        5.getSize():返回地图视图的大小,以像素表示.(Size)
        6.getViewport(view: Array<Point>[, viewportOptions: ViewportOptions]):根据提供的地理区域或坐标获得最佳的地图视野,返回的对象中包含center和zoom属性,分别表示地图的中心点和级别。此方法仅返回视野信息,不会将新的中心点和级别做用到当前地图上。(Viewport)
        7.getZoom():返回地图当前缩放级别。(Number)
        8.getPanorama():获取与Map类绑定的全景实例。(Panorama)

    修改地图状态方法:
        下面方法可以用来设置地图状态信息,这样可以动态设置。基本上没有返回值。

        1.centerAndZoom(center:Point, zoom:Number):设初始化地图。如果center类型为Point时,zoom必须赋值,范围3-19级,若调用高清底图(针对移动端开发)时,zoom可赋值范围为3-18级。如果center类型为字符串时,比如“北京”,zoom可以忽略,地图将自动根据center适配最佳zoom级别。参考前面介绍的信息。

        2.panTo(center:Point[, opts:PanOptions]):将地图的中心点更改为给定的点。如果该点在当前的地图视图中已经可见,则会以平滑动画的方式移动到中心点位置。可以通过配置强制移动过程不使用动画效果。

        3.panBy(x:Number, y:Number[, opts: PanOptions]):将地图在水平位置上移动x像素,垂直位置上移动y像素。如果指定的像素大于可视区域范围或者在配置中指定没有动画效果,则不执行滑动效果。

        4.reset():重新设置地图,恢复地图初始化时的中心点和级别。这个可以方便重新设置值。

        5.setCenter(center:Point|String):设置地图中心点。center除了可以为坐标点以外,还支持城市名。

        6.setCurrentCity(city:String):设置地图城市,注意当地图初始化时的类型设置为BMAP_PERSPECTIVE_MAP时,需要在调用centerAndZoom之前调用此方法设置地图所在城市。
        例如:
        var map = new BMap.Map(“container”, {mapType: BMAP_PERSPECTIVE_MAP}); map.setCurrentCity(“北京市”); map.centerAndZoom(new BMap.Point(116.404, 39.915), 18); 注意:初始化的坐标应与您设置的城市对应,否则地图将无法正常显示。如果地图初始化为BMAP_NORMAL_MAP类型,则在调用setMapType切换地图类型时也要调用此方法。

        7.setMapType(mapType:MapTypes):设置地图类型。注意,当设置地图类型为BMAP_PERSPECTIVE_MAP时,需要调用map.setCurrentCity方法设置城市。

        8.setViewport(view:Array<Point>|Viewport[, viewportOptions: ViewportOptions]):根据提供的地理区域或坐标设置地图视野,调整后的视野会保证包含提供的地理区域或坐标。

        9.setZoom(zoom:Number):将视图切换到指定的缩放等级,中心点坐标不变。注意:当有信息窗口在地图上打开时,地图缩放将保证信息窗口所在的坐标位置不动。

        10.highResolutionEnabled():是否使用高分辨率底图。仅当mapOptions.enableHighResolution属性为true且设备支持高分辨率时返回true。(Boolean)

        11.zoomIn():放大一级视图。

        12.zoomOut():缩小一级视图。

        13.addHotspot(hotspot:Hotspot):为地图添加热区。

        14.removeHotspot(hotspot:Hotspot):移除某个地图热区。

        15.clearHotspots():清空地图所有热区.

        以上方法还可以这样利用,就是当你设置一个控件的时候就可以调用上面的方法进行设置了。

    下面的控件方法,右键菜单方法,覆盖物方法,地图图层方法可以参考每个类说明的最后一个说明,这里就不说了,为了更好的分类运用。

    坐标变换:
        此方法就是像素点和成经纬度互相转换的方法。返回值就是相对的值。
        pixelToPoint(pixel:Pixel):像素坐标转换为经纬度坐标
        pointToPixel(point:Point):经纬度坐标转换为像素坐标。

    事件:
        这个分类我觉得还是比较重要的,毕竟效果是通过事件去实现的,所以,这些方法还是需要详细看看的:其中后面的括号为所要的参数。

        下面是鼠标点击事件,如果做移动Webapp的话,最好使用后面的触摸事件。
        1.click:左键单击地图时触发此事件。当双击时,产生的事件序列为: click click dblclick({type, target, point, pixel, overlay})
        2.dblclick:鼠标双击地图时会触发此事件。({type, target, pixel, point})
        3.rightclick:右键单击地图时触发此事件。当双击时,产生的事件序列为: rightclick rightclick rightdblclick ({type, target, point, pixel, overlay})
        4.rightdblclick:右键双击地图时触发此事件。({type, target, point, pixel, overlay})

        //web端移动事件
        5.maptypechange:地图类型发生变化时触发此事件。
        6.mousemove:鼠标在地图区域移动过程中触发此事件。({type, target, point, pixel, overlay})
        7.mouseover:鼠标移入地图区域时触发此事件。({type, target})
        8.mouseout:鼠标移出地图区域时触发此事件。({type, target})
        9.movestart:地图移动开始时触发此事件。({type, target})
        10.moving:地图移动过程中触发此事件。({type, target})
        11.moveend:地图移动结束时触发此事件。({type, target})
        12.zoomstart:地图更改缩放级别开始时触发触发此事件。({type, target})
        13.zoomend:地图更改缩放级别结束时触发触发此事件。({type, target})

        //添加覆盖物事件
        14.addoverlay:当使用Map.addOverlay()方法向地图中添加单个覆盖物时会触发此事件。({type, target})

        //添加控件事件
        15.addcontrol:当使用Map.addControl()方法向地图中添加单个控件时会触发此事件。({type, target})
        16.removecontrol:当使用Map.removeControl()方法移除单个控件时会触发此事件。({type, target})
        17.removeoverlay:当使用Map.removeOverlay()方法移除单个覆盖物时会触发此事件。({type, target})
        18.clearoverlays:当使用Map.clearOverlays()方法一次性移除全部覆盖物时会触发此事件({type, target})

        //拖拽事件
        19.dragstart:开始拖拽地图时触发。({type, target, pixel, point})
        20.dragging:拖拽地图过程中触发。({type, target, pixel, point})
        21.dragend:停止拖拽地图时触发。({type, target, pixel, point})

        //添加图层事件
        22.addtilelayer:添加一个自定义地图图层时触发此事件。({type, target})
        23.removetilelayer:移除一个自定义地图图层时触发此事件。({type, target})

        下面是加载事件
        24.load:调用Map.centerAndZoom()方法时会触发此事件。这表示位置、缩放层级已经确定,但可能还在载入地图图块。({type, target, pixel, point, zoom})
        25.resize:地图可视区域大小发生变化时会触发此事件。({type, target, size})
        29.tilesloaded:当地图所有图块完成加载时触发此事件。({type, target})

        下面是热区地图的事件
        26.hotspotclick:点击热区时触发此事件。({type, target, size})
        27.hotspotover:鼠标移至热区时触发此事件。({type, target, size})
        28.hotspotout:鼠标移出热区时触发此事件({type, target, size})

        下面的是移动设备的事件
        30.touchstart:触摸开始时触发此事件,仅适用移动设备({type, target, point,pixel})
        31.touchmove:触摸移动时触发此事件,仅适用移动设备。({type, target, point,pixel})
        32.touchend:触摸结束时触发此事件,仅适用移动设备。({type, target, point,pixel})
        33.longpress:长按事件,仅适用移动设备。({type, target, point,pixel})

        有了事件,就需要说明事件的使用方法,其实百度地图使用的方法是回调机制,如下所示:
            Map.addEventListener("事件名称",function(){回调方法});
        当然,上面提到的括号后面的参数传递的方法传递到回调函数里面。

其实我们学完上面的基本上有一个逻辑思路就是:
首先,引入百度地图,其次,可以去百度地图的示例看下范例,当然,如果你熟悉百度地图的API完全可以直接看API,然后一般的都是通过new BMap.你要实现类实例化,他里面的参数基本上是一个配置项,可以去附近类的名字看下,然后就是看他有什么方法进行写,下面的那些类我就不记录了,有兴趣的去看看百度地图,然后自己玩下吧,嘿嘿,如果你喜欢,请为我点个赞哦!谢谢支持!

打开App,阅读手记
15人推荐
发表评论
随时随地看视频慕课网APP