我有QGraphicsItem
(实际上是QDeclarativeItem
),我希望它占据QGraphicsView
的整个可见空间(同样,它实际上是派生的QDeclarativeView
它被添加到的类)。通常,您可以使用QDeclarativeView::setResizeMode(QDeclarativeView::SizeRootObjectToView)
和QDeclarativeView
自动调整根对象的大小以适应视图。
我遇到的问题是我使用
手动创建根小部件QDeclarativeComponent component(declarativeView->engine(), QUrl(qml));
QDeclarativeItem* object = qobject_cast<QDeclarativeItem*>(component.create());
if (object)
{
declarativeView->scene()->addItem(object);
...
而不是让QDeclarativeView
通过调用setSource()
自动执行此操作。我这样做的原因是因为我想在某些事件发生时交换QML场景,但我不想破坏前一场景。调用setSource()
会删除在调用setSource()
之前添加的所有项目。所以,我自己创建“根对象”并手动将其添加到场景中。
我正在使用windows resizeEvent 调整QDeclarativeItem
的大小,如下所示:
void AppWindow::resizeEvent (QResizeEvent* event)
{
QDeclarativeItem* object = sceneCache.value(sceneName, 0);
if (object)
{
object->setWidth(declarativeView->viewport()->width());
object->setHeight(declarativeView->viewport()->height());
}
}
这确实有效!但是,它不是很漂亮。如果您快速调整窗口大小,QDeclarativeItem
的调整大小不够快,并且在它赶上并调整大小之前您会短暂地看到灰色背景。它也不是很顺利。
只有在我调整了复杂项目时才会出现这种情况(在我的例子中,它是一个QWebKit小部件)。它适用于更简单的项目。但问题是,如果我让QDeclarativeView
这样做,我就没有这些问题:它的大小正确且顺利。
我想这不是特定于QtDeclarative的东西,而是QGraphicsView,虽然也许我错了。
有没有人有任何想法?
答案 0 :(得分:3)
我不确定这是否会消除闪烁,但您可以在resizeEvent()
中使用fitInView
:
declarativeView->fitInView(object, Qt::IgnoreAspectRatio);
答案 1 :(得分:3)
我已经解决了我的问题。
问题似乎与QML的WebView元素有关。我把它换成了从C ++注册的QGraphicsProxyWidget,将widget设置为普通的QWebView,所有问题都消失了。它现在的行为与WebView的行为完全相同。
缺点是我需要手动将QWebView信号/插槽/属性公开给QML。 (编辑:我通过一个名为object
的只读属性解决了这个问题,该属性返回了set小部件。由于QObjects自动转换为javascript可访问的对象,我可以访问Web视图,例如,像这样:object.url = 'http://google.com'
。为了方便起见,我还在QML对象上调用了一个init javascript函数,如果它存在的话,我只需将web视图设置在那里 - 效果很好!)
自从我提出这个问题以来我做的另一个改变是将“根对象”从C ++切换到QML本身,通过创建一个带有C ++可调用javascript函数的全屏矩形,该函数使用Qt.createComponent()来加载“实际的“QML文件并用anchors.fill锚定它。这种方式逻辑(和对象的缓存)是用QML而不是C ++完成的,所以我可以简单地设置Source(),让Qt处理调整大小等等,我纯粹在QML中工作(无论如何,对于应用程序的这一部分)。