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

相关文章

idea设置快捷键风格方式

《idea设置快捷键风格方式》在IntelliJIDEA中设置快捷键风格,打开IDEA,进入设置页面,选择Keymap,从Keymaps下拉列表中选择或复制想要的快捷键风格,点击Apply和OK即可使... 目录idea设www.chinasem.cn置快捷键风格按照以下步骤进行总结idea设置快捷键pyth

MyBatis配置文件中最常用的设置

《MyBatis配置文件中最常用的设置》文章主要介绍了MyBatis配置的优化方法,包括引用外部的properties配置文件、配置外置以实现环境解耦、配置文件中最常用的6个核心设置以及三种常用的Ma... 目录MyBATis配置优化mybatis的配置中引用外部的propertis配置文件⚠️ 注意事项X

Java JAR 启动内存参数配置指南(从基础设置到性能优化)

《JavaJAR启动内存参数配置指南(从基础设置到性能优化)》在启动Java可执行JAR文件时,合理配置JVM内存参数是保障应用稳定性和性能的关键,本文将系统讲解如何通过命令行参数、环境变量等方式... 目录一、核心内存参数详解1.1 堆内存配置1.2 元空间配置(MetASPace)1.3 线程栈配置1.

C#借助Spire.XLS for .NET实现Excel工作表自动化样式设置

《C#借助Spire.XLSfor.NET实现Excel工作表自动化样式设置》作为C#开发者,我们经常需要处理Excel文件,本文将深入探讨如何利用C#代码,借助强大的Spire.XLSfor.N... 目录为什么需要自动化工作表样式使用 Spire.XLS for .NET 实现工作表整体样式设置样式配置

Java实现为PDF设置背景色和背景图片

《Java实现为PDF设置背景色和背景图片》在日常的文档处理中,PDF格式因其稳定性和跨平台兼容性而广受欢迎,本文将深入探讨如何利用Spire.PDFforJava库,以简洁高效的方式为你的PDF文档... 目录库介绍与安装步骤Java 给 PDF 设置背景颜色Java 给 PDF 设置背景图片总结在日常的

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

Java利用Spire.XLS for Java设置Excel表格边框

《Java利用Spire.XLSforJava设置Excel表格边框》在日常的业务报表和数据处理中,Excel表格的美观性和可读性至关重要,本文将深入探讨如何利用Spire.XLSforJava库... 目录Spire.XLS for Java 简介与安装Maven 依赖配置手动安装 JAR 包核心API介

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

python设置环境变量路径实现过程

《python设置环境变量路径实现过程》本文介绍设置Python路径的多种方法:临时设置(Windows用`set`,Linux/macOS用`export`)、永久设置(系统属性或shell配置文件... 目录设置python路径的方法临时设置环境变量(适用于当前会话)永久设置环境变量(Windows系统