From 3860173a840754b6f8d4cfc5cb115c968d8d0c6b Mon Sep 17 00:00:00 2001 From: dogmaphobic Date: Thu, 5 May 2016 16:47:00 -0400 Subject: [PATCH] Fix sizing within MissionItemStatus --- src/MissionEditor/MissionEditor.qml | 1 + src/MissionEditor/MissionItemStatus.qml | 129 +++++++++++----------- src/QmlControls/MissionItemIndexLabel.qml | 16 +-- 3 files changed, 75 insertions(+), 71 deletions(-) diff --git a/src/MissionEditor/MissionEditor.qml b/src/MissionEditor/MissionEditor.qml index 45e91b80b..7a5f8917b 100644 --- a/src/MissionEditor/MissionEditor.qml +++ b/src/MissionEditor/MissionEditor.qml @@ -496,6 +496,7 @@ QGCView { orientation: ListView.Vertical model: controller.visualItems cacheBuffer: height * 2 + clip: true delegate: MissionItemEditor { missionItem: object diff --git a/src/MissionEditor/MissionItemStatus.qml b/src/MissionEditor/MissionItemStatus.qml index f0f0b1d6a..8b8cff538 100644 --- a/src/MissionEditor/MissionItemStatus.qml +++ b/src/MissionEditor/MissionItemStatus.qml @@ -35,8 +35,8 @@ Rectangle { property real expandedWidth ///< Width of control when expanded width: _expanded ? expandedWidth : _collapsedWidth - height: valueGrid.height + _margins - radius: ScreenTools.defaultFontPixelWidth + height: valueGrid.height + (_margins * 2) + radius: ScreenTools.defaultFontPixelWidth * 0.5 color: qgcPal.window opacity: 0.80 clip: true @@ -63,75 +63,78 @@ Rectangle { onClicked: _expanded = !_expanded } - Grid { - id: valueGrid + Row { + anchors.fill: parent anchors.margins: _margins - anchors.left: parent.left - anchors.top: parent.top - columns: 2 - columnSpacing: _margins + spacing: _margins - QGCLabel { text: qsTr("Distance:") } - QGCLabel { text: _distanceText } + Grid { + id: valueGrid + columns: 2 + columnSpacing: _margins + anchors.verticalCenter: parent.verticalCenter - QGCLabel { text: qsTr("Alt diff:") } - QGCLabel { text: _altText } + QGCLabel { text: qsTr("Distance:") } + QGCLabel { text: _distanceText } - QGCLabel { text: qsTr("Gradient:") } - QGCLabel { text: _gradientText } + QGCLabel { text: qsTr("Alt diff:") } + QGCLabel { text: _altText } - QGCLabel { text: qsTr("Azimuth:") } - QGCLabel { text: _azimuthText } - } + QGCLabel { text: qsTr("Gradient:") } + QGCLabel { text: _gradientText } - QGCFlickable { - anchors.leftMargin: _margins - anchors.rightMargin: _margins - anchors.left: valueGrid.right - anchors.right: parent.right - anchors.top: parent.top - anchors.bottom: parent.bottom - contentWidth: graphRow.width - clip: true - - Row { - id: graphRow - anchors.top: parent.top - anchors.bottom: parent.bottom - spacing: ScreenTools.defaultFontPixelWidth * ScreenTools.smallFontPointRatio - - Repeater { - model: missionItems - - Item { - height: graphRow.height - width: ScreenTools.defaultFontPixelWidth * ScreenTools.smallFontPointRatio * 2 - visible: object.specifiesCoordinate && !object.isStandaloneCoordinate - - - property real availableHeight: height - (ScreenTools.defaultFontPixelHeight * ScreenTools.smallFontPointRatio) - indicator.height - - property bool graphAbsolute: true - - MissionItemIndexLabel { - id: indicator - anchors.horizontalCenter: parent.horizontalCenter - y: availableHeight - (availableHeight * object.altPercent) - small: true - isCurrentItem: object.isCurrentItem - label: object.abbreviation - visible: object.relativeAltitude ? true : (object.homePosition || graphAbsolute) - } + QGCLabel { text: qsTr("Azimuth:") } + QGCLabel { text: _azimuthText } + } - /* - Taking these off for now since there really isn't room for the numbers - QGCLabel { - anchors.bottom: parent.bottom - anchors.horizontalCenter: parent.horizontalCenter - font.pointSize: ScreenTools.smallFontPointSize - text: (object.relativeAltitude ? "" : "=") + object.coordinate.altitude.toFixed(0) + QGCFlickable { + anchors.leftMargin: _margins + anchors.rightMargin: _margins + anchors.top: parent.top + anchors.bottom: parent.bottom + width: parent.width - valueGrid.width - (_margins * 2) + contentWidth: graphRow.width + visible: _expanded + clip: true + + Row { + id: graphRow + anchors.top: parent.top + anchors.bottom: parent.bottom + //anchors.margins: ScreenTools.defaultFontPixelWidth * ScreenTools.smallFontPointRatio + spacing: ScreenTools.defaultFontPixelWidth * ScreenTools.smallFontPointRatio + + Repeater { + model: missionItems + + Item { + height: graphRow.height + width: indicator.width + visible: object.specifiesCoordinate && !object.isStandaloneCoordinate + + property real availableHeight: height - indicator.height + property bool graphAbsolute: true + + MissionItemIndexLabel { + id: indicator + anchors.horizontalCenter: parent.horizontalCenter + y: availableHeight - (availableHeight * object.altPercent) + small: true + isCurrentItem: object.isCurrentItem + label: object.abbreviation + visible: object.relativeAltitude ? true : (object.homePosition || graphAbsolute) + } + + /* + Taking these off for now since there really isn't room for the numbers + QGCLabel { + anchors.bottom: parent.bottom + anchors.horizontalCenter: parent.horizontalCenter + font.pointSize: ScreenTools.smallFontPointSize + text: (object.relativeAltitude ? "" : "=") + object.coordinate.altitude.toFixed(0) + } + */ } - */ } } } diff --git a/src/QmlControls/MissionItemIndexLabel.qml b/src/QmlControls/MissionItemIndexLabel.qml index 369b90932..e6b70357f 100644 --- a/src/QmlControls/MissionItemIndexLabel.qml +++ b/src/QmlControls/MissionItemIndexLabel.qml @@ -19,22 +19,22 @@ Rectangle { border.color: "white" color: isCurrentItem ? "green" : qgcPal.mapButtonHighlight - property real _width: small ? ScreenTools.smallFontPointSize * 1.5 : ScreenTools.mediumFontPointSize * 1.5 + property real _width: small ? ScreenTools.defaultFontPixelHeight * ScreenTools.smallFontPointRatio * 1.75 : ScreenTools.defaultFontPixelHeight * 1.75 QGCPalette { id: qgcPal } - MouseArea { - anchors.fill: parent - - onClicked: parent.clicked() - } - QGCLabel { id: _label anchors.fill: parent horizontalAlignment: Text.AlignHCenter verticalAlignment: Text.AlignVCenter color: "white" - font.pointSize: small ? ScreenTools.smallFontPointSize : ScreenTools.mediumFontPointSize + font.pointSize: small ? ScreenTools.smallFontPointSize : ScreenTools.defaultFontPointSize } + + MouseArea { + anchors.fill: parent + onClicked: parent.clicked() + } + } -- 2.22.0