參考
QT webengine顯示HTML簡單示例
示例1
- 編譯器 : Desktop Qt 5.15.2 MSVC2019 64bit
- 編輯器: QtCreator
- 代碼:
TestWebenqine.pro
# TestWebenqine.pro
QT += core gui webenginewidgets
greaterThan(QT_MAJOR_VERSION, 4): QT += widgets
CONFIG += c++17
# You can make your code fail to compile if it uses deprecated APIs.
# In order to do so, uncomment the following line.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000 # disables all the APIs deprecated before Qt 6.0.0
SOURCES += \
main.cpp \
mainwindow.cpp
HEADERS += \
mainwindow.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
mainwindow.h
//mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QWebEngineView>
QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
MainWindow(QWidget *parent = nullptr);
~MainWindow();
//使得網(wǎng)頁的窗口大小隨著mainwindow的窗口大小變化而變化
void resizeEvent(QResizeEvent *event);
private:
Ui::MainWindow *ui;
QWebEngineView *view; //聲明view
};
#endif // MAINWINDOW_H
mainwindow.cpp
//mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QResizeEvent>
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
, ui(new Ui::MainWindow)
{
ui->setupUi(this);
view = new QWebEngineView(this);
//view->setFixedSize(this->width(),this->height());
view->load(QUrl(QStringLiteral("https://www.qweather.com/weather/luoyang-101180901.html")));
//view->load(QUrl(QStringLiteral("https://www.baidu.com")));
view->showMaximized();
}
MainWindow::~MainWindow()
{
delete ui;
}
void MainWindow::resizeEvent(QResizeEvent *event)
{
QMainWindow::resizeEvent(event); // 調(diào)用基類的 resizeEvent,確保正常的處理
// 獲取新的 mainwindow 大小
QSize newSize = event->size();
// 將新的大小應(yīng)用于 view
view->setFixedSize(newSize.width(), newSize.height());
}
main.cpp
//main.cpp
#include "mainwindow.h"
#include <QApplication>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;
w.show();
return a.exec();
}
效果
文章來源:http://www.zghlxwxcb.cn/news/detail-854681.html
示例2 (使用setDevToolsPage函數(shù))
- 編譯器 : Desktop Qt 5.15.2 MSVC2019 64bit
- 編輯器: QtCreator
- 代碼:
main.cpp
#include "mainwindow.h"
#include <QApplication>
#include <QWebEngineView>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
//MainWindow w;
//w.show();
QWebEngineView *view = new QWebEngineView();
QWebEngineView *view1 = new QWebEngineView();
view->setUrl(QUrl("http://baidu.com"));
view->page()->setDevToolsPage(view1->page());
view->setWindowTitle("BaiDu");
view1->setWindowTitle("DevTool");
view->show();//顯示頁面
view1->show();//顯示view頁面的JS腳本(也就是說:view1是view的開發(fā)者工具)
return a.exec();
}
效果
文章來源地址http://www.zghlxwxcb.cn/news/detail-854681.html
到了這里,關(guān)于QT webengine顯示HTML簡單示例的文章就介紹完了。如果您還想了解更多內(nèi)容,請?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!