Qt下使用QWebEngineView实现百度地图的显示

文章目录

  • 前言
  • 一、前期准备
  • 二、HTML文件创建
  • 三、实现步骤
  • 四、示例完整代码
  • 总结


前言

本文讲述了在Qt下使用QWebEngineView来加载HTML页面,实现该需求是需要连接网络的,这里进行了百度地图的嵌入显示,主要内容将结合相应的示例进行讲解,以便大家学习,如有错误之处,欢迎大家批评指正。

项目效果
请添加图片描述


提示:以下是本篇文章正文内容,下面案例可供参考

一、前期准备

下面是我的示例相关信息:

Qt构建环境:Qt5.14_MSVC2017_64bit
地图文件:baiduMap.html
交互工具:qwebchannel.js

这里的构建环境使用的是MSVC编译器,这样才能使用qwebengineview,在项目的pro文件中需要添加下列代码:

QT += webenginewidgets   #只有用msvc编译器才能使用qwebengineview

Qt与JS交互工具qwebchannel.js在Qt安装文件夹内直接找到,后面需要将地图文件和交互工具放到项目生成的exe同级目录下
请添加图片描述

二、HTML文件创建

这里与Qt进行交互的是百度地图API,并且要生成一个html类型的地图文件,
首先打开百度地图开放平台->进行注册登录->选择控制台->应用管理->我的应用->创建应用(如下图)->提交后获取应用AK(后面生成的HTML文件需要使用)
请添加图片描述
接下来可以在百度地图开放平台示例中心来生成地图文件,下面是我的示例的baiduMap.html文件内容,其中也有与Qt交互的代码介绍,注意其中的“您的AK密钥”要修改为上一步获取的应用AK哦

<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
<title>CanvasLayer</title>
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=您的AK密钥"></script>
<style type="text/css">
body, html,#container {width: 100%;height: 100%;overflow: hidden;margin:0;font-family:"微软雅黑";}</style>
</head>
<body>
    <div id="container"></div>     <!-- 创建一个地图容器元素container -->
</body>
</html>
<script src="qwebchannel.js"></script>
<script type="text/javascript">
	//百度地图开放平台示例中心
	//https://lbsyun.baidu.com/jsdemo.htm#uWalkNavPanel
	
	//创建地图实例
    var map = new BMap.Map("container");
	
	//初始化地图,设置中心点坐标和地图级别
	map.centerAndZoom(new BMap.Point(116.404,39.915),11);   //根据经纬度来设置中心点
	//map.centerAndZoom('北京市',11);   //根据城市名来设置中心点
	
	//开启鼠标滚轮缩放
    map.enableScrollWheelZoom(true)
	
	//添加平移缩放控件
    map.addControl(new BMap.NavigationControl());
	
	//添加缩略地图
	map.addControl(new BMap.OverviewMapControl());

	//添加比例尺控件
	map.addControl(new BMap.ScaleControl());

	//添加地图类型控件
	map.addControl(new BMap.MapTypeControl());
	
	//还可以添加自定义控件,参考下面这篇文章
	//JS调用百度地图——添加基础控件
	//https://blog.csdn.net/weixin_43445778/article/details/105481424
	
	/**********************JS****************************/
	//设置经纬度
	function setPoint(lng,lat)
	{
		map.setCenter(new BMap.Point(lng,lat));
	}
	
	/**********************QT****************************/
	//qt交互注册,myBridge相当于示例中的m_bridge
    new QWebChannel(qt.webChannelTransport,function(channel) 
	{
        myBridge = channel.objects.bridge;
    });
	
	//监听地图的单击事件
    map.addEventListener("click",function(e)
	{
        myBridge.getPoint(e.point.lng,e.point.lat);
    });
</script>

这里需要学习一下百度地图JavaScript API的使用,可以参考这篇文章:百度地图API基本使用(一)

三、实现步骤

下面引用内容来自这篇文章,创建工程的详细步骤也可以进行参考:Qt嵌入百度地图API的详细流程与常见问题

基本思路:
1.在界面中要创建网页容器QWebEngineView类,这是Qt提供的继承于QWidget类的一个窗口,使用时在.pro文件中要添加QT += webenginewidgets;
2.创建Qt与Html的连接通道QWebChannel,通过该通道可以实现主程序与网页之间的通信。当然,通道的建立是双方面的,即主程序和网页中都要进行相关操作;
3.通道建立完成即可实现主程序与网页之间的函数相互调用,并由此实现参数传递

这里是我的示例的初始化代码,其中的MyBridge类作为主程序和网页之间的"桥梁",并通过信号与槽实现从网页接收数据:

void MainWindow::initWidget()
{
    //创建MyBridge对象用于与JS交互
    m_bridge = new MyBridge();

    //将单个对象注册到QWebChannel,注册名为bridge
    QWebChannel *channel = new QWebChannel(this);
    channel->registerObject(QString("bridge"),(QObject*)m_bridge);
    ui->wg_map->page()->setWebChannel(channel);

    //加载HTML文件
    QString htmlPath = QCoreApplication::applicationDirPath() + "/baiduMap.html";
    ui->wg_map->page()->load(QUrl(htmlPath));

    //关联信号和槽函数
    connect(m_bridge,&MyBridge::signal_showDate,this,&MainWindow::slot_showDate);
}

发送按钮槽函数中通过runJavaScript函数实现地图上指定经纬度的跳转:

void MainWindow::on_pb_send_clicked()
{
    //调用HTML的setPoint函数
    QString cmd = QString("setPoint(%1,%2)").arg(ui->le_longitude->text()).arg(ui->le_latitude->text());
    ui->wg_map->page()->runJavaScript(cmd);
}

四、示例完整代码

1.MyMap.pro

QT += core gui
QT += webenginewidgets   #只有用msvc编译器才能使用qwebengineview

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

CONFIG += c++11

DEFINES += QT_DEPRECATED_WARNINGS

SOURCES += \
    main.cpp \
    mainwindow.cpp \
    mybridge.cpp

HEADERS += \
    mainwindow.h \
    mybridge.h

FORMS += \
    mainwindow.ui

# Default rules for deployment.
qnx: target.path = /tmp/$${TARGET}/bin
else: unix:!android: target.path = /opt/$${TARGET}/bin
!isEmpty(target.path): INSTALLS += target

2.mybridge.h

#ifndef MYBRIDGE_H
#define MYBRIDGE_H

#include<QObject>
#include<QDebug>

class MyBridge : public QObject
{
   Q_OBJECT
public:
    MyBridge();

signals:
    void signal_showDate(QString lng,QString lat);

public slots:
    void getPoint(QString lng,QString lat);

};
#endif // MYBRIDGE_H

3.mybridge.cpp

#include "mybridge.h"

MyBridge::MyBridge()
{

}

void MyBridge::getPoint(QString lng,QString lat)
{
    emit signal_showDate(lng,lat);
}

4.mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QWebEngineView>
#include <QWebChannel>
#include "mybridge.h"

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

    void initWidget();

private slots:
    void slot_showDate(QString longitude,QString latitude);

    void on_pb_send_clicked();

private:
    Ui::MainWindow *ui;

    MyBridge *m_bridge;

};
#endif // MAINWINDOW_H

5.mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    this->initWidget();
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::initWidget()
{
    //创建MyBridge对象用于与JS交互
    m_bridge = new MyBridge();

    //将单个对象注册到QWebChannel,注册名为bridge
    QWebChannel *channel = new QWebChannel(this);
    channel->registerObject(QString("bridge"),(QObject*)m_bridge);
    ui->wg_map->page()->setWebChannel(channel);

    //加载HTML文件
    QString htmlPath = QCoreApplication::applicationDirPath() + "/baiduMap.html";
    ui->wg_map->page()->load(QUrl(htmlPath));

    //关联信号和槽函数
    connect(m_bridge,&MyBridge::signal_showDate,this,&MainWindow::slot_showDate);
}

void MainWindow::slot_showDate(QString longitude,QString latitude)
{
    ui->le_longitude->setText(longitude);
    ui->le_latitude->setText(latitude);
}

void MainWindow::on_pb_send_clicked()
{
    //调用HTML的setPoint函数
    QString cmd = QString("setPoint(%1,%2)").arg(ui->le_longitude->text()).arg(ui->le_latitude->text());
    ui->wg_map->page()->runJavaScript(cmd);
}

6.mainwindow.ui
请添加图片描述

总结

通过我的示例可以看到,这里实现百度地图的显示其实是QWebEngineView与javaScript的交互调用,所以也需要掌握基本的JS语法,以及一些基础的百度地图API的使用,后续也可以实现在地图上添加标注,画出轨迹等功能,这就需要我们不断的学习啦,一起加油!


hello:
共同学习,共同进步,如果还有相关问题,可在评论区留言进行讨论。

参考文章:
Qt嵌入百度地图API的详细流程与常见问题
QWebEngineView与javaScript交互调用百度离线地图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/351377.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AWS免费套餐——云存储S3详解

文章目录 前言一、为什么选择S3二、费用估算三、创建S3云存储注册账户登录账户创建存储桶关于官网相关文档 总结 前言 不论个人还是企业&#xff0c;日常开发中经常碰到需要将文档、安装包、日志等文件数据存储到服务器的需求。往常最常用的是云服务器&#xff0c;但是仅仅承担…

批量数据之DataX数据同步

文章目录 1 DataX1.1 引言1.2 DataX 简介1.3 核心1.3.1 DataX3.0 框架设计1.3.2 DataX3.0 核心架构 1.4 使用 DataX 实现数据同步1.4.1 准备安装1.4.2 Linux 上安装 DataX 软件1.4.3 DataX 基本使用1.4.4 MySQL 数据库1.4.4.1 安装1.4.4.2 准备同步1.4.4.3 创建存储过程&#x…

C# 设置一个定时器函数

C#中&#xff0c;创建设置一个定时器&#xff0c;能够定时中断执行特定操作&#xff0c;可以用于发送心跳、正计时和倒计时等。 本文对C#的定时器简单封装一下&#xff0c;哎&#xff0c;以方便定时器的创建。 定义 using Timer System.Timers.Timer;class SetTimer {Timer …

Nginx编译安装以及负载均衡配置(Ubuntu 22.04)

目录 Nginx编译安装以及负载均衡配置 Ubuntu 22.04.1 LTS 编译安装 nginx-1.22.1 1.安装依赖包 2. 下载nginx 3. 编译安装 报错解决 解决问题2 4.安装 5启动Nginx&#xff1a; 负载均衡 负载均衡算法 轮询 加权负载均衡 ip_hash算法 算法进行配置演示 加权负载均衡 轮询 IP 哈希…

如何提高记忆力?

许多学员经常问我&#xff1a;为什么您的记忆力那么好&#xff1f;有没有什么方法&#xff0c;可以提高记忆力&#xff1f; 今天&#xff0c;我想好好聊聊这个问题。 当然&#xff0c;学习和记忆&#xff0c;是一个巨大的话题。这篇文章只是一个初探。希望能帮你打开一些视野&a…

IPoE技术汇总

在国内并没有遇到这么多的IPoE&#xff08;IP over Ethernet&#xff09;技术&#xff0c;可能也是因为我来日本多年了&#xff0c;没有接触国内的IPv4 over IPv6的技术&#xff0c;感觉国内IPv4地址紧张&#xff0c;用的传统NAT和PPPoE非常多&#xff0c;大多数设备还是建立在…

好物周刊#38:在线图片处理

https://github.com/cunyu1943/JavaPark https://yuque.com/cunyu1943 村雨遥的好物周刊&#xff0c;记录每周看到的有价值的信息&#xff0c;主要针对计算机领域&#xff0c;每周五发布。 一、项目 1. AiEditor 一个面向 AI 的下一代富文本编辑器&#xff0c;她基于 Web C…

8通液体水位检测IC/液位检测芯片/抗干扰水位检测VK36W8I SOP16/QFN16L FAE支持

产品型号&#xff1a;VK36W8I 产品品牌&#xff1a;永嘉微电/VINKA 封装形式&#xff1a;SOP16/QFN16L 工程服务&#xff0c;技术支持&#xff01; 概述 VK36W8I具有8个触摸检测通道&#xff0c;可用来检测8个点的水位。该芯片具有较高的集成度&#xff0c;仅需极少的外部组…

2024 高级前端面试题之 CSS 「精选篇」

该内容主要整理关于 CSS 的相关面试题&#xff0c;其他内容面试题请移步至 「最新最全的前端面试题集锦」 查看。 CSS模块精选篇 1. 盒模型2. BFC3. 层叠上下文4. 居中布局5. 选择器权重计算方式6. 清除浮动7. link 与 import 的区别8. CSS3的新特性9. CSS动画和过渡10. 有哪些…

目录操作(实现ls -i的功能(加一个文件类型))

1》打开目录 opendir #include <sys/types.h> #include <dirent.h> DIR *opendir(const char *name); 形参&#xff1a;name&#xff1a;要打开的目录的路径/名字 返回值&#xff1a;成功DIR *类型的目录流指针 失败&#xff1a;返回NULL 2》关闭目录 closedir #…

万界星空科技可视化数据大屏的作用

随着科技的不断发展和进步&#xff0c;当前各种数据化的设备也是如同雨后春笋般冒了出来&#xff0c;并且其可以说是给我们带来了极大的便利的。在这其中&#xff0c;数据大屏就是非常具有代表性的一个例子。 数据大屏的主要作用包括&#xff1a; 数据分析&#xff1a;数据大屏…

一些反序列化总结

1 反序列化漏洞原理 如果反序列化的内容就是那串字符串&#xff0c;是用户可以控制的&#xff08;即变量的值&#xff09;&#xff0c;且后台不正当的使用了PHP中的魔法函数&#xff0c;就会导致反序列化漏洞&#xff0c;可以执行任意命令。Java 序列化指 Java 对象转换为字节序…

插入排序和希尔排序

. 个人主页&#xff1a;晓风飞 专栏&#xff1a;数据结构|Linux|C语言 路漫漫其修远兮&#xff0c;吾将上下而求索 文章目录 插入排序基本思想&#xff1a;代码实现&#xff1b; 希尔排序基本思想&#xff1a;在这里插入图片描述多组并排优化《数据结构(C语言版)》--- 严蔚敏希…

Golang中make与new有何区别

&#x1f4d5;作者简介&#xff1a; 过去日记&#xff0c;致力于Java、GoLang,Rust等多种编程语言&#xff0c;热爱技术&#xff0c;喜欢游戏的博主。 &#x1f4d7;本文收录于go进阶系列&#xff0c;大家有兴趣的可以看一看 &#x1f4d8;相关专栏Rust初阶教程、go语言基础系…

Typora 无法导出 pdf 问题的解决

目录 问题描述 解决困难 解决方法 问题描述 Windows 下&#xff0c;以前&#xff08;Windows 11&#xff09; Typora 可以顺利较快地由 .md 导出 .pdf 文件&#xff0c;此功能当然非常实用与重要。 然而&#xff0c;有一次电脑因故重装了系统&#xff08;刷机&#xff09;…

Armv8-M的TrustZone技术之SAU寄存器总结

每个SAU寄存器是32位宽。下表显示了SAU寄存器概要。 5.1 SAU_CTRL register SAU_CTRL寄存器的特征如下图和表所示&#xff1a; 5.2 SAU_TYPE register 5.3 SAU_RNR register 5.4 SAU_RBAR register 5.5 SAU_RLAR register 5.6 SAU区域配置 当SAU启用时&#xff0c;未由已启用…

Android 基础技术——RecyclerView

笔者希望做一个系列&#xff0c;整理 Android 基础技术&#xff0c;本章是关于 RecyclerView RecyclerView 对比 ListView 的优点 Adapter 面向的是 ViewHolder 不是 View, 可以省略 convertView.setTag 和 getTag 这些步骤可以设置布局管理器&#xff1a;竖向、横向、瀑布流方…

RUST笔记:candle使用基础

candle介绍 candle是huggingface开源的Rust的极简 ML 框架。 candle-矩阵乘法示例 cargo new myapp cd myapp cargo add --git https://github.com/huggingface/candle.git candle-core cargo build # 测试&#xff0c;或执行 cargo ckeckmain.rs use candle_core::{Device…

惊了!用vue开发官网,以前我觉得胡闹,现在觉得未尝不可。

以前&#xff0c;有人做好官网UI&#xff08;展示性&#xff0c;没啥功能&#xff09;&#xff0c;找我开发前端&#xff0c;说要vue来做&#xff0c;我都劝了。 基于以下四个原因&#xff1a; 1、官网毕竟还是考虑seo的&#xff0c;流量多少算多少&#xff0c;总比没有强&am…

Doris 与 Clickhouse 对比(一)

1. 常用引擎 ☕️ Doris 表数据模型 duplicate key &#x1f3ac; 场景&#xff1a;适用于数据无需提前聚合的分析业务。 ⚠️ 注意点&#xff1a;只指定排序列&#xff0c;相同的行并不会合并。 unique key &#x1f3ac; 场景&#xff1a;适用于有更新需求的业务。 ⚠…