百度地图在jsp页面加载大量轨迹导致地图卡顿
2024-10-20 16:35:54
原画线方式:
//存储大量点轨迹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})
polyline.id = 123456;
map.addOverlay(polyline);
备注:Polyline是个覆盖物对象,可以和其他对象一样自定义属性的,比如在声明以后设置polyline的id属性直接用polyline.id=content就可以了。再例如:polyline.name
或 polyline.length等。覆盖物对象可以根据自己的需求自定义任何属性,取值的时候只需按这个字段取就可以了。
最新文章
- jira的插件开发流程实践
- 小明的密码-初级DP解法
- iOS设计 - 一款APP从设计稿到切图过程概述
- js中列表控件排序箭头,在wke中不支持的解决办法
- How do I set the default schema for a user in MySQL
- js 滚动加载iframe框中内容
- 字符串和json之间的互相转化
- android webview 漏洞背后的节操
- 自己手写简约实用的Jquery tabs插件(基于bootstrap环境)
- leetcode解决问题的方法||Integer to Roman问题
- 使用Eclipse创建模板并格式化代码
- android线程与线程池-----AsyncTask(一)《android开发艺术与探索》
- poj2924---高斯求和
- [Windows Azure] 使用 Windows Azure 快速搭建 Redis 服务器
- Hadoop概论
- php中的冒泡排序算法
- hadoop生态圈列式存储系统--kudu
- oh-my-zsh: bracketed-paste-magic:zle:47: not enough arguments for -U
- Mysql 全文搜索 Match Against用法
- Python 2、8、10、16进制间的转换