370 lines
14 KiB
QML
Raw Normal View History

/*
* Copyright (c) 2020-2021 Alex Spataru <https://github.com/alex-spataru>
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*/
import QtQuick 2.12
import QtQuick.Layouts 1.12
2020-12-27 17:21:19 -06:00
import QtQuick.Controls 2.12
2021-02-08 00:20:42 -05:00
import QtQuick.Window 2.12 as QtWindow
2020-12-26 01:30:18 -06:00
import "../Widgets" as Widgets
Control {
2020-12-27 17:21:19 -06:00
id: root
background: Rectangle {
2021-09-05 02:41:48 -05:00
color: Cpp_ThemeManager.windowBackground
2020-12-27 17:21:19 -06:00
}
2020-12-26 01:30:18 -06:00
//
2020-12-27 17:21:19 -06:00
// Custom properties
2020-12-26 01:30:18 -06:00
//
2020-12-30 16:11:51 -06:00
readonly property int minimumWidgetSize: 320
2020-12-25 15:33:12 -06:00
2020-12-27 00:00:31 -06:00
//
// Group/dataset updating
//
Connections {
target: Cpp_UI_WidgetProvider
2021-02-10 15:48:25 -05:00
//*! Optimize this function
2021-02-10 19:44:30 -05:00
function onWidgetCountChanged() {
2020-12-27 00:00:31 -06:00
// Generate accelerometer widgets
2021-02-10 19:44:30 -05:00
accGenerator.model = 0
accGenerator.model = Cpp_UI_WidgetProvider.accelerometerGroupCount()
2020-12-26 22:53:16 -06:00
2020-12-27 00:00:31 -06:00
// Generate gyro widgets
2021-02-10 19:44:30 -05:00
gyroGenerator.model = 0
gyroGenerator.model = Cpp_UI_WidgetProvider.gyroGroupCount()
2020-12-26 22:53:16 -06:00
2020-12-27 00:00:31 -06:00
// Generate bar widgets
2021-02-10 19:44:30 -05:00
barGenerator.model = 0
barGenerator.model = Cpp_UI_WidgetProvider.barDatasetCount()
2020-12-26 22:53:16 -06:00
2021-09-03 13:51:43 -05:00
// Generate gauge widgets
gaugeGenerator.model = 0
gaugeGenerator.model = Cpp_UI_WidgetProvider.gaugeDatasetCount()
2021-03-12 00:19:54 -05:00
// Generate compass widgets
compassGenerator.model = 0
compassGenerator.model = Cpp_UI_WidgetProvider.compassDatasetCount()
2020-12-27 00:00:31 -06:00
// Generate map widgets
2021-02-10 19:44:30 -05:00
mapGenerator.model = 0
mapGenerator.model = Cpp_UI_WidgetProvider.mapGroupCount()
2020-12-26 22:53:16 -06:00
}
2020-12-27 00:00:31 -06:00
}
//
// UI inside scrollview
//
ScrollView {
z: 0
id: _sv
clip: false
contentWidth: -1
anchors.fill: parent
2020-12-30 16:11:51 -06:00
anchors.rightMargin: 5
2020-12-27 17:21:19 -06:00
anchors.margins: app.spacing * 1.5
2020-12-27 00:00:31 -06:00
ColumnLayout {
2020-12-30 16:11:51 -06:00
x: 0
width: _sv.width - 15
2020-12-27 00:00:31 -06:00
GridLayout {
Layout.fillWidth: true
Layout.fillHeight: true
rowSpacing: app.spacing
columnSpacing: app.spacing
2020-12-27 17:21:19 -06:00
columns: Math.floor(_sv.width / (root.minimumWidgetSize + 2 * app.spacing))
2020-12-27 00:00:31 -06:00
Repeater {
2020-12-27 20:50:17 -06:00
id: gyroGenerator
2020-12-27 00:00:31 -06:00
delegate: Item {
Layout.fillWidth: true
Layout.fillHeight: true
2020-12-27 17:21:19 -06:00
Layout.minimumWidth: root.minimumWidgetSize
Layout.minimumHeight: root.minimumWidgetSize
2020-12-27 00:00:31 -06:00
2020-12-27 20:50:17 -06:00
Widgets.GyroDelegate {
groupIndex: index
2020-12-27 00:00:31 -06:00
anchors.fill: parent
2021-02-09 21:03:20 -05:00
onHeaderDoubleClicked: windowGyro.show()
2021-02-08 00:20:42 -05:00
}
QtWindow.Window {
id: windowGyro
width: 640
height: 480
2021-02-08 00:20:42 -05:00
minimumWidth: root.minimumWidgetSize * 1.2
minimumHeight: root.minimumWidgetSize * 1.2
title: gyro.title
Rectangle {
anchors.fill: parent
color: gyro.backgroundColor
}
Widgets.GyroDelegate {
id: gyro
showIcon: true
gradient: false
headerHeight: 48
groupIndex: index
anchors.margins: 0
anchors.fill: parent
borderColor: backgroundColor
2021-02-09 21:03:20 -05:00
headerDoubleClickEnabled: false
2021-09-05 03:20:08 -05:00
titleColor: Cpp_ThemeManager.text
2021-02-08 00:20:42 -05:00
}
}
2020-12-27 00:00:31 -06:00
}
}
Repeater {
2020-12-27 20:50:17 -06:00
id: accGenerator
2020-12-27 00:00:31 -06:00
delegate: Item {
Layout.fillWidth: true
Layout.fillHeight: true
2020-12-27 17:21:19 -06:00
Layout.minimumWidth: root.minimumWidgetSize
Layout.minimumHeight: root.minimumWidgetSize
2020-12-27 20:50:17 -06:00
Widgets.AccelerometerDelegate {
groupIndex: index
2020-12-27 17:21:19 -06:00
anchors.fill: parent
2021-02-09 21:03:20 -05:00
onHeaderDoubleClicked: windowAcc.show()
2021-02-08 00:20:42 -05:00
}
QtWindow.Window {
id: windowAcc
width: 640
height: 480
2021-02-08 00:20:42 -05:00
minimumWidth: root.minimumWidgetSize * 1.2
minimumHeight: root.minimumWidgetSize * 1.2
title: acc.title
Rectangle {
anchors.fill: parent
color: acc.backgroundColor
}
Widgets.AccelerometerDelegate {
id: acc
showIcon: true
gradient: false
headerHeight: 48
groupIndex: index
anchors.margins: 0
anchors.fill: parent
borderColor: backgroundColor
2021-02-09 21:03:20 -05:00
headerDoubleClickEnabled: false
2021-09-05 03:20:08 -05:00
titleColor: Cpp_ThemeManager.text
2021-02-08 00:20:42 -05:00
}
}
2020-12-27 00:00:31 -06:00
}
}
Repeater {
2020-12-27 20:50:17 -06:00
id: mapGenerator
2020-12-27 00:00:31 -06:00
delegate: Item {
Layout.fillWidth: true
Layout.fillHeight: true
2020-12-27 17:21:19 -06:00
Layout.minimumWidth: root.minimumWidgetSize
Layout.minimumHeight: root.minimumWidgetSize
2020-12-27 00:00:31 -06:00
2020-12-27 20:50:17 -06:00
Widgets.MapDelegate {
groupIndex: index
2020-12-27 00:00:31 -06:00
anchors.fill: parent
2021-02-09 21:03:20 -05:00
onHeaderDoubleClicked: windowMap.show()
2021-02-08 00:20:42 -05:00
}
QtWindow.Window {
id: windowMap
width: 640
height: 480
2021-02-08 00:20:42 -05:00
minimumWidth: root.minimumWidgetSize * 1.2
minimumHeight: root.minimumWidgetSize * 1.2
title: map.title
Rectangle {
anchors.fill: parent
color: map.backgroundColor
}
Widgets.MapDelegate {
id: map
showIcon: true
gradient: false
headerHeight: 48
groupIndex: index
anchors.margins: 0
anchors.fill: parent
borderColor: backgroundColor
2021-02-09 21:03:20 -05:00
headerDoubleClickEnabled: false
2021-09-05 03:20:08 -05:00
titleColor: Cpp_ThemeManager.text
2021-02-08 00:20:42 -05:00
}
}
2020-12-27 00:00:31 -06:00
}
}
2021-09-03 13:51:43 -05:00
Repeater {
id: gaugeGenerator
delegate: Item {
Layout.fillWidth: true
Layout.fillHeight: true
Layout.minimumWidth: root.minimumWidgetSize
Layout.minimumHeight: root.minimumWidgetSize
Widgets.GaugeDelegate {
datasetIndex: index
anchors.fill: parent
2021-09-05 03:20:08 -05:00
onHeaderDoubleClicked: windowGauge.show()
2021-09-03 13:51:43 -05:00
}
QtWindow.Window {
2021-09-05 03:20:08 -05:00
id: windowGauge
2021-09-03 13:51:43 -05:00
width: 640
height: 480
minimumWidth: root.minimumWidgetSize * 1.2
minimumHeight: root.minimumWidgetSize * 1.2
title: gauge.title
Rectangle {
anchors.fill: parent
color: gauge.backgroundColor
}
Widgets.GaugeDelegate {
id: gauge
showIcon: true
gradient: false
headerHeight: 48
datasetIndex: index
anchors.margins: 0
anchors.fill: parent
borderColor: backgroundColor
headerDoubleClickEnabled: false
2021-09-05 03:20:08 -05:00
titleColor: Cpp_ThemeManager.text
2021-09-03 13:51:43 -05:00
}
}
}
}
2020-12-27 00:00:31 -06:00
Repeater {
2020-12-27 20:50:17 -06:00
id: barGenerator
2020-12-27 00:00:31 -06:00
delegate: Item {
Layout.fillWidth: true
Layout.fillHeight: true
2020-12-27 17:21:19 -06:00
Layout.minimumWidth: root.minimumWidgetSize
Layout.minimumHeight: root.minimumWidgetSize
2020-12-27 00:00:31 -06:00
2020-12-27 20:50:17 -06:00
Widgets.BarDelegate {
datasetIndex: index
2020-12-27 00:00:31 -06:00
anchors.fill: parent
2021-02-09 21:03:20 -05:00
onHeaderDoubleClicked: windowBar.show()
2021-02-08 00:20:42 -05:00
}
QtWindow.Window {
id: windowBar
width: 640
height: 480
2021-02-08 00:20:42 -05:00
minimumWidth: root.minimumWidgetSize * 1.2
minimumHeight: root.minimumWidgetSize * 1.2
title: bar.title
Rectangle {
anchors.fill: parent
color: bar.backgroundColor
}
Widgets.BarDelegate {
id: bar
showIcon: true
gradient: false
headerHeight: 48
datasetIndex: index
anchors.margins: 0
anchors.fill: parent
borderColor: backgroundColor
2021-02-09 21:03:20 -05:00
headerDoubleClickEnabled: false
2021-09-05 03:20:08 -05:00
titleColor: Cpp_ThemeManager.text
2021-02-08 00:20:42 -05:00
}
}
2020-12-27 00:00:31 -06:00
}
}
2021-03-12 00:19:54 -05:00
2021-03-12 09:56:17 -05:00
Repeater {
id: compassGenerator
2021-03-12 00:19:54 -05:00
2021-03-12 09:56:17 -05:00
delegate: Item {
Layout.fillWidth: true
Layout.fillHeight: true
Layout.minimumWidth: root.minimumWidgetSize
Layout.minimumHeight: root.minimumWidgetSize
2021-03-12 00:19:54 -05:00
Widgets.CompassDelegate {
datasetIndex: index
anchors.fill: parent
2021-03-12 09:56:17 -05:00
onHeaderDoubleClicked: windowCompass.show()
}
QtWindow.Window {
id: windowCompass
width: 640
height: 480
minimumWidth: root.minimumWidgetSize * 1.2
minimumHeight: root.minimumWidgetSize * 1.2
title: compass.title
Rectangle {
anchors.fill: parent
color: compass.backgroundColor
}
Widgets.CompassDelegate {
id: compass
showIcon: true
gradient: false
headerHeight: 48
datasetIndex: index
anchors.margins: 0
anchors.fill: parent
borderColor: backgroundColor
headerDoubleClickEnabled: false
2021-09-05 03:20:08 -05:00
titleColor: Cpp_ThemeManager.text
2021-03-12 09:56:17 -05:00
}
2021-03-12 00:19:54 -05:00
}
}
}
2020-12-27 00:00:31 -06:00
}
2021-03-12 00:19:54 -05:00
2021-03-12 09:56:17 -05:00
Item {
Layout.minimumHeight: 10
}
2021-03-12 00:19:54 -05:00
}
}
}