Baidu MapVGL点聚合 设置点权重

2024-01-19 22:04

本文主要是介绍Baidu MapVGL点聚合 设置点权重,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

百度的聚合图层只能根据点数聚合,不能根据权重展示聚合结果。本次修改文件是:**mapvgl.min.js**
  • 搜索源码,找到类似的下方代码。_w为本次改动(定义和使用两处改动)
function g(a, c) {let _w = a.geometry.weight?a.geometry.weight:1;a = a.geometry.coordinates;return {x: a[0] / 360 + .5,y: n(a[1]),zoom: Infinity,index: c,parentId: -1,weight:_w}
}
  • 修改函数prototype._cluster:下文调用属性weight的地方为本次修改点
w.prototype._cluster = function(a, c) {var b = [], d = this.options, f = d.reduce, h = d.minPoints;d = d.radius / (d.extent * Math.pow(2, c));for (var g = 0; g < a.length; g++) {var k = a[g];if (!(k.zoom <= c)) {k.zoom = c;for (var l = this.trees[c + 1], m = l.within(k.x, k.y, d), p = k.numPoints || k.weight , n = p, q = 0, r = m; q < r.length; q += 1) {var t = l.points[r[q]];t.zoom > c && (n += t.numPoints || t.weight)}if (n >= h) {q = k.x * p;r = k.y * p;p = f && 1 < p ? this._map(k, !0) : null;t = (g << 5) + (c + 1) + this.points.length;for (var v = 0; v < m.length; v += 1) {var u = l.points[m[v]];if (!(u.zoom <= c)) {u.zoom = c;var w = u.numPoints || u.weight;q += u.x * w;r += u.y * w;u.parentId = t;f && (p || (p = this._map(k, !0)),f(p, this._map(u)))}}k.parentId = t;b.push({x: q / n,y: r / n,zoom: Infinity,id: t,parentId: -1,numPoints: n,properties: p})} else if (b.push(k),1 < n)for (k = 0,n = m; k < n.length; k += 1)m = l.points[n[k]],m.zoom <= c || (m.zoom = c,b.push(m))}}return b
}
  • HTML定义地图点时,增加权重字段属性:weight 即可
// 构造数据
while (randomCount--) {var cityCenter = mapv.utilCityCenter.getCenterByCityName(citys[parseInt(Math.random() * citys.length, 10)]);data.push({geometry: {type: 'Point',coordinates: [cityCenter.lng - 2 + Math.random() * 4, cityCenter.lat - 2 + Math.random() * 4],weight: 3},properties: {icon: ['images/marker.png','images/icons/icon-accident.png','images/icons/icon-location.png','images/icons/icon-airplane.png'][randomCount % 4],width: randomCount % 2 === 0 ? 100 / 4 : 30,height: randomCount % 2 === 0 ? 153 / 4 : 30}});
}

这篇关于Baidu MapVGL点聚合 设置点权重的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/623835

相关文章

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Ubuntu中Nginx虚拟主机设置的项目实践

《Ubuntu中Nginx虚拟主机设置的项目实践》通过配置虚拟主机,可以在同一台服务器上运行多个独立的网站,本文主要介绍了Ubuntu中Nginx虚拟主机设置的项目实践,具有一定的参考价值,感兴趣的可... 目录简介安装 Nginx创建虚拟主机1. 创建网站目录2. 创建默认索引文件3. 配置 Nginx4

如何关闭 Mac 触发角功能或设置修饰键? mac电脑防止误触设置技巧

《如何关闭Mac触发角功能或设置修饰键?mac电脑防止误触设置技巧》从Windows换到iOS大半年来,触发角是我觉得值得吹爆的MacBook效率神器,成为一大说服理由,下面我们就来看看mac电... MAC 的「触发角」功能虽然提高了效率,但过于灵敏也让不少用户感到头疼。特别是在关键时刻,一不小心就可能触

Nginx配置系统服务&设置环境变量方式

《Nginx配置系统服务&设置环境变量方式》本文介绍了如何将Nginx配置为系统服务并设置环境变量,以便更方便地对Nginx进行操作,通过配置系统服务,可以使用系统命令来启动、停止或重新加载Nginx... 目录1.Nginx操作问题2.配置系统服android务3.设置环境变量总结1.Nginx操作问题

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

前端 CSS 动态设置样式::class、:style 等技巧(推荐)

《前端CSS动态设置样式::class、:style等技巧(推荐)》:本文主要介绍了Vue.js中动态绑定类名和内联样式的两种方法:对象语法和数组语法,通过对象语法,可以根据条件动态切换类名或样式;通过数组语法,可以同时绑定多个类名或样式,此外,还可以结合计算属性来生成复杂的类名或样式对象,详细内容请阅读本文,希望能对你有所帮助...