我正在使用QT5.5实现一个简单的程序,其中包含一个HTML窗口(QWebview),如下面的屏幕截图所示:
现在我想要为iOS安装该程序,例如对于iPad。我发现QWebview类不适用于移动系统,所以我不得不用QML文件将我的HTML窗口更改为QQuickView(或者有更好的方法吗?)。我在网上找到了以下代码:
QQuickView *view = new QQuickView();
QWidget *container = QWidget::createWindowContainer(view, this);
container->setMinimumSize(200,400);
container->setMaximumSize(200,400);
container->setFocusPolicy(Qt::TabFocus);
view->setSource(QUrl("qrc:///webview.qml"));
layout->addWidget(container);
然后我将容器添加到mainWindow。 webview.qml:
import QtQuick 2.5
import QtWebView 1.0
Rectangle {
id: rectangle
width: 200
height: 400
WebView {
id: webview
url: "file:///test.html"
anchors.fill: parent
width: 200
height: 400
}
}
但不知怎的,我无法正确布局。 HTML window on iOS 容器后面有一个空白/白色矩形,容器也不在右侧的HTML窗口中。当我在qml文件中更改矩形的宽度和高度时,它只会更改webview的大小,而不是白色背景。
任何人都可以告诉我,我怎样才能做到这一点?我还使用了container->setParent()
,但视图始终位于左侧。
答案 0 :(得分:0)
作者代码的可见性可能不够,但总体而言,更容易在布局中设置具有特定对齐的小部件。这样,您可以命令窗口小部件位于某一侧,并使放置不依赖于坐标/主机窗口小部件大小等。layout
变量假定为水平框布局或QHBoxLayout。
// make sure that QHBoxLayout* layout = new QHBoxLayout(this);
// or set the horizontal layout somehow else
QQuickView *view = new QQuickView();
QWidget *container = QWidget::createWindowContainer(view, this);
container->serFixedWidth(200); // the layout is horizontal
// and we *may* want to fix the width
container->setFocusPolicy(Qt::TabFocus);
view->setSource(QUrl("qrc:///webview.qml"));
layout->addWidget(container, Qt::AlignRight); // align to the right
请注意,水平布局的其余部分应该按照相对位置填充。