百度地图历史轨迹回放:起止点为坐标点,从后台获取10个途经点

    利用百度地图 驾车线路规划 实现 运输车辆历史轨迹回放画线路 的功能。

     运输车辆的历史轨迹即运输车辆在过去某段时间内走过的路线轨迹。首先得有时间段,即想要画出运输车辆在哪一段时间内的路线轨迹;其次得有在这段历史时间内运输车辆走过的所有轨迹点,这些轨迹点需要从后台获取,当然获取时得从前台把时间段传给后台。

    根据业务需求,获取指定车辆的出发时间和停止时间,然后将这两个时间传递给后台,后台根据这两个时间点获取对应时间段的该指定车辆的走过的轨迹点。

    后台将指定车辆在某个时间段内的轨迹点返回给前台,前台接收到这些轨迹点,依据百度地图的驾车线路规划,画出基于这些轨迹点的轨迹回放路线。

    具体方法是:从后台获取某时间段内的所有历史轨迹点,将第一个点作为轨迹的起始点,将最后一个点作为轨迹的终止点,然后从第一个点到最后一个点的所有途经点中,根据某规律选取10个途经点(因为百度地图JavaScript v2.0 api 规定途经点不能超过10个。但个人测试过,可以取到29个途经点来画出历史轨迹。当途经点为30个是,百度地图就画不出轨迹路线了。)。

    确定了起始点、终止点、途经点之后,利用百度地图的DrivingRoute创建一个驾车实例,并在驾车实例中规定驾车策略policy为最短路径策略BMAP_DRIVING_POLICY_LEAST_DISTANCE(因为只有最短路径策略的路径规划是唯一的,而另外两个策略:最短时间BMAP_DRIVING_POLICY_LEAST_TIME、避开高速BMAP_DRIVING_POLICY_AVOID_HIGHWAYS的路径规划不是唯一的。)

    例如:var myDriving = new BMap.DrivingRoute(map, {renderOptions:{map: map, autoViewport: false}, policy: BMAP_DRIVING_POLICY_LEAST_DISTANCE});

    创建好驾车实例myDriving 后,利用驾车实例的search方法发起检索,即可在地图中检索出一条最短路径的轨迹路线。在用search方法检索时,将从后台获取到的起始点、终止点、途经点,作为参数传递给search方法即可。

    例如:myDriving.search(trackPoints[0], trackPoints[trackPoints.length - 1], {waypoints: wayPoints});//waypoints表示途经点

    利用设置途经点的方法虽然可以实现历史轨迹回放的效果,但是由于10个途经点并不能完全代表车辆实际走过的所有路径,所以依此方法规划出来的路径很多时候并不全面或并不准确。要想实现历史轨迹回放与真实车辆走过的路径完全一样,就需要把从后台获取的所有轨迹点都利用上,使画出的轨迹必须经过每一个途经点,这样才能保证轨迹的真实性。



	
	
	
	
	
	起止点为坐标点,从后台获取10个途经点


	


具体效果如下图所示:

百度地图历史轨迹回放:起止点为坐标点,从后台获取10个途经点_第1张图片

JavaScript API v2.0说明(http://lbsyun.baidu.com/cms/jsapi/reference/jsapi_reference.html#a7b16)

    此类用于获取驾车路线规划方案:DrivingRoute(location: Map | Point | String, opts: DrivingRouteOptions)
创建一个驾车导航实例,其中location表示检索区域,类型可为地图实例、坐标点或城市名称的字符串。
当参数为地图实例时,检索位置由地图当前的中心点确定;当参数为坐标时,检索位置由该点所在位置确定;当参数为城市名称时,检索会在该城市内进行。
    opts: DrivingRouteOptions————此类表示DrivingRoute构造函数的可选参数。
    renderOptions:此类表示搜索结果呈现的配置。它没有构造函数,但可通过对象字面量形式表示。 map:展现结果的地图实例。当指定此参数后,搜索结果的标注、线路等均会自动添加到此地图上。autoViewport:检索结束后是否自动调整地图视野。此属性对LocalCity无效。
    policy:此枚举类型表示驾车方案的策略配置。BMAP_DRIVING_POLICY_LEAST_TIME:最少时间。 BMAP_DRIVING_POLICY_LEAST_DISTANCE:最短距离。 BMAP_DRIVING_POLICY_AVOID_HIGHWAYS:避开高速。
    search(start: String | Point | LocalResultPoi, end: String | Point | LocalResultPoi, options: object)
发起检索。 start: 起点,参数可以是关键字、坐标点(自1.1版本支持)和LocalSearchPoi实例。 
end: 终点,参数可以是关键字、坐标点(自1.1版本支持)或LocalSearchPoi实例。 
    option:{startCity:String,endCity:string,waypoints:array } startCity表示是驾车查询的起点城市,可以是城市名或者城市编码,endCity表示驾车查询的终点城市,可以是城市名或者城市编码,waypoints途经点集合,最多支持10个途经点,可以是名称也可以是坐标。


JavaScript API v3.0说明:(http://lbsyun.baidu.com/cms/jsapi/reference/jsapi_reference_3_0.html#a7b22)
要想使用百度地图JavaScriptV3.0的接口,只需将

    此类用于获取驾车路线规划方案:DrivingRoute(location:Map | Point | String, opts: DrivingRouteOptions)
创建一个驾车导航实例,其中location表示检索区域,类型可为地图实例、坐标点或城市名称的字符串。当参数为地图实例时,检索位置由地图当前的中心点确定;当参数为坐标时,检索位置由该点所在位置确定;当参数为城市名称时,检索会在该城市内进行。
    DrivingRouteOptions:此类表示DrivingRoute构造函数的可选参数。
    renderOptions:此类表示搜索结果呈现的配置。它没有构造函数,但可通过对象字面量形式表示。
    map:展现结果的地图实例。当指定此参数后,搜索结果的标注、线路等均会自动添加到此地图上
    autoViewport:Boolean,检索结束后是否自动调整地图视野。此属性对LocalCity无效
    policy:此枚举类型表示驾车方案的策略配置。
BMAP_DRIVING_POLICY_DEFAULT:默认。 BMAP_DRIVING_POLICY_FIRST_HIGHWAYS:优先高速。 BMAP_DRIVING_POLICY_AVOID_HIGHWAYS:避开高速。 BMAP_DRIVING_POLICY_AVOID_CONGESTION:避开拥堵。
    search(start: Point | LocalResultPoi, end: Point | LocalResultPoi)————发起检索。 
start: 起点,参数可以是坐标点和LocalSearchPoi实例。 end: 终点,参数可以是坐标点或LocalSearchPoi实例(未提到途经点个数限制)

你可能感兴趣的:(百度地图api)