工程名 : 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的更多相关文章

  1. Hibernate4.2.4入门(一)——环境搭建和简单例子

    一.前言 发下牢骚,这段时间要做项目,又要学框架,搞得都没时间写笔记,但是觉得这知识学过还是要记录下.进入主题了 1.1.Hibernate简介 什么是Hibernate?Hibernate有什么用? ...

  2. AgileEAS.NET SOA 中间件平台.Net Socket通信框架-简单例子-实现简单的服务端客户端消息应答

    一.AgileEAS.NET SOA中间件Socket/Tcp框架介绍 在文章AgileEAS.NET SOA 中间件平台Socket/Tcp通信框架介绍一文之中我们对AgileEAS.NET SOA ...

  3. spring mvc(注解)上传文件的简单例子

    spring mvc(注解)上传文件的简单例子,这有几个需要注意的地方1.form的enctype=”multipart/form-data” 这个是上传文件必须的2.applicationConte ...

  4. ko 简单例子

    Knockout是在下面三个核心功能是建立起来的: 监控属性(Observables)和依赖跟踪(Dependency tracking) 声明式绑定(Declarative bindings) 模板 ...

  5. mysql定时任务简单例子

    mysql定时任务简单例子 ? 1 2 3 4 5 6 7 8 9     如果要每30秒执行以下语句:   [sql] update userinfo set endtime = now() WHE ...

  6. java socket编程开发简单例子 与 nio非阻塞通道

    基本socket编程 1.以下只是简单例子,没有用多线程处理,只能一发一收(由于scan.nextLine()线程会进入等待状态),使用时可以根据具体项目功能进行优化处理 2.以下代码使用了1.8新特 ...

  7. 一个简单例子:贫血模型or领域模型

    转:一个简单例子:贫血模型or领域模型 贫血模型 我们首先用贫血模型来实现.所谓贫血模型就是模型对象之间存在完整的关联(可能存在多余的关联),但是对象除了get和set方外外几乎就没有其它的方法,整个 ...

  8. [转] 3个学习Socket编程的简单例子:TCP Server/Client, Select

    以前都是采用ACE的编写网络应用,最近由于工作需要,需要直接只用socket接口编写CS的代码,重新学习这方面的知识,给出自己所用到的3个简单例子,都是拷贝别人的程序.如果你能完全理解这3个例子,估计 ...

  9. jsonp的简单例子

    jsonp的简单例子 index.html <!DOCTYPE html> <html> <head> <meta charset="UTF-8&q ...

随机推荐

  1. sort命令详解及Nginx统计运用

    sort命令是帮我们依据不同的数据类型进行排序,其语法及常用参数格式: sort [-bcfMnrtk][源文件][-o 输出文件] 补充说明:sort可针对文本文件的内容,以行为单位来排序. 参 数 ...

  2. Redis的简单了解以及主从复制

    1.Redis的简单了解 Redis是一种高性能的分布式NoSql数据库,持久存储,高并发,数据类型丰富,通过现场申请内存空间,同时可以配置虚拟内存.五种数据类型:string(字符串,这种格式和me ...

  3. Oracle HA 之 oracle 11.2 rac库配置active dataguard

    目录 configing active dataguard for 11.2 rac. 1 一.建组.建用户.配置环境变量.内核参数等... 1 二.配置共享磁盘... 3 1)创建4块共享磁盘并fd ...

  4. 设计模式之——Composite模式

    composite模式又叫做组合模式/复合模式. 它是一种能够使容器与内容具有一致性,创造出递归结构的模式. 示例程序是列出文件夹以及其内部文件与文件夹一览的功能: 可以由示例图看出,有一个电影文件夹 ...

  5. Python开发【数据结构】:排序练习

    排序练习 问题一: 现在有一个列表,列表中的数范围都在0到100之间,列表长度大约为100万.设计算法在O(n)时间复杂度内将列表进行排序. import random data = [random. ...

  6. Python开发【Django】:Form组件

    Form组件 Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 创建Form类时,主要涉及到 [ ...

  7. Word 2010文档自动生成目录和某页插入页码

    一.Word 2010文档自动生成目录 关于Word文档自动生成目录一直是我身边同学们最为难的地方,尤其是毕业论文,经常因为目录问题,被要求修改,而且每次修改完正文后,目录的内容和页码可能都会发生变化 ...

  8. Openstack(五)Memcache- repcached集群

    5.1.1下载Memcache- repcached并解压 # wget http://downloads.sourceforge.net/repcached/memcached-1.2.8-repc ...

  9. python技巧总结之set、日志、rsa加密

    一.日志模块logging模块调用 1.日志模块使用原理 #!/usr/bin/python # -*- coding:utf-8 -*- import logging # 方式一: "&q ...

  10. centos上yum安装nodeJS

    更新node.js各版本yum源 Node.js v8.x安装命令 curl --silent --location https://rpm.nodesource.com/setup_8.x | ba ...