[英]Qt - QQuickWidget setSource without freezing UI
我正在管理一个项目,在该项目中,我必须从数据库中管理客户数据,而且我必须添加一个地图小部件,该部件显示客户的位置(通过从数据库中获取他的坐标)..我创建了一个小原型来学习如何使用QML + Map Plugin,因为我以前从未使用过它们,所以我决定使用QQuickWidget来显示我的地图(该地图的QML取自Qt的示例,并进行了一些修改)..但是当我执行程序时,我遇到了一个问题,显示UI需要花费几分钟,我认为这与我缓慢的互联网连接以获取地图数据及所有信息有关,但是我在这里需要显示UI和eveything(执行数据库查询等)。 所以我需要的是在正常处理UI的同时执行Map的小部件(获取地图),以便用户可以选择,搜索,删除并做任何他想做的事情(该地图的小部件将为空,因为尚未加载),直到地图已准备好显示。
这是我的代码:MainWindow:
ui->quickWidget->setSource(QUrl("qrc:/new/prefix1/main.qml"));
QObject *object = ui->quickWidget->rootObject();
object->setProperty("_title" , "Oslo");
object->setProperty("_x" , "59.93");
object->setProperty("_y" , "10.76");
地图的QML脚本(main.qml):
import QtQuick 2.0
import QtQuick.Window 2.0
import QtLocation 5.6
import QtPositioning 5.6
Item
{
width: 512
height: 512
visible: true
property var _x: 0
property var _y: 0
property string _title: ""
Plugin
{
id: mapPlugin
name: "osm"
}
Map
{
anchors.fill: parent
plugin: mapPlugin
center: QtPositioning.coordinate(_x , _y)
zoomLevel: 15
ListModel
{
id: locationModel
ListElement {lat: 0; lon: 0; color: "blue"}
ListElement {lat: 5; lon: 12.5; color: "green"}
ListElement {lat: 10; lon: 25; color: "red"}
}
MapItemView
{
model: locationModel
delegate: MapQuickItem
{
coordinate: QtPositioning.coordinate(_x , _y)
anchorPoint: Qt.point(10 , 10)
sourceItem: Column
{
Image {source: "marker.png"}
Text {text: _title}
}
}
}
}
}
谢谢 !
我发现问题是由于缺少OpenSSL库引起的。 您可以在此处阅读相关主题:
解决方案,对我有用:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.