/*===================================================================== QGroundControl Open Source Ground Control Station (c) 2009, 2015 QGROUNDCONTROL PROJECT This file is part of the QGROUNDCONTROL project QGROUNDCONTROL is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. QGROUNDCONTROL is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with QGROUNDCONTROL. If not, see . ======================================================================*/ import QtQuick 2.5 import QtQuick.Controls 1.2 import QtPositioning 5.2 import QGroundControl 1.0 import QGroundControl.Palette 1.0 import QGroundControl.Controls 1.0 import QGroundControl.FlightDisplay 1.0 import QGroundControl.ScreenTools 1.0 //-- Left Menu Item { id: settingsMenu anchors.fill: parent property alias animateShowDialog: __animateShowDialog property alias animateHideDialog: __animateHideDialog readonly property int __animationDuration: 100 readonly property real __closeButtonSize: ScreenTools.defaultFontPixelHeight * 2 readonly property real _margins: ScreenTools.defaultFontPixelHeight / 2 QGCPalette { id: qgcPal } onVisibleChanged: { //-- Unselect any selected button panelActionGroup.current = null //-- Destroy panel contents if not visible if(!visible) { __rightPanel.source = "" } } function closeSettings() { __rightPanel.source = "" mainWindow.hideLeftMenu() } ParallelAnimation { id: __animateShowDialog NumberAnimation { target: __transparentSection properties: "opacity" from: 0.0 to: 0.8 duration: settingsMenu.__animationDuration } NumberAnimation { target: __transparentSection properties: "width" from: 1 to: mainWindow.width duration: settingsMenu.__animationDuration } } ParallelAnimation { id: __animateHideDialog NumberAnimation { target: __transparentSection properties: "opacity" from: 0.8 to: 0.0 duration: settingsMenu.__animationDuration } NumberAnimation { target: __transparentSection properties: "width" from: mainWindow.width to: 1 duration: settingsMenu.__animationDuration } onRunningChanged: { if (!running) { parent.visible = false } } } // This covers the screen with a transparent section Rectangle { id: __transparentSection height: parent.height - toolBar.height anchors.bottom: parent.bottom anchors.left: parent.left opacity: 0.0 color: qgcPal.window visible: __rightPanel.source == "" // Dismiss if clicked outside menu area MouseArea { anchors.fill: parent onClicked: { if (!__animateShowDialog.running) mainWindow.hideLeftMenu() } } } //-- Top Separator Rectangle { id: __topSeparator width: parent.width height: 1 y: toolBar.height anchors.left: parent.left color: QGroundControl.isDarkStyle ? "#909090" : "#7f7f7f" } // This is the menu dialog panel which is anchored to the left edge Rectangle { id: __leftMenu width: ScreenTools.defaultFontPixelWidth * 14 anchors.left: parent.left anchors.top: __topSeparator.bottom anchors.bottom: parent.bottom color: qgcPal.windowShadeDark QGCFlickable { anchors.fill: parent contentHeight: buttonColumn.height + _margins flickableDirection: Flickable.VerticalFlick clip: true ExclusiveGroup { id: panelActionGroup } Column { id: buttonColumn anchors.leftMargin: _margins anchors.rightMargin: _margins anchors.left: parent.left anchors.right: parent.right anchors.topMargin: _margins anchors.top: parent.top spacing: ScreenTools.defaultFontPixelHeight QGCLabel { text: qsTr("Preferences") anchors.horizontalCenter: parent.horizontalCenter } QGCButton { anchors.left: parent.left anchors.right: parent.right text: qsTr("General") exclusiveGroup: panelActionGroup onClicked: { if(__rightPanel.source != "GeneralSettings.qml") { __rightPanel.source = "GeneralSettings.qml" } checked = true } } QGCButton { anchors.left: parent.left anchors.right: parent.right text: qsTr("Comm Links") exclusiveGroup: panelActionGroup onClicked: { if(__rightPanel.source != "LinkSettings.qml") { __rightPanel.source = "LinkSettings.qml" } checked = true } } QGCButton { anchors.left: parent.left anchors.right: parent.right text: qsTr("Offline Maps") exclusiveGroup: panelActionGroup onClicked: { if(__rightPanel.source != "OfflineMap.qml") { __rightPanel.source = "OfflineMap.qml" } checked = true } } QGCButton { anchors.left: parent.left anchors.right: parent.right text: qsTr("MavLink") exclusiveGroup: panelActionGroup onClicked: { if(__rightPanel.source != "MavlinkSettings.qml") { __rightPanel.source = "MavlinkSettings.qml" } checked = true } } QGCButton { anchors.left: parent.left anchors.right: parent.right text: qsTr("Console") exclusiveGroup: panelActionGroup onClicked: { if(__rightPanel.source != "QGroundControl/Controls/AppMessages.qml") { __rightPanel.source = "QGroundControl/Controls/AppMessages.qml" } checked = true } } QGCButton { anchors.left: parent.left anchors.right: parent.right text: qsTr("Mock Link") visible: ScreenTools.isDebug exclusiveGroup: panelActionGroup onClicked: { if(__rightPanel.source != "MockLink.qml") { __rightPanel.source = "MockLink.qml" } checked = true } } QGCButton { anchors.left: parent.left anchors.right: parent.right text: qsTr("Debug") visible: ScreenTools.isDebug exclusiveGroup: panelActionGroup onClicked: { if(__rightPanel.source != "DebugWindow.qml") { __rightPanel.source = "DebugWindow.qml" } checked = true } } } } } //-- Clicking in tool bar area dismiss it all MouseArea { anchors.top: parent.top anchors.left: parent.left anchors.right: parent.right height: toolBar.height onClicked: { if (!__animateShowDialog.running) mainWindow.hideLeftMenu() } } //-- Vertical Separator Rectangle { id: __verticalSeparator width: 1 height: parent.height - toolBar.height anchors.left: __leftMenu.right anchors.bottom: parent.bottom color: QGroundControl.isDarkStyle ? "#909090" : "#7f7f7f" } //-- Main Setting Display Area Rectangle { anchors.left: __verticalSeparator.right width: mainWindow.width - __leftMenu.width - __verticalSeparator.width height: parent.height - toolBar.height - __topSeparator.height anchors.bottom: parent.bottom visible: __rightPanel.source != "" color: qgcPal.window //-- Panel Contents Loader { id: __rightPanel anchors.fill: parent } //-- Dismiss it all Item { id: closeButton width: __closeButtonSize height: __closeButtonSize anchors.right: parent.right anchors.top: parent.top anchors.margins: ScreenTools.defaultFontPixelSize * 0.5 QGCColoredImage { source: "/res/XDelete.svg" mipmap: true fillMode: Image.PreserveAspectFit color: qgcPal.text width: parent.width * 0.75 height: parent.height * 0.75 anchors.centerIn: parent } MouseArea { anchors.fill: parent onClicked: { if (!__animateShowDialog.running) { __rightPanel.source = "" mainWindow.hideLeftMenu() } } } } } }