You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
256 lines
8.9 KiB
256 lines
8.9 KiB
/**************************************************************************** |
|
* |
|
* (c) 2009-2016 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org> |
|
* |
|
* QGroundControl is licensed according to the terms in the file |
|
* COPYING.md in the root of the source code directory. |
|
* |
|
****************************************************************************/ |
|
|
|
import QtQuick 2.3 |
|
import QtQuick.Layouts 1.2 |
|
import QtQuick.Controls 1.2 |
|
|
|
import QGroundControl 1.0 |
|
import QGroundControl.Controls 1.0 |
|
import QGroundControl.Palette 1.0 |
|
import QGroundControl.MultiVehicleManager 1.0 |
|
import QGroundControl.ScreenTools 1.0 |
|
import QGroundControl.Controllers 1.0 |
|
|
|
Rectangle { |
|
id: toolBar |
|
color: qgcPal.globalTheme === QGCPalette.Light ? Qt.rgba(1,1,1,0.8) : Qt.rgba(0,0,0,0.75) |
|
|
|
QGCPalette { id: qgcPal; colorGroupEnabled: true } |
|
|
|
property var _activeVehicle: QGroundControl.multiVehicleManager.activeVehicle |
|
property bool isMessageImportant: _activeVehicle ? !_activeVehicle.messageTypeNormal && !_activeVehicle.messageTypeNone : false |
|
property bool isBackgroundDark: true |
|
property bool opaqueBackground: false |
|
|
|
readonly property color colorGreen: "#05f068" |
|
readonly property color colorOrange: "#f0ab06" |
|
readonly property color colorRed: "#fc4638" |
|
readonly property color colorGrey: "#7f7f7f" |
|
readonly property color colorBlue: "#636efe" |
|
readonly property color colorWhite: "#ffffff" |
|
|
|
signal showSettingsView |
|
signal showSetupView |
|
signal showPlanView |
|
signal showFlyView |
|
signal showAnalyzeView |
|
|
|
function checkSettingsButton() { |
|
settingsButton.checked = true |
|
} |
|
|
|
function checkSetupButton() { |
|
setupButton.checked = true |
|
} |
|
|
|
function checkPlanButton() { |
|
planButton.checked = true |
|
} |
|
|
|
function checkFlyButton() { |
|
flyButton.checked = true |
|
} |
|
|
|
function checkAnalyzeButton() { |
|
analyzeButton.checked = true |
|
} |
|
|
|
Component.onCompleted: { |
|
//-- TODO: Get this from the actual state |
|
flyButton.checked = true |
|
} |
|
|
|
// Easter egg mechanism |
|
MouseArea { |
|
anchors.fill: parent |
|
onClicked: { |
|
console.log("easter egg click", ++_clickCount) |
|
eggTimer.restart() |
|
if (_clickCount == 5) { |
|
QGroundControl.corePlugin.showAdvancedUI = true |
|
} else if (_clickCount == 7) { |
|
QGroundControl.corePlugin.showTouchAreas = true |
|
} |
|
} |
|
|
|
property int _clickCount: 0 |
|
|
|
Timer { |
|
id: eggTimer |
|
interval: 1000 |
|
onTriggered: parent._clickCount = 0 |
|
} |
|
} |
|
|
|
/// Bottom single pixel divider |
|
Rectangle { |
|
anchors.left: parent.left |
|
anchors.right: parent.right |
|
anchors.bottom: parent.bottom |
|
height: 1 |
|
color: "black" |
|
visible: qgcPal.globalTheme == QGCPalette.Light |
|
} |
|
|
|
RowLayout { |
|
anchors.bottomMargin: 1 |
|
anchors.rightMargin: ScreenTools.defaultFontPixelWidth / 2 |
|
anchors.fill: parent |
|
spacing: ScreenTools.defaultFontPixelWidth * 2 |
|
|
|
//--------------------------------------------- |
|
// Toolbar Row |
|
Row { |
|
id: viewRow |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
spacing: ScreenTools.defaultFontPixelWidth / 2 |
|
|
|
ExclusiveGroup { id: mainActionGroup } |
|
|
|
QGCToolBarButton { |
|
id: settingsButton |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
exclusiveGroup: mainActionGroup |
|
source: "/res/QGCLogoWhite" |
|
logo: true |
|
onClicked: toolBar.showSettingsView() |
|
visible: !QGroundControl.corePlugin.options.combineSettingsAndSetup |
|
} |
|
|
|
QGCToolBarButton { |
|
id: setupButton |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
exclusiveGroup: mainActionGroup |
|
source: "/qmlimages/Gears.svg" |
|
onClicked: toolBar.showSetupView() |
|
} |
|
|
|
QGCToolBarButton { |
|
id: planButton |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
exclusiveGroup: mainActionGroup |
|
source: "/qmlimages/Plan.svg" |
|
onClicked: toolBar.showPlanView() |
|
} |
|
|
|
QGCToolBarButton { |
|
id: flyButton |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
exclusiveGroup: mainActionGroup |
|
source: "/qmlimages/PaperPlane.svg" |
|
onClicked: toolBar.showFlyView() |
|
} |
|
|
|
QGCToolBarButton { |
|
id: analyzeButton |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
exclusiveGroup: mainActionGroup |
|
source: "/qmlimages/Analyze.svg" |
|
visible: !ScreenTools.isMobile |
|
onClicked: toolBar.showAnalyzeView() |
|
} |
|
|
|
Rectangle { |
|
anchors.margins: ScreenTools.defaultFontPixelHeight / 2 |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
width: 1 |
|
color: qgcPal.text |
|
visible: _activeVehicle |
|
} |
|
} |
|
|
|
//------------------------------------------------------------------------- |
|
//-- Vehicle Selector |
|
QGCButton { |
|
id: vehicleSelectorButton |
|
width: ScreenTools.defaultFontPixelHeight * 8 |
|
text: "Vehicle " + (_activeVehicle ? _activeVehicle.id : "None") |
|
visible: QGroundControl.multiVehicleManager.vehicles.count > 1 |
|
anchors.verticalCenter: parent.verticalCenter |
|
|
|
menu: vehicleMenu |
|
|
|
Menu { |
|
id: vehicleMenu |
|
} |
|
|
|
Component { |
|
id: vehicleMenuItemComponent |
|
|
|
MenuItem { |
|
onTriggered: QGroundControl.multiVehicleManager.activeVehicle = vehicle |
|
|
|
property int vehicleId: Number(text.split(" ")[1]) |
|
property var vehicle: QGroundControl.multiVehicleManager.getVehicleById(vehicleId) |
|
} |
|
} |
|
|
|
property var vehicleMenuItems: [] |
|
|
|
function updateVehicleMenu() { |
|
// Remove old menu items |
|
for (var i = 0; i < vehicleMenuItems.length; i++) { |
|
vehicleMenu.removeItem(vehicleMenuItems[i]) |
|
} |
|
vehicleMenuItems.length = 0 |
|
|
|
// Add new items |
|
for (var i=0; i<QGroundControl.multiVehicleManager.vehicles.count; i++) { |
|
var vehicle = QGroundControl.multiVehicleManager.vehicles.get(i) |
|
var menuItem = vehicleMenuItemComponent.createObject(null, { "text": "Vehicle " + vehicle.id }) |
|
vehicleMenuItems.push(menuItem) |
|
vehicleMenu.insertItem(i, menuItem) |
|
} |
|
} |
|
|
|
Component.onCompleted: updateVehicleMenu() |
|
|
|
Connections { |
|
target: QGroundControl.multiVehicleManager.vehicles |
|
onCountChanged: vehicleSelectorButton.updateVehicleMenu() |
|
} |
|
} |
|
|
|
MainToolBarIndicators { |
|
anchors.margins: ScreenTools.defaultFontPixelHeight * 0.66 |
|
anchors.top: parent.top |
|
anchors.bottom: parent.bottom |
|
Layout.fillWidth: true |
|
visible: _activeVehicle |
|
} |
|
|
|
QGCLabel { |
|
id: waitForVehicle |
|
anchors.verticalCenter: parent.verticalCenter |
|
text: qsTr("Waiting For Vehicle Connection") |
|
font.pointSize: ScreenTools.mediumFontPointSize |
|
font.family: ScreenTools.demiboldFontFamily |
|
color: colorRed |
|
visible: !_activeVehicle |
|
} |
|
} |
|
|
|
// Progress bar |
|
Rectangle { |
|
id: progressBar |
|
anchors.bottom: parent.bottom |
|
height: toolBar.height * 0.05 |
|
width: _activeVehicle ? _activeVehicle.parameterManager.loadProgress * parent.width : 0 |
|
color: colorGreen |
|
} |
|
|
|
}
|
|
|