Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Q
qgroundcontrol
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Valentin Platzgummer
qgroundcontrol
Commits
e3134f6a
Commit
e3134f6a
authored
Dec 05, 2015
by
Don Gagne
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Change window close sequence to prompt user from Qml side
parent
4105a169
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
30 additions
and
15 deletions
+30
-15
MainWindow.cc
src/ui/MainWindow.cc
+10
-14
MainWindow.h
src/ui/MainWindow.h
+5
-0
MainWindow.qml
src/ui/MainWindow.qml
+15
-1
No files found.
src/ui/MainWindow.cc
View file @
e3134f6a
...
...
@@ -425,24 +425,20 @@ void MainWindow::showStatusBarCallback(bool checked)
checked
?
statusBar
()
->
show
()
:
statusBar
()
->
hide
();
}
void
MainWindow
::
acceptWindowClose
(
void
)
{
qgcApp
()
->
toolbox
()
->
linkManager
()
->
shutdown
();
// The above shutdown causes a flurry of activity as the vehicle components are removed. This in turn
// causes the Windows Version of Qt to crash if you allow the close event to be accepted. In order to prevent
// the crash, we ignore the close event and setup a delayed timer to close the window after things settle down.
QTimer
::
singleShot
(
1500
,
this
,
&
MainWindow
::
_closeWindow
);
}
void
MainWindow
::
closeEvent
(
QCloseEvent
*
event
)
{
// Disallow window close if there are active connections
if
(
qgcApp
()
->
toolbox
()
->
multiVehicleManager
()
->
vehicles
()
->
count
())
{
QGCMessageBox
::
StandardButton
button
=
QGCMessageBox
::
warning
(
tr
(
"QGroundControl close"
),
tr
(
"There are still active connections to vehicles. Do you want to disconnect these before closing?"
),
QMessageBox
::
Yes
|
QMessageBox
::
Cancel
,
QMessageBox
::
Cancel
);
if
(
button
==
QMessageBox
::
Yes
)
{
qgcApp
()
->
toolbox
()
->
linkManager
()
->
shutdown
();
// The above disconnect causes a flurry of activity as the vehicle components are removed. This in turn
// causes the Windows Version of Qt to crash if you allow the close event to be accepted. In order to prevent
// the crash, we ignore the close event and setup a delayed timer to close the window after things settle down.
QTimer
::
singleShot
(
1500
,
this
,
&
MainWindow
::
_closeWindow
);
}
emit
showWindowCloseMessage
();
event
->
ignore
();
return
;
}
...
...
src/ui/MainWindow.h
View file @
e3134f6a
...
...
@@ -91,6 +91,9 @@ public:
/// @brief Saves the last used connection
void
saveLastUsedConnection
(
const
QString
connection
);
// Called from MainWindow.qml when the user accepts the window close dialog
Q_INVOKABLE
void
acceptWindowClose
(
void
);
public
slots
:
/** @brief Show the application settings */
void
showSettings
();
...
...
@@ -132,6 +135,7 @@ protected slots:
* this incoherent.
*/
void
handleActiveViewActionState
(
bool
triggered
);
signals:
// Signals the Qml to show the specified view
void
showFlyView
(
void
);
...
...
@@ -139,6 +143,7 @@ signals:
void
showSetupView
(
void
);
void
showToolbarMessage
(
const
QString
&
message
);
void
showWindowCloseMessage
(
void
);
// These are used for unit testing
void
showSetupFirmware
(
void
);
...
...
src/ui/MainWindow.qml
View file @
e3134f6a
...
...
@@ -23,6 +23,7 @@ along with QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.
import
QtQuick
2.5
import
QtQuick
.
Controls
1.2
import
QtQuick
.
Dialogs
1.2
import
QtPositioning
5.2
import
QGroundControl
1.0
...
...
@@ -95,6 +96,8 @@ Item {
onShowToolbarMessage
:
toolBar
.
showToolbarMessage
(
message
)
onShowWindowCloseMessage
:
windowCloseDialog
.
open
()
// The following are use for unit testing only
onShowSetupFirmware
:
setupViewLoader
.
item
.
showFirmwarePanel
()
...
...
@@ -173,13 +176,24 @@ Item {
function
showPopUp
(
dropItem
,
centerX
)
{
if
(
currentPopUp
)
{
currentPopUp
.
close
()
}
}
indicatorDropdown
.
centerX
=
centerX
indicatorDropdown
.
sourceComponent
=
dropItem
indicatorDropdown
.
visible
=
true
currentPopUp
=
indicatorDropdown
}
MessageDialog
{
id
:
windowCloseDialog
title
:
"
QGroundControl close
"
text
:
"
There are still active connections to vehicles. Do you want to disconnect these before closing?
"
standardButtons
:
StandardButton
.
Yes
|
StandardButton
.
Cancel
modality
:
Qt
.
ApplicationModal
visible
:
false
onYes
:
controller
.
acceptWindowClose
()
}
//-- Left Settings Menu
Loader
{
id
:
leftPanel
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment