mirror of
https://github.com/Serial-Studio/Serial-Studio.git
synced 2025-01-15 05:22:53 +08:00
148 lines
3.3 KiB
QML
148 lines
3.3 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
|
|
ColumnLayout {
|
|
id: root
|
|
|
|
spacing: 0
|
|
implicitWidth: labelBg.width
|
|
|
|
//
|
|
// Custom properties
|
|
//
|
|
property real value: 0
|
|
property real minValue: 0
|
|
property real maxValue: 0
|
|
property string units: ""
|
|
property bool alarm: false
|
|
property string textValue: ""
|
|
property bool rangeVisible: false
|
|
property real maximumWidth: root.width
|
|
|
|
//
|
|
// Helper function to calculate padding
|
|
//
|
|
function getPaddedText(value) {
|
|
const valueText = value.toFixed(Cpp_UI_Dashboard.precision)
|
|
const maxText = root.maxValue.toFixed(Cpp_UI_Dashboard.precision)
|
|
const leftSpaces = " ".repeat(Math.max(0, maxText.length - valueText.length))
|
|
return leftSpaces + value
|
|
}
|
|
|
|
//
|
|
// Max value
|
|
//
|
|
Label {
|
|
opacity: 0.8
|
|
elide: Qt.ElideRight
|
|
visible: root.rangeVisible
|
|
Layout.alignment: Qt.AlignHCenter
|
|
font: Cpp_Misc_CommonFonts.monoFont
|
|
Layout.maximumWidth: root.maximumWidth
|
|
horizontalAlignment: Text.AlignHCenter
|
|
color: Cpp_ThemeManager.colors["widget_text"]
|
|
text: root.maxValue.toFixed(Cpp_UI_Dashboard.precision) + " " + root.units
|
|
}
|
|
|
|
//
|
|
// Spacer
|
|
//
|
|
Item {
|
|
implicitHeight: 4
|
|
}
|
|
|
|
//
|
|
// Connector line
|
|
//
|
|
Rectangle {
|
|
implicitWidth: 2
|
|
Layout.fillHeight: true
|
|
visible: root.rangeVisible
|
|
Layout.alignment: Qt.AlignHCenter
|
|
color: root.alarm ? Cpp_ThemeManager.colors["alarm"] :
|
|
Cpp_ThemeManager.colors["widget_border"]
|
|
|
|
Behavior on color {ColorAnimation{}}
|
|
}
|
|
|
|
//
|
|
// Spacer
|
|
//
|
|
Item {
|
|
implicitHeight: 8
|
|
}
|
|
|
|
//
|
|
// Value display
|
|
//
|
|
Label {
|
|
elide: Qt.ElideRight
|
|
Layout.alignment: Qt.AlignHCenter
|
|
Layout.maximumWidth: root.maximumWidth
|
|
horizontalAlignment: Text.AlignHCenter
|
|
color: Cpp_ThemeManager.colors["widget_text"]
|
|
text: root.textValue !== "" ? root.textValue :
|
|
root.getPaddedText(root.value) + " " + root.units
|
|
font: root.rangeVisible ? Cpp_Misc_CommonFonts.customMonoFont(14) :
|
|
Cpp_Misc_CommonFonts.customMonoFont(12)
|
|
|
|
background: Rectangle {
|
|
z: 0
|
|
radius: 5
|
|
id: labelBg
|
|
border.width: 2
|
|
anchors.fill: parent
|
|
anchors.margins: root.rangeVisible ? -8 : -4
|
|
color: Cpp_ThemeManager.colors["widget_base"]
|
|
border.color: root.alarm ? Cpp_ThemeManager.colors["alarm"] :
|
|
Cpp_ThemeManager.colors["widget_border"]
|
|
|
|
Behavior on border.color {ColorAnimation{}}
|
|
}
|
|
}
|
|
|
|
//
|
|
// Spacer
|
|
//
|
|
Item {
|
|
implicitHeight: 8
|
|
}
|
|
|
|
//
|
|
// Connector line
|
|
//
|
|
Rectangle {
|
|
implicitWidth: 2
|
|
Layout.fillHeight: true
|
|
visible: root.rangeVisible
|
|
Layout.alignment: Qt.AlignHCenter
|
|
color: root.alarm ? Cpp_ThemeManager.colors["alarm"] :
|
|
Cpp_ThemeManager.colors["widget_border"]
|
|
|
|
Behavior on color {ColorAnimation{}}
|
|
}
|
|
|
|
//
|
|
// Spacer
|
|
//
|
|
Item {
|
|
implicitHeight: 4
|
|
}
|
|
|
|
//
|
|
// Minimum value
|
|
//
|
|
Label {
|
|
opacity: 0.8
|
|
elide: Qt.ElideRight
|
|
visible: root.rangeVisible
|
|
Layout.alignment: Qt.AlignHCenter
|
|
font: Cpp_Misc_CommonFonts.monoFont
|
|
Layout.maximumWidth: root.maximumWidth
|
|
horizontalAlignment: Text.AlignHCenter
|
|
color: Cpp_ThemeManager.colors["widget_text"]
|
|
text: root.minValue.toFixed(Cpp_UI_Dashboard.precision) + " " + root.units
|
|
}
|
|
}
|