、創建基本地圖
<Map
center={{ lng, lat }}
zoom="11"
style={{ height: '39vh'}} enableScrollWheelZoom ref={this.mapRef}
>
</Map>
2、實現駕車規劃
const driving = new BMapGL.DrivingRoute(this?.mapRef?.current?.map, {
renderOptions:{map: this?.mapRef?.current?.map, autoViewport: true}
});
driving.search(start, end);
3、計算駕車時間和距離
const driving = new BMapGL.DrivingRoute(this?.mapRef?.current?.map, {
renderOptions:{map: this?.mapRef?.current?.map, autoViewport: true},
onSearchComplete: (results: any) => {
if (driving.getStatus() != BMAP_STATUS_SUCCESS){
return ;
}
const plan = results.getPlan(0);
this.setState({
planTime: plan.getDuration(true), //獲取時間
planDistance: plan.getDistance(true) //獲取距離
})
});
driving.search(start, end);
4、修改起點和終點圖標
const driving = new BMapGL.DrivingRoute(this?.mapRef?.current?.map, {
renderOptions:{map: this?.mapRef?.current?.map, autoViewport: true},
onMarkersSet: (result: any) => {
const startIcon = new BMapGL.Icon(carPng, new BMapGL.Size(69.6, 40));
const endIcon = new BMapGL.Icon(hospitalPng, new BMapGL.Size(85, 59));
result[0].marker.setIcon(startIcon);
result[0].marker.setTitle(current?.vidId ?? '起點');
result[result.length - 1].marker.setIcon(endIcon);
result[result.length - 1].marker.setTitle(current?.orgName ?? '終點');
}
});
driving.search(start, end);