我想在QML
地图上动态绘制圆圈(通过C ++),但根据zoomLevel,圆圈可能不可见。 MapCircle
没有zoomLevel属性。所以我首先创建MapQuickItem
并尝试将MapCircle
作为其sourceItem
。在QML我有
function add_point(lat, lng){
var circle = Qt.createQmlObject('import QtLocation 5.3; MapCircle { }', map, "dynamic");
circle.center = QtPositioning.coordinate(lat, lng);
circle.radius = 5.0;
circle.color = 'blue';
circle.border.width = 1;
var item = Qt.createQmlObject('import QtLocation 5.3; MapQuickItem{}', map, "dynamic");
item.anchorPoint.x = 2.5;
item.anchorPoint.y = 2.5;
item.coordinate = QtPositioning.coordinate(lat, lng);
item.sourceItem = circle;
item.zoomLevel = 19.0
map.addMapItem(item);
map.points.push(item);
return true;
}
如果我只是绘制了MapCircle
,则地图上会显示一个圆圈,但是上面的代码在任何zoomLevel
屏幕上都没有显示,我尝试删除zoomLevel
属性,但仍然没有出现。
答案 0 :(得分:0)
MapQuickItem用于将标准QQuickItem添加到地图中。虽然MapCircle是一个QQuickItem,但它不应该放在那里。 如果要通过MapQuickItem将圆添加到地图中,则应添加一个Rectangle作为源项,并使用适当的半径。 以下两种方法均可使用
var item = Qt.createQmlObject('import QtQuick 2.7; import QtLocation 5.3; MapQuickItem{}', map, "dynamic");
item.anchorPoint = Qt.point(2.5,2.5)
item.coordinate = QtPositioning.coordinate(lat, lng);
item.zoomLevel = 10
var circle = Qt.createQmlObject('import QtQuick 2.7; Rectangle{ width: 32; height: 32; radius: 16}', map);
item.sourceItem = circle
map.addMapItem(item);
和
var item = Qt.createQmlObject('import QtQuick 2.7; import QtLocation 5.3; MapQuickItem{ sourceItem: Rectangle{ width: 32; height: 32; radius: 16}}', map, "dynamic");
item.anchorPoint = Qt.point(2.5,2.5)
item.coordinate = QtPositioning.coordinate(lat, lng);
item.zoomLevel = 10
map.addMapItem(item);
请记住,矩形大小表示像素大小。将zoomLevel设置为MapQuickItem时,它将变为该缩放级别的像素。 意味着在缩放级别10,矩形将是32像素宽。在缩放级别9,它将是16,依此类推。 顺便说一下,如果要根据缩放级别控制可见性,则应该编写可见属性的脚本。 类似的东西:
item.visible: map.zoomLevel > 10