## 一、前言说明
搞地图软件开发很多年,遇到过各种形形色色的需求,包括之前中东的用户,需要中东的英文地图,而且还要离线支持,后面搞了个天地图杂交谷歌离线瓦片完成的。最近又遇到个新的需求,那就是希望天地图能够支持21级别的瓦片地图,查阅了官方文档资料,天地图默认只支持到18级别的,这就难搞了,后面尝试了把缩放级别最大级别设置21,发现比例尺是可以缩放的,也就是功能是具备的,只是没有瓦片地图文件,也就是卡在在线的瓦片地图文件,天地图的服务器只提供到了18级别,这是源头的问题,那如果换成离线的呢,之前就已经把天地图离线js文件都搞定了,所有在线功能都能离线实现,所以赶紧试试离线瓦片的效果,发现也是最大只能到18级别,尽管已经放了21级别的离线瓦片地图文件,这就很奇怪了,缩放也能正常到21级别,瓦片文件也有,查看打印信息,居然没有去触发加载21级别的文件,所以上终极大法,打开离线js文件,全局搜maxZoom字样,找到了T.TileLayer = T.re.extend({等几处地方,居然写死了最大18,怪不得,原来代码中也限制了最大到18级别,而且离线瓦片的地方也有,在代码 = new T.TileLayer(的后面,写的也是18,只要把这几处全部改成21,运行一看真的有了,非常完美。
所以总结就是,天地图的本身底层是无所谓支持到多少层级的,只不过受限于瓦片的层级,在线的默认只能到18级别,离线的可以通过修改对应js文件来实现到更大的级别。
为什么有这个需求?因为无人机行业的兴起,现在无人机移动的时候,如果是18级别,移动个几米,看不清楚很大的变化,如果在21级别,那就很明显了,精度高多了。
## 二、效果图
## 三、代码使用
1. 将core_map(地图组件)/core_webview(浏览器组件)这两个组件目录拷贝到你的项目目录,并在pro中填写引入代码加入到你的项目中。$$PWD/../表示上级目录。
```cpp
include ($$PWD/../core_map/core_map.pri)
include ($$PWD/../core_webview/core_webview.pri)
```
2. 在pro中启用地图内核,比如百度地图内核对应需要在pro文件中增加一行定义DEFINES += baidux,天地图内核对应 DEFINES += tianx。如果是vsqt环境,添加的位置大概在属性-》配置属性-》C/C++-》预处理器。
3. 引入头文件。
```cpp
#include "webview.h"
#include "maphelper.h"
#include "mapobjbase.h"
```
4. 新建一个窗体,上面放一个布局,推荐用表格布局 gridlayout,可以放多个浏览器控件。
5. 实例化浏览器类和地图类。
```cpp
//实例化浏览器控件
WebView *webView = new WebView(this);
//加入到布局
webView->setLayout(ui->gridLayout);
//实例化地图类/参数2表示何种地图内核/你用的哪一种就填哪一种/必须正确
MapObjBase *mapObj = MapHelper::getMapObj(this, MapCore_Tian);
//传入网页控件用于执行函数
mapObj->setWebView(webView);
//直接加载地图
mapObj->load();
//异步加载地图
//QMetaObject::invokeMethod(mapObj, "load", Qt::QueuedConnection);
```
6. 所有地图相关的函数接口在MapObjBase类中,可以打开mapobjbase.h查看具体说明。
7. 地图中大部分的功能都是通过执行js函数来触发,比如添加标注、添加折线图等。这些必须严格按照提供的js函数名称和参数来执行。对应示例都提供了相关的调用方法。
8. 部分函数接口。
```cpp
QString js;
//设置地图级别(值越大放大/越小缩小)
js = "setZoom(9)";
//街道图卫星图切换(0-街道图/1-卫星图/2-混合图)
js = "setMapType(1)";
//添加一个标记(北京那边)
js = QString("addMarker('测试点', '测试地址', '', '', 100, '%1', 2)").arg("116.475836,40.251114");
//最终通过浏览器控件执行
webView->runJs(js);
```
9. 浏览器组件使用示例。
```cpp
//实例化浏览器控件
WebView *webView = new WebView(this);
//加入到布局
webView->setLayout(ui->verticalLayout);
//打开网址
webView->load("https://www.baidu.com", "", "");
```
10. 特别强调,浏览器控件的加载,会自动根据布局的大小调整自己的大小,如果窗体还没显示就调用了load,那么很可能地图出不来,原因是因为窗体没显示的时候,Qt中所有控件的尺寸都是不确定的,只有显示后才是确定的,所以一定要显示后再去加载地图。这种现象主要发生在需要主动调整浏览器控件尺寸的浏览器控件中,比如miniblink或者cef,如果是webkit或者webengine就不需要。
```cpp
int main(int argc, char *argv[])
{
QApplication a(argc, argv);