QWebEngineView_简单例子_01
工程名 : WebEngine01
1、WebEngine01.pro
#-------------------------------------------------
#
# Project created by QtCreator 2016-11-08T08:40:05
#
#------------------------------------------------- QT += core gui \
webenginewidgets greaterThan(QT_MAJOR_VERSION, 4): QT += widgets TARGET = WebEngine01
TEMPLATE = app SOURCES += main.cpp\
mainwindow.cpp \
TformWebEngine01.cpp \
TzcWebEngine.cpp HEADERS += mainwindow.h \
TformWebEngine01.h \
TzcWebEngine.h FORMS += mainwindow.ui \
TformWebEngine01.ui
2、main.cpp
#include "mainwindow.h"
#include <QApplication> int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;
w.show(); return a.exec();
}
3、TzcWebEngine.h / TzcWebEngine.cpp 自定义的 继承QWebEngineView的子类
3.1、TzcWebEngine.h
#ifndef TZCWEBENGINE_H
#define TZCWEBENGINE_H #include <QtWebEngineWidgets/QtWebEngineWidgets> class TzcWebEngine : public QWebEngineView
{
Q_OBJECT public:
explicit TzcWebEngine(QWidget* parent = Q_NULLPTR); public:
void FenXi();
}; #endif // TZCWEBENGINE_H
3.2、TzcWebEngine.cpp
#include "TzcWebEngine.h" #include <QDebug> TzcWebEngine::TzcWebEngine(QWidget* parent):
QWebEngineView(parent)
{
} void TzcWebEngine::FenXi()
{
qDebug() << this->url().url();
//this->page()->url()
//this->page()->runJavaScript(); // http://blog.csdn.net/li235456789/article/details/50959384
// const QString script = QLatin1String(
// "var evObj = document.createEvent('MouseEvents');"
// "evObj.initEvent('click', true, true);"
// "this.dispatchEvent(evObj);");
//element.evaluateJavaScript(script); const QString script = QLatin1String(
"var evObj = document.getElementById('loginButton');"
"evObj.initEvent('click', true, true);"
"this.dispatchEvent(evObj);");
this->page()->runJavaScript(script); // http://bbs.csdn.net/topics/370070779
}
4、TformWebEngine01.h / TformWebEngine01.cpp 承载(显示) WebEngineView的 窗口(QWidget)。
暂时 好像没有没有使用这个窗口(QWidget),要用的话 用起来也很简单
4.1、TformWebEngine01.h
#ifndef TFORMWEBENGINE01_H
#define TFORMWEBENGINE01_H #include <QWidget> namespace Ui {
class TformWebEngine01;
} class TformWebEngine01 : public QWidget
{
Q_OBJECT public:
explicit TformWebEngine01(QWidget *parent = );
~TformWebEngine01(); private:
Ui::TformWebEngine01 *ui;
}; #endif // TFORMWEBENGINE01_H
4.2、TformWebEngine01.cpp
#include "TformWebEngine01.h"
#include "ui_TformWebEngine01.h" TformWebEngine01::TformWebEngine01(QWidget *parent) :
QWidget(parent),
ui(new Ui::TformWebEngine01)
{
ui->setupUi(this);
} TformWebEngine01::~TformWebEngine01()
{
delete ui;
}
5、MainWindow.h / MainWindow.cpp 主界面
5.1、MainWindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H #include <QMainWindow>
#include <QCloseEvent>
#include "TzcWebEngine.h" namespace Ui {
class MainWindow;
} class MainWindow : public QMainWindow
{
Q_OBJECT public:
explicit MainWindow(QWidget *parent = );
~MainWindow(); private:
Ui::MainWindow *ui; public:
TzcWebEngine *Fpwe; private slots:
void on_pbtnShowFrmWE_clicked();
void on_pbtnFenXi_clicked(); protected:
void closeEvent(QCloseEvent *_event);
}; #endif // MAINWINDOW_H
5.2、MainWindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h" #include <QDebug> MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this); Fpwe = NULL;
//this->setAttribute(Qt::WA_DeleteOnClose);
} MainWindow::~MainWindow()
{
//qDebug() << "~MainWindow()";
Fpwe = NULL;
delete ui;
} //函数主体部分
void MainWindow::closeEvent(QCloseEvent *_event)//此函数在QWidget关闭时执行
{
//event->ignore();
//qDebug() << "closeEvent";
if (Fpwe != NULL)
{
Fpwe->close();
delete Fpwe;
Fpwe = NULL;
}
_event->accept();
} void MainWindow::on_pbtnShowFrmWE_clicked()
{
if (Fpwe == NULL)
{
Fpwe = new TzcWebEngine();
//Fpwe->load(QUrl::fromUserInput("http://www.baidu.com"));
Fpwe->load(QUrl::fromUserInput("http://www.caiak998.com/"));
int iTitleBarHeight = style()->pixelMetric(QStyle::PM_TitleBarHeight);
int iDefaultFrameWidth = style()->pixelMetric(QStyle::PM_DefaultFrameWidth); Fpwe->setGeometry(iDefaultFrameWidth, iTitleBarHeight + iDefaultFrameWidth, , ); // Fpwe->showFullScreen();
// QRect rt = Fpwe->geometry();
// qDebug() << rt.left() << " , " << rt.top() << " , " << rt.width() << " , " << rt.height();
// Fpwe->setAttribute(Qt::WA_DeleteOnClose);
}
Fpwe->show();
} void MainWindow::on_pbtnFenXi_clicked()
{
if (Fpwe == NULL)
return;
Fpwe->FenXi();
}
6、界面
6.1、主界面 mainwindow.ui
6.1.1、图片

6.1.2、XML代码
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
<class>MainWindow</class>
<widget class="QMainWindow" name="MainWindow">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>564</width>
<height>325</height>
</rect>
</property>
<property name="windowTitle">
<string>MainWindow</string>
</property>
<widget class="QWidget" name="centralWidget">
<widget class="QPushButton" name="pbtnShowFrmWE">
<property name="geometry">
<rect>
<x>20</x>
<y>10</y>
<width>131</width>
<height>23</height>
</rect>
</property>
<property name="text">
<string>Show FrmWebEngine01</string>
</property>
</widget>
<widget class="QPushButton" name="pbtnFenXi">
<property name="geometry">
<rect>
<x>20</x>
<y>40</y>
<width>131</width>
<height>23</height>
</rect>
</property>
<property name="text">
<string>Fen Xi</string>
</property>
</widget>
</widget>
</widget>
<layoutdefault spacing="6" margin="11"/>
<resources/>
<connections/>
</ui>
6.2、承载(显示) WebEngineView的 窗口
TformWebEngine01.ui
6.2.1、图片

6.2.2、XML代码
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
<class>TformWebEngine01</class>
<widget class="QWidget" name="TformWebEngine01">
<property name="geometry">
<rect>
<x>0</x>
<y>0</y>
<width>553</width>
<height>361</height>
</rect>
</property>
<property name="windowTitle">
<string>Form</string>
</property>
</widget>
<resources/>
<connections/>
</ui>
7、
8、
QWebEngineView_简单例子_01的更多相关文章
- Hibernate4.2.4入门(一)——环境搭建和简单例子
一.前言 发下牢骚,这段时间要做项目,又要学框架,搞得都没时间写笔记,但是觉得这知识学过还是要记录下.进入主题了 1.1.Hibernate简介 什么是Hibernate?Hibernate有什么用? ...
- AgileEAS.NET SOA 中间件平台.Net Socket通信框架-简单例子-实现简单的服务端客户端消息应答
一.AgileEAS.NET SOA中间件Socket/Tcp框架介绍 在文章AgileEAS.NET SOA 中间件平台Socket/Tcp通信框架介绍一文之中我们对AgileEAS.NET SOA ...
- spring mvc(注解)上传文件的简单例子
spring mvc(注解)上传文件的简单例子,这有几个需要注意的地方1.form的enctype=”multipart/form-data” 这个是上传文件必须的2.applicationConte ...
- ko 简单例子
Knockout是在下面三个核心功能是建立起来的: 监控属性(Observables)和依赖跟踪(Dependency tracking) 声明式绑定(Declarative bindings) 模板 ...
- mysql定时任务简单例子
mysql定时任务简单例子 ? 1 2 3 4 5 6 7 8 9 如果要每30秒执行以下语句: [sql] update userinfo set endtime = now() WHE ...
- java socket编程开发简单例子 与 nio非阻塞通道
基本socket编程 1.以下只是简单例子,没有用多线程处理,只能一发一收(由于scan.nextLine()线程会进入等待状态),使用时可以根据具体项目功能进行优化处理 2.以下代码使用了1.8新特 ...
- 一个简单例子:贫血模型or领域模型
转:一个简单例子:贫血模型or领域模型 贫血模型 我们首先用贫血模型来实现.所谓贫血模型就是模型对象之间存在完整的关联(可能存在多余的关联),但是对象除了get和set方外外几乎就没有其它的方法,整个 ...
- [转] 3个学习Socket编程的简单例子:TCP Server/Client, Select
以前都是采用ACE的编写网络应用,最近由于工作需要,需要直接只用socket接口编写CS的代码,重新学习这方面的知识,给出自己所用到的3个简单例子,都是拷贝别人的程序.如果你能完全理解这3个例子,估计 ...
- jsonp的简单例子
jsonp的简单例子 index.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8&q ...
随机推荐
- sort命令详解及Nginx统计运用
sort命令是帮我们依据不同的数据类型进行排序,其语法及常用参数格式: sort [-bcfMnrtk][源文件][-o 输出文件] 补充说明:sort可针对文本文件的内容,以行为单位来排序. 参 数 ...
- Redis的简单了解以及主从复制
1.Redis的简单了解 Redis是一种高性能的分布式NoSql数据库,持久存储,高并发,数据类型丰富,通过现场申请内存空间,同时可以配置虚拟内存.五种数据类型:string(字符串,这种格式和me ...
- Oracle HA 之 oracle 11.2 rac库配置active dataguard
目录 configing active dataguard for 11.2 rac. 1 一.建组.建用户.配置环境变量.内核参数等... 1 二.配置共享磁盘... 3 1)创建4块共享磁盘并fd ...
- 设计模式之——Composite模式
composite模式又叫做组合模式/复合模式. 它是一种能够使容器与内容具有一致性,创造出递归结构的模式. 示例程序是列出文件夹以及其内部文件与文件夹一览的功能: 可以由示例图看出,有一个电影文件夹 ...
- Python开发【数据结构】:排序练习
排序练习 问题一: 现在有一个列表,列表中的数范围都在0到100之间,列表长度大约为100万.设计算法在O(n)时间复杂度内将列表进行排序. import random data = [random. ...
- Python开发【Django】:Form组件
Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 创建Form类时,主要涉及到 [ ...
- Word 2010文档自动生成目录和某页插入页码
一.Word 2010文档自动生成目录 关于Word文档自动生成目录一直是我身边同学们最为难的地方,尤其是毕业论文,经常因为目录问题,被要求修改,而且每次修改完正文后,目录的内容和页码可能都会发生变化 ...
- Openstack(五)Memcache- repcached集群
5.1.1下载Memcache- repcached并解压 # wget http://downloads.sourceforge.net/repcached/memcached-1.2.8-repc ...
- python技巧总结之set、日志、rsa加密
一.日志模块logging模块调用 1.日志模块使用原理 #!/usr/bin/python # -*- coding:utf-8 -*- import logging # 方式一: "&q ...
- centos上yum安装nodeJS
更新node.js各版本yum源 Node.js v8.x安装命令 curl --silent --location https://rpm.nodesource.com/setup_8.x | ba ...