mirror of
https://github.com/f4exb/sdrangel.git
synced 2024-11-14 12:22:00 -05:00
116 lines
3.0 KiB
QML
116 lines
3.0 KiB
QML
|
import QtQuick 2.12
|
||
|
import QtQuick.Window 2.12
|
||
|
import QtLocation 5.12
|
||
|
import QtPositioning 5.12
|
||
|
|
||
|
Item {
|
||
|
id: qmlMap
|
||
|
property int vorZoomLevel: 11
|
||
|
|
||
|
Plugin {
|
||
|
id: mapPlugin
|
||
|
name: "osm"
|
||
|
}
|
||
|
|
||
|
Map {
|
||
|
id: map
|
||
|
objectName: "map"
|
||
|
anchors.fill: parent
|
||
|
plugin: mapPlugin
|
||
|
center: QtPositioning.coordinate(51.5, 0.125) // London
|
||
|
zoomLevel: 10
|
||
|
|
||
|
|
||
|
MapItemView {
|
||
|
model: vorModel
|
||
|
delegate: vorRadialComponent
|
||
|
}
|
||
|
|
||
|
MapStation {
|
||
|
id: station
|
||
|
objectName: "station"
|
||
|
stationName: "Home"
|
||
|
coordinate: QtPositioning.coordinate(51.5, 0.125)
|
||
|
}
|
||
|
|
||
|
MapItemView {
|
||
|
model: vorModel
|
||
|
delegate: vorComponent
|
||
|
}
|
||
|
|
||
|
onZoomLevelChanged: {
|
||
|
if (zoomLevel > 11) {
|
||
|
station.zoomLevel = zoomLevel
|
||
|
vorZoomLevel = zoomLevel
|
||
|
} else {
|
||
|
station.zoomLevel = 11
|
||
|
vorZoomLevel = 11
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
Component {
|
||
|
id: vorRadialComponent
|
||
|
MapPolyline {
|
||
|
line.width: 2
|
||
|
line.color: 'gray'
|
||
|
path: vorRadial
|
||
|
}
|
||
|
}
|
||
|
|
||
|
Component {
|
||
|
id: vorComponent
|
||
|
MapQuickItem {
|
||
|
id: vor
|
||
|
anchorPoint.x: image.width/2
|
||
|
anchorPoint.y: bubble.height/2
|
||
|
coordinate: position
|
||
|
zoomLevel: vorZoomLevel
|
||
|
|
||
|
sourceItem: Grid {
|
||
|
columns: 1
|
||
|
Grid {
|
||
|
horizontalItemAlignment: Grid.AlignHCenter
|
||
|
verticalItemAlignment: Grid.AlignVCenter
|
||
|
columnSpacing: 5
|
||
|
layer.enabled: true
|
||
|
layer.smooth: true
|
||
|
Image {
|
||
|
id: image
|
||
|
source: vorImage
|
||
|
MouseArea {
|
||
|
anchors.fill: parent
|
||
|
hoverEnabled: true
|
||
|
onDoubleClicked: (mouse) => {
|
||
|
selected = !selected
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
Rectangle {
|
||
|
id: bubble
|
||
|
color: bubbleColour
|
||
|
border.width: 1
|
||
|
width: text.width + 5
|
||
|
height: text.height + 5
|
||
|
radius: 5
|
||
|
Text {
|
||
|
id: text
|
||
|
anchors.centerIn: parent
|
||
|
text: vorData
|
||
|
}
|
||
|
MouseArea {
|
||
|
anchors.fill: parent
|
||
|
hoverEnabled: true
|
||
|
onDoubleClicked: (mouse) => {
|
||
|
selected = !selected
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|