qt android中使用webview

qt5.9以后qml引入了webview,所以要想在安卓中使用webview只能使用此模块

但是本人不熟悉qml,只能采用widget和qml混合编程的方式,经过大量的调试运行,终于成功了,特此记录一下

#-------------------------------------------------
#
# Project created by QtCreator 2020-11-16T21:40:17
#
#-------------------------------------------------

QT       += core gui quickwidgets qml quick webview

greaterThan(QT_MAJOR_VERSION, 4): QT += widgets

TARGET = FileTest
TEMPLATE = app

# The following define makes your compiler emit warnings if you use
# any feature of Qt which has been marked as deprecated (the exact warnings
# depend on your compiler). Please consult the documentation of the
# deprecated API in order to know how to port your code away from it.
DEFINES += QT_DEPRECATED_WARNINGS

# You can also make your code fail to compile if you use deprecated APIs.
# In order to do so, uncomment the following line.
# You can also select to disable deprecated APIs only up to a certain version of Qt.
#DEFINES += QT_DISABLE_DEPRECATED_BEFORE=0x060000    # disables all the APIs deprecated before Qt 6.0.0

CONFIG += c++11

SOURCES += \
        main.cpp \
        mainwindow.cpp

HEADERS += \
        mainwindow.h

FORMS += \
        mainwindow.ui

CONFIG += mobility
MOBILITY = 


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

RESOURCES += \
    res.qrc
#include "mainwindow.h"
#include <QApplication>
#include <QtWebView/QtWebView>
int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    QtWebView::initialize();
    MainWindow w;
    w.show();

    return a.exec();
}
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QWidget>
#include <QQuickItem>

namespace Ui {
class MainWindow;
}

class MainWindow : public QWidget
{
    Q_OBJECT

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

private:
    Ui::MainWindow *ui;
    QQuickItem *item;
signals:
    void loadUrl(QString url);
public slots:
    void onGo();
};

#endif // MAINWINDOW_H
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QQuickWidget>
#include <QVBoxLayout>
#include <QMetaObject>
MainWindow::MainWindow(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    QQuickWidget* quickWidget = new QQuickWidget();
    quickWidget->setSource(QUrl("qrc:/main.qml"));
    ui->widget->layout()->addWidget(quickWidget);

    item=quickWidget->rootObject();
    connect(this,SIGNAL(loadUrl(QString)),item,SIGNAL(loadUrl(QString)));

    connect(ui->goBt,&QPushButton::clicked,this,&MainWindow::onGo);
}

MainWindow::~MainWindow()
{
    delete ui;
}
void MainWindow::onGo()
{
    QString url=ui->lineEdit->text();
    if(!url.startsWith("https://"))url="https://"+ui->lineEdit->text();
    emit loadUrl(url);
}
import QtQuick 2.2
import QtWebView 1.0
Rectangle {

    id : root;
    width: parent.width
    height: parent.height
    signal loadUrl(string url)
    WebView {
        id: webView
        width: parent.width
        height: parent.height
        anchors.fill: parent
        url: "https://www.baidu.com"
    }
    function onLoadUrl(str){
        webView.url=str;
        //webView.reload();
    }
    Component.onCompleted: {
        // employer 信号 连接 多个槽函数或信号
        root.loadUrl.connect(onLoadUrl)
    }
}

 

评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值