在Qt中添加显示百度地图的View

在Qt中添加显示百度地图view

1,通过百度地图API获取html代码

百度地图API网址链接http://api.map.baidu.com/lbsapi/creatmap/
进去后查找武汉大学,获取以武汉大学为中心的地图,随后根据个人设置地图格式或添加标注,最后获取html代码。新建一个html文件map.html,把刚获取的代码粘贴进去。

2,使用webengine在Qt中显示

Qt5改版之后,取消了Qwebview模块,在新版Qt中,若想知道其包含了那些组件并了解其用法,可以在菜单栏帮助-索引里查找。
导入头文件:

#include <QWebEngineView>
#include <QUrl>

在.pro文件里添加库:

QT += webenginewidgets

在WenEngineView里获取并显示百度地图的代码如下:

QWebEngineView *view=new QWebEngineView(parentWidget());  //新建WebEngineView
view->load(QUrl("file:///home/nyh00/build-map1-Desktop_Qt_5_9_2_GCC_64bit-Debug/map.html"));//通过map.html的路径把其load进该view里
view->show();//显示

效果图如下所示:
在这里插入图片描述

不弹出新窗口,在主窗口中显示

在主窗口拖入一个GraphicsView,并将它提升为QwebEngineView,如下图所示:

在这里插入图片描述
加载并显示的代码如下所示:

ui->graphicsView->load(QUrl("file:///home/nyh00/build-map1-Desktop_Qt_5_9_2_GCC_64bit-Debug/map.html"));
ui->graphicsView->show();

效果图如下:

在这里插入图片描述

给获取到的百度地图API添加定位标记

在html的创建地图函数里,添加以下两行代码:

var marker=new BMap.Marker(point); //创建含有定位信息的标注
map.addOverlay(marker);  //将标注添加显示在地图上

即:在这里插入图片描述地图显示效果如图所示:
在这里插入图片描述

  • 7
    点赞
  • 38
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要实现Qt的离线百度地图,可以参照以下步骤: 1.首先下载离线百度地图的数据,可以从百度官方网站或其他第三方网站获取。这些数据通常以瓦片(tile)的形式呈现,并且按照地理坐标系统进行存储。 2.在Qt创建地图窗口,可以使用QGraphicsView或QOpenGLWidget等控件来显示地图。根据需要将其放置在主窗口。 3.在Qt创建一个自定义的类来加载离线地图数据,并将其显示在地图窗口。可以使用QImage或QPixmap来加载地图瓦片,并使用QPainter绘制地图。 4.根据用户的操作,可以实现地图的缩放、平移等功能。在地图窗口使用鼠标事件和键盘事件来处理用户的交互操作,并在自定义的类更新地图的显示。 5.为了提高地图的加载速度和性能,可以使用缓存机制来存储已经加载过的地图瓦片,避免重复加载。 6.如果需要在地图上显示标记、路径等信息,可以使用Qt的图形元素类来实现。例如,使用QGraphicsItem来绘制标记点,使用QGraphicsPathItem来绘制路径等。 7.在加载离线百度地图时,需要根据地图瓦片的坐标系进行转换。百度地图采用的是墨卡托投影(Mercator Projection)坐标系,而Qt默认使用的是经纬度坐标系。可以通过相应的坐标转换算法来完成转换。 8.最后,根据具体需求,可以进一步定制和优化离线百度地图的功能和性能,例如添加地图切换、地理位置搜索等功能。 总之,通过使用Qt的图形和事件处理功能,结合合适的地图数据和坐标转换算法,就可以实现离线百度地图显示交互
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值