1

我的问题很简单,但我一直在努力寻找解决方案。我在图像中显示了 QMainWindow,在 QtCreator 中构建。

在此处输入图像描述

我想在 QWidget csWindow 中加载一个 html 网页,因为我在加载网页的位置放置了一个 Qlabel label_pic。这是到目前为止的代码:

MainWindow::MainWindow(QWidget *parent, Project *project) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    this->project = project;

    QWebEngineView *view = new QWebEngineView(ui->label_pic);
    view->load(QUrl("http://localhost/myWeb.html"));

    ////works fine, for an image
    //QPixmap pix(":/img/imgs/someImage.png");
    //ui->label_pic->setPixmap(pix);

    //I also can load the web page in the QWidget csWindow but with the same result
    //QWebEngineView *view  = new QWebEngineView(ui->csWindow);
    //view->load(QUrl("http://localhost/myWebb.html"));

}

页面加载正常,但不适合相应的空间,它是用固定大小创建的,从不调整大小。我希望在移动拆分器时调整网页大小,但我没有成功。

我尝试了几种方法,首先将图像放入 label_pic,启用属性缩放内容并且工作正常。现在,我想对网页做同样的事情。

提前致谢。

4

1 回答 1

1

页面加载正常,但不适合相应的空间

这是因为在QWebEngineView完成加载之前不知道它的大小,所以您需要连接到它的信号loadFinished并调整大小 label_pic

connect(view, &QWebEngineView::loadFinished, [this]() {this->ui->label_pic->resize(this->ui->csWindow->size());});

我希望在移动拆分器时调整网页大小

然后,您还需要连接到QSplitter::splitterMoved来自所有拆分器的信号并调整 csWindow 和 label_pic 的大小,如下所示:

connect(ui->splitter, &QSplitter::splitterMoved, [this]() { this->view->resize(this->ui->csWindow->size()); this->ui->label_pic->resize(this->ui->csWindow->size());});
connect(ui->splitter_2, &QSplitter::splitterMoved, [this]() { this->view->resize(this->ui->csWindow->size()); this->ui->label_pic->resize(this->ui->csWindow->size());});
connect(ui->splitter_3, &QSplitter::splitterMoved, [this]() { this->view->resize(this->ui->csWindow->size()); this->ui->label_pic->resize(this->ui->csWindow->size());});

请注意,如果您从设计器或添加代码为窗口设置布局,这将最有效,例如:

QGridLayout *layout = new QGridLayout;
layout->addWidget(ui->splitter_3);
this->ui->centralWidget->setLayout(layout);

请记住,您应该在加载视图之前创建所有连接语句。

于 2018-05-20T00:23:23.757 回答