Qt编写地图综合应用27-点聚合
一、前言
在地图上查询结果通常以标记点的形式展现,但是如果标记点较多,不仅会大大增加客户端的渲染时间,让客户端变得很卡,而且会让人产生密集恐惧症。为了解决这一问题,我们需要一种手段能在用户有限的可视区域范围内,利用最小的区域展示出最全面的信息,而又不产生重叠覆盖。这就是点聚合功能的由来,百度地图内置类点聚合的功能,在项目初期可能只有个位数的设备需要在地图上显示,随着设备数量的增多,会发现标注点不仅密密麻麻而且变得越发卡顿,这样就需要有个合并的功能,就某个区域的点都合并到一个点图标展示,当用户单击该合并后的点以后,再去展开具体的详细的标注点,监控行业、电力行业都用得非常频繁。
最简单的设置点聚合的方式是将传入标注点坐标集合,转换生成标注点对象数组,再生成的时候可以设置点的名称、经纬度、其他信息等,然后实例化一个MarkerClusterer对象,再将生成的标注点对象数组传给这个对象即可。具体的点聚合算法我们也无需知道,基本上都是比较智能的,当我们缩小地图范围时候可以看到多个集中的标注点消失了,变成了统一的一个点聚合图标,单击此图标会自动展开下属的所有标注点,一般建议在设置点聚合的时候要规划好,哪些标注点属于哪个点聚合,尽量一个区域内的放在一起。
二、功能特点
- 同时支持在线地图和离线地图两种模式。
- 同时支持webkit内核、webengine内核、miniblink内核、IE内核。
- 支持设置多个标注点,信息包括名称、地址、经纬度。
- 可设置地图是否可单击、拖动、鼠标滚轮缩放。
- 可设置协议版本、秘钥、主题样式、中心坐标、中心城市、地理编码位置等。
- 可设置地图缩放比例和级别,缩略图、比例尺、路况信息等控件的可见。
- 支持地图交互,比如鼠标按下获取对应位置的经纬度。
- 支持查询路线,可设置起点位置、终点位置、路线模式、路线方式、路线方案(最少时间、最少换乘、最少步行、不乘地铁、最短距离、避开高速)。
- 可显示点线面工具,可直接在地图上划线、点、矩形、圆形等。
- 可设置行政区划,指定某个城市区域绘制图层,在线地图自动输出行政区划边界点集合到js文件给离线地图使用。
- 可静态或者动态添加多个覆盖物。支持点、折线、多边形、矩形、圆形、弧线、点聚合等。
- 提供函数接口处理经纬度解析成地址和地址解析成经纬度坐标。
- 提供的demo直接可以单独选点执行对应的处理比如路线查询。
- 可以拿到路线查询到的点坐标信息集合,比如用于机器人坐标导航等。
- 封装了丰富的函数比如删除指定点和所有点,删除指定覆盖物和所有覆盖物等。
- 标注点弹框信息可以自定义内容,标准html格式。
- 标注点单击事件可选 0-不处理 1-自己弹框 2-发送信号。
- 标注点可设置动画效果 0-不处理 1-跳动 2-坠落
- 标注点可设置本地图片文件等。
- 函数接口友好和统一,使用简单方便,就一个类。
- 支持js动态交互添加点、删除点、清空点、重置点,不需要刷新页面。
- 支持任意Qt版本、任意系统、任意编译器。
三、体验地址
- 体验地址:https://pan.baidu.com/s/1ZxG-oyUKe286LPMPxOrO2A 提取码:o05q 文件名:bin_map.zip
- 国内站点:https://gitee.com/feiyangqingyun
- 国际站点:https://github.com/feiyangqingyun
- 个人主页:https://blog.csdn.net/feiyangqingyun
- 知乎主页:https://www.zhihu.com/people/feiyangqingyun/
四、效果图
五、相关代码
void MapBaiDu::getPoints(QStringList &list)
{
//通用多个点坐标转换成 BMap.Point 对象
//坐标格式 121.414,31.1828|121.414,31.1838|121.416,31.1838
list << QString(" function getPoints(points) {");
list << QString(" var pts = []");
list << QString(" var listPoint = points.split('|');");
list << QString(" var len = listPoint.length");
list << QString(" for (var i = 0; i < len; i++) {");
list << QString(" var list = listPoint[i].split(',');");
list << QString(" var pot = new BMap.Point(list[0], list[1]);");
list << QString(" pts.push(pot);");
list << QString(" }");
list << QString(" return pts;");
list << QString(" }");
}
void MapBaiDu::getMarkers(QStringList &list)
{
//通用多个点坐标转换成 BMap.Marker 对象
//坐标格式 121.414,31.1828|121.414,31.1838|121.416,31.1838
list << QString(" function getMarkers(points) {");
list << QString(" var markers = []");
list << QString(" var listPoint = points.split('|');");
list << QString(" var len = listPoint.length");
list << QString(" for (var i = 0; i < len; i++) {");
list << QString(" var list = listPoint[i].split(',');");
list << QString(" var pot = new BMap.Point(list[0], list[1]);");
list << QString(" var marker = new BMap.Marker(pot);");
list << QString(" markers.push(marker);");
list << QString(" }");
list << QString(" return markers;");
list << QString(" }");
}
void MapBaiDu::getBounds(QStringList &list)
{
//获取可视区域经纬度 bssw=左下角 bsne=右上角 bsce=中心
list << QString(" function getBounds() {");
list << QString(" var bs = map.getBounds();");
list << QString(" var bssw = bs.getSouthWest();");
list << QString(" var bsne = bs.getNorthEast();");
list << QString(" var bsce = bs.getCenter();");
list << QString(" var rect = bssw.lng + ',' + bssw.lat + ',' + bsne.lng + ',' + bsne.lat + ',' + bsce.lng + ',' + bsce.lat + ',' + map.getZoom();");
//信号发出去
list << QString(" receiveData('bounds', rect);");
list << QString(" }");
}
void MapBaiDu::getBoundary(QStringList &list)
{
//获取边界点集合
list << QString(" function getBoundary() {");
list << QString(" for (var i = 0; i < polygons.length; i++) {");
list << QString(" var polyline = polygons[i];");
list << QString(" var pts = polyline.getPath();");
list << QString(" var result = '';");
list << QString(" for (var j = 0; j < pts.length; j++) {");
list << QString(" result += pts[j].lng + ',' + pts[j].lat + ';';");
list << QString(" }");
list << QString(" receiveData('newboundary', result);");
list << QString(" }");
list << QString(" }");
}
void MapBaiDu::getZoom(QStringList &list)
{
//获取当前地图缩放级别
list << QString(" function getZoom() {");
list << QString(" var zoom = map.getZoom();");
list << QString(" receiveData('zoom', zoom);");
list << QString(" }");
}
void MapBaiDu::addMarkerClusterer(QStringList &list)
{
//动态添加点聚合
list << QString(" function addMarkerClusterer(points) {");
list << QString(" var markers = getMarkers(points);");
//最简单的用法,生成一个marker数组,然后调用markerClusterer类即可
list << QString(" var markerClusterer = new BMapLib.MarkerClusterer(map, {markers:markers});");
list << QString(" }");
}
Qt编写地图综合应用27-点聚合的更多相关文章
- Qt编写的开源帖子集合(懒人专用)
回顾自己学习Qt以来九年了,在这九年多时间里面,从本论坛学习不到不少的东西,今天特意整了一下自己开源过的资源的帖子,整理一起方便大家直接跳转下载,不统计不知道,一统计吓一跳,不知不觉开源了这么多代码, ...
- Qt编写项目作品大全(自定义控件+输入法+大屏电子看板+视频监控+楼宇对讲+气体安全等)
一.自定义控件大全 (一).控件介绍 超过160个精美控件,涵盖了各种仪表盘.进度条.进度球.指南针.曲线图.标尺.温度计.导航条.导航栏,flatui.高亮按钮.滑动选择器.农历等.远超qwt集成的 ...
- Qt编写安防视频监控系统(界面很漂亮)
一.前言 视频监控系统在整个安防领域,已经做到了烂大街的程序,全国起码几百家公司做过类似的系统,当然这一方面的需求量也是非常旺盛的,各种定制化的需求越来越多,尤其是这几年借着人脸识别的东风,发展更加迅 ...
- Qt编写自定义控件二动画按钮
现在的web发展越来越快,很多流行的布局样式,都是从web开始的,写惯了Qt widgets 项目,很多时候想改进一下现有的人机交互,尤其是在现有的按钮上加一些动画的效果,例如鼠标移上去变大,移开还原 ...
- Qt编写自定义控件11-设备防区按钮控件
前言 在很多项目应用中,需要根据数据动态生成对象显示在地图上,比如地图标注,同时还需要可拖动对象到指定位置显示,能有多种状态指示,安防领域一般用来表示防区或者设备,可以直接显示防区号,有多种状态颜色指 ...
- Qt编写数据可视化大屏界面电子看板系统
一.前言 目前大屏大数据可视化UI这块非常火,趁热也用Qt来实现一个,Qt这个一站式超大型GUI超市,没有什么他做不了的,大屏电子看板当然也不在话下,有了QSS和QPainter这两个无敌的工具组合, ...
- Qt编写安防视频监控系统18-云台控制
一.前言 云台控制是视频监控系统中必备的一个功能,对球机进行上下左右的移动,还有焦距的控制,其实核心就是控制XYZ三个坐标轴,为了开发这个模块,特意研究了各种云台控制的方法和开源库比如soap,有些厂 ...
- Qt编写数据可视化大屏界面电子看板13-基础版
一.前言 之前发布的Qt编写的可视化大屏电子看板系统,很多开发者比较感兴趣,也收到了很多反馈意见,纵观市面上的大屏系统,基本上都是B/S结构的web版本,需要在后台进行自定义配置模块,绑定数据源等,其 ...
- Qt编写气体安全管理系统10-数据导出
一.前言 数据导出一般指导出到excel表格,可能有部分用户还需要导出到pdf,因为pdf基本上不可编辑,防止用户重新编辑导出的数据,excel可能绝大部分用过电脑的人都知道,广为流行,主要就是微软的 ...
- Qt编写自定义控件61-通用移动
一.前言 通用移动类,目标就是为了实现放入任意的控件以后,支持鼠标拖动,在容器中或者父类中拖动,这个应用场景非常多,比如在地图上放置的设备,需要用户自行按下拖动到指定的合适的位置,然后保存设备的位置坐 ...
随机推荐
- 15 Transformer 框架概述
博客配套视频链接: https://space.bilibili.com/383551518?spm_id_from=333.1007.0.0 b 站直接看 配套 github 链接:https:// ...
- Nuxt.js 应用中的 app:templates 事件钩子详解
title: Nuxt.js 应用中的 app:templates 事件钩子详解 date: 2024/10/18 updated: 2024/10/18 author: cmdragon excer ...
- 7000元才有的高性能显卡配置,ToDesk云电脑只要不到1块!
高性能显卡不仅仅是游戏玩家的刚需,也是设计师.工程师和剪辑师等专业人士的必备电脑配置.对于追求极致图形处理能力的用户来说,7000元的显卡预算并不罕见.然而,这样的花费对于大多数个人用户和小型企业来说 ...
- 配置和使用nvm免安装版本(nvm-noinstall.zip)
配置和使用nvm免安装版本(nvm-noinstall.zip) NVM(Node Version Manager)是一个用于管理多个Node.js版本的命令行工具一下分几个步骤说明如何配置和使用nv ...
- 2.11 Linux四种远程管理协议
提到远程管理,通常指的是远程管理服务器,而非个人计算机.个人计算机可以随时拿来用,服务器通常放置在机房中,用户无法直接接触到服务器硬件,只能采用远程管理的方式. 远程管理,实际上就是计算机(服务器)之 ...
- 2.10 破解密码这么简单,Linux是安全的操作系统吗?
很多人看到系统修复模式这节内容时,都会有所感慨:Linux 的密码破解太容易了,这样的操作系统还安全吗?Linux 不是以安全性著称的吗? 图 1 密码安全 本节,我们结合图 1 解释一下类似的问题. ...
- .NET Core 委托底层原理浅谈
简介 .NET通过委托来提供回调函数机制,与C/C++不同的是,委托确保回调是类型安全,且允许多播委托.并支持调用静态/实例方法. 简单来说,C++的函数指针有如下功能限制,委托作为C#中的上位替代, ...
- Abp vNext 入门到放弃系列
文章目录 1.模块介绍 2.模块加载机制 3.依赖注入 4.AutoMapper-- 待定 5.本地化--待定 6.模型验证--待定 7.异常处理--待定 8.缓存 9.动态代理和拦截 10.分布式锁 ...
- Stratum挖矿协议&XMR挖矿流量分析
目录 前言 区块链和挖矿相关概念 挖矿木马 挖矿协议Stratum Stratum工作过程 XMR挖矿流量分析 环境搭建 流量分析 总结 前言 之前参与了一个关于"挖矿行为检测"的 ...
- 【网关开发】Openresty使用cosocket API 发送http与tcp网络请求
背景 为网关提供健康检查功能时需要对节点发送http或者tcp探活请求.Openresty 提供cosocket来处理非阻塞IO. 实现 跟工程结合在一起,这里简单拼接数据结构 local funct ...