百度地图在jsp页面加载大量轨迹导致地图卡顿

原画线方式:

//存储大量点轨迹json数组:historyPathList
for(var i=0;i<historyPathList.length-1;i++){   
       drawColorLine(i,color,4,historyPathList);
   }
//显示原始路线
function drawColorLine(i,color,weitht,list){
    var polyline = new BMap.Polyline([
        new BMap.Point(list[i].Lng,list[i].Lat),//起始点的经纬度
        new BMap.Point(list[i+1].Lng,list[i+1].Lat)//终点的经纬度
    ], {strokeColor:color,//设置颜色
        strokeWeight:weitht, //宽度
        strokeOpacity:1});//透明度
    map.addOverlay(polyline);
}
这样写会多加很多不必要的点,而且对API调用了过多次数,会影响性能。

改进:

 var polylinePointsArray = [];
   for(var i=0;i<historyPathList.length;i++){
       polylinePointsArray[i] = new BMap.Point(historyPathList[i].Lng,historyPathList[i].Lat);
   }
   var polyline = new BMap.Polyline(polylinePointsArray, {strokeColor:"green", strokeWeight:4, strokeOpacity:1})
   map.addOverlay(polyline);

转载于:https://www.cnblogs.com/qiantao/p/11497454.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值