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
af38a105
Commit
af38a105
authored
Feb 04, 2015
by
Don Gagne
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Re-implemented Setup View
parent
1da6c502
Changes
12
Hide whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
370 additions
and
153 deletions
+370
-153
cogwheels.png
files/Setup/cogwheels.png
+0
-0
qgroundcontrol.pro
qgroundcontrol.pro
+4
-6
qgroundcontrol.qrc
qgroundcontrol.qrc
+7
-6
SetupButton.qml
qml/QGroundControl/Controls/SetupButton.qml
+88
-0
qmldir
qml/QGroundControl/Controls/qmldir
+2
-0
SetupView.cc
src/VehicleSetup/SetupView.cc
+63
-62
SetupView.h
src/VehicleSetup/SetupView.h
+13
-7
SetupView.ui
src/VehicleSetup/SetupView.ui
+90
-0
SetupViewButtons.qml
src/VehicleSetup/SetupViewButtons.qml
+88
-0
SetupWidgetHolder.ui
src/VehicleSetup/SetupWidgetHolder.ui
+0
-40
VehicleSummary.qml
src/VehicleSetup/VehicleSummary.qml
+6
-27
test.qml
src/test.qml
+9
-5
No files found.
files/Setup/cogwheels.png
0 → 100644
View file @
af38a105
10.2 KB
qgroundcontrol.pro
View file @
af38a105
...
@@ -208,6 +208,8 @@ ReleaseBuild {
...
@@ -208,6 +208,8 @@ ReleaseBuild {
}
}
}
}
QML_IMPORT_PATH
=
$$
BASEDIR
/
qml
#
qextserialport
should
not
be
used
by
general
QGroundControl
code
.
Use
QSerialPort
instead
.
This
is
only
#
qextserialport
should
not
be
used
by
general
QGroundControl
code
.
Use
QSerialPort
instead
.
This
is
only
#
here
to
support
special
case
Firmware
Upgrade
code
.
#
here
to
support
special
case
Firmware
Upgrade
code
.
include
(
libs
/
qextserialport
/
src
/
qextserialport
.
pri
)
include
(
libs
/
qextserialport
/
src
/
qextserialport
.
pri
)
...
@@ -343,7 +345,7 @@ FORMS += \
...
@@ -343,7 +345,7 @@ FORMS += \
src
/
ui
/
px4_configuration
/
PX4FirmwareUpgrade
.
ui
\
src
/
ui
/
px4_configuration
/
PX4FirmwareUpgrade
.
ui
\
src
/
ui
/
QGCUASFileView
.
ui
\
src
/
ui
/
QGCUASFileView
.
ui
\
src
/
QGCQmlWidgetHolder
.
ui
\
src
/
QGCQmlWidgetHolder
.
ui
\
src
/
ui
/
QGCMapRCToParamDialog
.
ui
src
/
ui
/
QGCMapRCToParamDialog
.
ui
\
HEADERS
+=
\
HEADERS
+=
\
src
/
MG
.
h
\
src
/
MG
.
h
\
...
@@ -713,13 +715,12 @@ FORMS += \
...
@@ -713,13 +715,12 @@ FORMS += \
src
/
VehicleSetup
/
ParameterEditor
.
ui
\
src
/
VehicleSetup
/
ParameterEditor
.
ui
\
src
/
ui
/
QGCPX4VehicleConfig
.
ui
\
src
/
ui
/
QGCPX4VehicleConfig
.
ui
\
src
/
AutoPilotPlugins
/
PX4
/
FlightModeConfig
.
ui
\
src
/
AutoPilotPlugins
/
PX4
/
FlightModeConfig
.
ui
\
src
/
VehicleSetup
/
Setup
WidgetHolder
.
ui
\
src
/
VehicleSetup
/
Setup
View
.
ui
\
HEADERS
+=
\
HEADERS
+=
\
src
/
VehicleSetup
/
SetupView
.
h
\
src
/
VehicleSetup
/
SetupView
.
h
\
src
/
VehicleSetup
/
ParameterEditor
.
h
\
src
/
VehicleSetup
/
ParameterEditor
.
h
\
src
/
VehicleSetup
/
VehicleComponent
.
h
\
src
/
VehicleSetup
/
VehicleComponent
.
h
\
src
/
VehicleSetup
/
VehicleComponentSummaryItem
.
h
\
src
/
AutoPilotPlugins
/
AutoPilotPluginManager
.
h
\
src
/
AutoPilotPlugins
/
AutoPilotPluginManager
.
h
\
src
/
AutoPilotPlugins
/
AutoPilotPlugin
.
h
\
src
/
AutoPilotPlugins
/
AutoPilotPlugin
.
h
\
src
/
AutoPilotPlugins
/
Generic
/
GenericAutoPilotPlugin
.
h
\
src
/
AutoPilotPlugins
/
Generic
/
GenericAutoPilotPlugin
.
h
\
...
@@ -733,13 +734,11 @@ HEADERS+= \
...
@@ -733,13 +734,11 @@ HEADERS+= \
src
/
AutoPilotPlugins
/
PX4
/
SensorsComponent
.
h
\
src
/
AutoPilotPlugins
/
PX4
/
SensorsComponent
.
h
\
src
/
AutoPilotPlugins
/
PX4
/
SafetyComponent
.
h
\
src
/
AutoPilotPlugins
/
PX4
/
SafetyComponent
.
h
\
src
/
AutoPilotPlugins
/
PX4
/
PX4ParameterFacts
.
h
\
src
/
AutoPilotPlugins
/
PX4
/
PX4ParameterFacts
.
h
\
src
/
VehicleSetup
/
SetupWidgetHolder
.
h
\
SOURCES
+=
\
SOURCES
+=
\
src
/
VehicleSetup
/
SetupView
.
cc
\
src
/
VehicleSetup
/
SetupView
.
cc
\
src
/
VehicleSetup
/
ParameterEditor
.
cc
\
src
/
VehicleSetup
/
ParameterEditor
.
cc
\
src
/
VehicleSetup
/
VehicleComponent
.
cc
\
src
/
VehicleSetup
/
VehicleComponent
.
cc
\
src
/
VehicleSetup
/
VehicleComponentSummaryItem
.
cc
\
src
/
AutoPilotPlugins
/
AutoPilotPluginManager
.
cc
\
src
/
AutoPilotPlugins
/
AutoPilotPluginManager
.
cc
\
src
/
AutoPilotPlugins
/
Generic
/
GenericAutoPilotPlugin
.
cc
\
src
/
AutoPilotPlugins
/
Generic
/
GenericAutoPilotPlugin
.
cc
\
src
/
AutoPilotPlugins
/
Generic
/
GenericParameterFacts
.
cc
\
src
/
AutoPilotPlugins
/
Generic
/
GenericParameterFacts
.
cc
\
...
@@ -752,7 +751,6 @@ SOURCES += \
...
@@ -752,7 +751,6 @@ SOURCES += \
src
/
AutoPilotPlugins
/
PX4
/
SensorsComponent
.
cc
\
src
/
AutoPilotPlugins
/
PX4
/
SensorsComponent
.
cc
\
src
/
AutoPilotPlugins
/
PX4
/
SafetyComponent
.
cc
\
src
/
AutoPilotPlugins
/
PX4
/
SafetyComponent
.
cc
\
src
/
AutoPilotPlugins
/
PX4
/
PX4ParameterFacts
.
cc
\
src
/
AutoPilotPlugins
/
PX4
/
PX4ParameterFacts
.
cc
\
src
/
VehicleSetup
/
SetupWidgetHolder
.
cc
\
#
Fact
System
code
#
Fact
System
code
...
...
qgroundcontrol.qrc
View file @
af38a105
...
@@ -241,19 +241,18 @@
...
@@ -241,19 +241,18 @@
<file alias="test.qml">src/test.qml</file>
<file alias="test.qml">src/test.qml</file>
<file alias="QGroundControl/FactControls/qmldir">qml/QGroundControl/FactControls/qmldir</file>
<file alias="QGroundControl/FactControls/qmldir">qml/QGroundControl/FactControls/qmldir</file>
<file alias="QGroundControl/FactControls/SetupButton.qml">qml/QGroundControl/FactControls/SetupButton.qml</file>
<file alias="QGroundControl/FactControls/FactLabel.qml">qml/QGroundControl/FactControls/FactLabel.qml</file>
<file alias="QGroundControl/FactControls/FactLabel.qml">qml/QGroundControl/FactControls/FactLabel.qml</file>
<file alias="QGroundControl/FactControls/FactTextField.qml">qml/QGroundControl/FactControls/FactTextField.qml</file>
<file alias="QGroundControl/FactControls/FactTextField.qml">qml/QGroundControl/FactControls/FactTextField.qml</file>
<file alias="QGroundControl/FactControls/FactCheckBox.qml">qml/QGroundControl/FactControls/FactCheckBox.qml</file>
<file alias="QGroundControl/FactControls/FactCheckBox.qml">qml/QGroundControl/FactControls/FactCheckBox.qml</file>
<file alias="QGroundControl/Controls/qmldir">qml/QGroundControl/Controls/qmldir</file>
<file alias="QGroundControl/Controls/SetupButton.qml">qml/QGroundControl/Controls/SetupButton.qml</file>
<file alias="octo_x.png">files/images/px4/airframes/octo_x.png</file>
<file alias="octo_x.png">files/images/px4/airframes/octo_x.png</file>
<file alias="px4fmu_2.x.png">files/images/px4/boards/px4fmu_2.x.png</file>
<file alias="px4fmu_2.x.png">files/images/px4/boards/px4fmu_2.x.png</file>
<file alias="SetupViewConnected.qml">src/VehicleSetup/SetupViewConnected.qml</file>
<file alias="SetupViewButtons.qml">src/VehicleSetup/SetupViewButtons.qml</file>
<file alias="SetupViewDisconnected.qml">src/VehicleSetup/SetupViewDisconnected.qml</file>
<file alias="VehicleSummary.qml">src/VehicleSetup/VehicleSummary.qml</file>
<file alias="SetupPane.qml">src/VehicleSetup/SetupPane.qml</file>
<file alias="SafetyComponent.qml">src/AutoPilotPlugins/PX4/SafetyComponent.qml</file>
<file alias="SafetyComponent.qml">src/AutoPilotPlugins/PX4/SafetyComponent.qml</file>
...
@@ -263,6 +262,8 @@
...
@@ -263,6 +262,8 @@
<file alias="FlightModesComponentSummary.qml">src/AutoPilotPlugins/PX4/FlightModesComponentSummary.qml</file>
<file alias="FlightModesComponentSummary.qml">src/AutoPilotPlugins/PX4/FlightModesComponentSummary.qml</file>
<file alias="AirframeComponentSummary.qml">src/AutoPilotPlugins/PX4/AirframeComponentSummary.qml</file>
<file alias="AirframeComponentSummary.qml">src/AutoPilotPlugins/PX4/AirframeComponentSummary.qml</file>
<file alias="QGroundControl/Controls/setupButtonImage.png">files/Setup/cogwheels.png</file>
</qresource>
</qresource>
<qresource prefix="/AutoPilotPlugins/PX4">
<qresource prefix="/AutoPilotPlugins/PX4">
...
...
qml/QGroundControl/Controls/SetupButton.qml
0 → 100644
View file @
af38a105
import
QtQuick
2.2
import
QtQuick
.
Controls
1.2
import
QtQuick
.
Controls
.
Styles
1.2
import
QtGraphicalEffects
1.0
import
QGroundControl
.
FactSystem
1.0
Button
{
checkable
:
true
height
:
80
text
:
"
Button
"
property
bool
setupComplete
:
true
property
bool
setupIndicator
:
true
style
:
ButtonStyle
{
id
:
buttonStyle
property
var
__qgcpal
:
QGCPalette
{
colorGroup
:
control
.
enabled
?
QGCPalette
.
Active
:
QGCPalette
.
Disabled
}
background
:
Rectangle
{
id
:
innerRect
readonly
property
real
titleHeight
:
30
border.color
:
control
.
checked
?
"
#eee333
"
:
"
#676767
"
radius
:
10
color
:
control
.
checked
?
"
#eee333
"
:
"
#343434
"
Text
{
id
:
titleBar
width
:
parent
.
width
height
:
parent
.
titleHeight
verticalAlignment
:
TextEdit
.
AlignVCenter
horizontalAlignment
:
TextEdit
.
AlignHCenter
text
:
control
.
text
font.pixelSize
:
12
color
:
control
.
checked
?
"
black
"
:
"
white
"
Rectangle
{
id
:
setupIndicator
readonly
property
real
indicatorRadius
:
6
x
:
parent
.
width
-
(
indicatorRadius
*
2
)
-
5
y
:
(
parent
.
height
-
(
indicatorRadius
*
2
))
/
2
width
:
indicatorRadius
*
2
height
:
indicatorRadius
*
2
radius
:
indicatorRadius
color
:
control
.
setupIndicator
?
(
control
.
setupComplete
?
"
green
"
:
"
red
"
)
:
innerRect
.
color
}
}
Rectangle
{
width
:
parent
.
width
height
:
parent
.
height
-
parent
.
titleHeight
y
:
parent
.
titleHeight
color
:
__qgcpal
.
window
border.color
:
control
.
checked
?
"
#eee333
"
:
"
#676767
"
Image
{
id
:
buttonImage
source
:
"
setupButtonImage.png
"
sourceSize
:
Qt
.
size
(
parent
.
width
-
20
,
parent
.
height
-
20
)
anchors.horizontalCenter
:
parent
.
horizontalCenter
anchors.verticalCenter
:
parent
.
verticalCenter
smooth
:
true
visible
:
false
}
ColorOverlay
{
anchors.fill
:
buttonImage
source
:
buttonImage
color
:
control
.
checked
?
"
#eee333
"
:
"
#58585a
"
}
}
}
label
:
Item
{}
}
}
qml/QGroundControl/Controls/qmldir
0 → 100644
View file @
af38a105
Module QGroundControl.Controls
SetupButton 1.0 SetupButton.qml
\ No newline at end of file
src/VehicleSetup/SetupView.cc
View file @
af38a105
...
@@ -25,13 +25,14 @@
...
@@ -25,13 +25,14 @@
/// @author Don Gagne <don@thegagnes.com>
/// @author Don Gagne <don@thegagnes.com>
#include "SetupView.h"
#include "SetupView.h"
#include "ui_SetupView.h"
#include "UASManager.h"
#include "UASManager.h"
#include "AutoPilotPluginManager.h"
#include "AutoPilotPluginManager.h"
#include "VehicleComponent.h"
#include "VehicleComponent.h"
#include "PX4FirmwareUpgrade.h"
#include "PX4FirmwareUpgrade.h"
#include "ParameterEditor.h"
#include "ParameterEditor.h"
#include "
Setup
WidgetHolder.h"
#include "
QGCQml
WidgetHolder.h"
#include "MainWindow.h"
#include "MainWindow.h"
#include "QGCMessageBox.h"
#include "QGCMessageBox.h"
...
@@ -40,16 +41,38 @@
...
@@ -40,16 +41,38 @@
#include <QDebug>
#include <QDebug>
SetupView
::
SetupView
(
QWidget
*
parent
)
:
SetupView
::
SetupView
(
QWidget
*
parent
)
:
Q
GCQuick
Widget
(
parent
),
QWidget
(
parent
),
_uasCurrent
(
NULL
),
_uasCurrent
(
NULL
),
_initComplete
(
false
),
_initComplete
(
false
),
_autoPilotPlugin
(
NULL
)
_autoPilotPlugin
(
NULL
),
_currentSetupWidget
(
NULL
),
_ui
(
new
Ui
::
SetupView
)
{
{
_ui
->
setupUi
(
this
);
bool
fSucceeded
=
connect
(
UASManager
::
instance
(),
SIGNAL
(
activeUASSet
(
UASInterface
*
)),
this
,
SLOT
(
_setActiveUAS
(
UASInterface
*
)));
bool
fSucceeded
=
connect
(
UASManager
::
instance
(),
SIGNAL
(
activeUASSet
(
UASInterface
*
)),
this
,
SLOT
(
_setActiveUAS
(
UASInterface
*
)));
Q_UNUSED
(
fSucceeded
);
Q_UNUSED
(
fSucceeded
);
Q_ASSERT
(
fSucceeded
);
Q_ASSERT
(
fSucceeded
);
setResizeMode
(
SizeRootObjectToView
);
//setResizeMode(SizeRootObjectToView);
_ui
->
buttonHolder
->
setAutoPilot
(
NULL
);
_ui
->
buttonHolder
->
setSource
(
QUrl
::
fromUserInput
(
"qrc:/qml/SetupViewButtons.qml"
));
QObject
*
rootObject
=
(
QObject
*
)
_ui
->
buttonHolder
->
rootObject
();
Q_ASSERT
(
rootObject
);
fSucceeded
=
connect
(
rootObject
,
SIGNAL
(
setupButtonClicked
(
QVariant
)),
this
,
SLOT
(
_setupButtonClicked
(
QVariant
)));
Q_ASSERT
(
fSucceeded
);
fSucceeded
=
connect
(
rootObject
,
SIGNAL
(
firmwareButtonClicked
()),
this
,
SLOT
(
_firmwareButtonClicked
()));
Q_ASSERT
(
fSucceeded
);
fSucceeded
=
connect
(
rootObject
,
SIGNAL
(
parametersButtonClicked
()),
this
,
SLOT
(
_parametersButtonClicked
()));
Q_ASSERT
(
fSucceeded
);
fSucceeded
=
connect
(
rootObject
,
SIGNAL
(
summaryButtonClicked
()),
this
,
SLOT
(
_summaryButtonClicked
()));
Q_ASSERT
(
fSucceeded
);
_setActiveUAS
(
UASManager
::
instance
()
->
getActiveUAS
());
_setActiveUAS
(
UASManager
::
instance
()
->
getActiveUAS
());
}
}
...
@@ -63,10 +86,16 @@ void SetupView::_setActiveUAS(UASInterface* uas)
...
@@ -63,10 +86,16 @@ void SetupView::_setActiveUAS(UASInterface* uas)
{
{
if
(
_uasCurrent
)
{
if
(
_uasCurrent
)
{
Q_ASSERT
(
_autoPilotPlugin
);
Q_ASSERT
(
_autoPilotPlugin
);
disconnect
(
_autoPilotPlugin
);
disconnect
(
_autoPilotPlugin
,
&
AutoPilotPlugin
::
pluginReady
,
this
,
&
SetupView
::
_pluginReady
);
_autoPilotPlugin
=
NULL
;
}
}
_autoPilotPlugin
=
NULL
;
_ui
->
buttonHolder
->
setAutoPilot
(
NULL
);
_firmwareButtonClicked
();
QObject
*
button
=
_ui
->
buttonHolder
->
rootObject
()
->
findChild
<
QObject
*>
(
"firmwareButton"
);
Q_ASSERT
(
button
);
button
->
setProperty
(
"checked"
,
true
);
_uasCurrent
=
uas
;
_uasCurrent
=
uas
;
if
(
_uasCurrent
)
{
if
(
_uasCurrent
)
{
...
@@ -74,48 +103,27 @@ void SetupView::_setActiveUAS(UASInterface* uas)
...
@@ -74,48 +103,27 @@ void SetupView::_setActiveUAS(UASInterface* uas)
connect
(
_autoPilotPlugin
,
&
AutoPilotPlugin
::
pluginReady
,
this
,
&
SetupView
::
_pluginReady
);
connect
(
_autoPilotPlugin
,
&
AutoPilotPlugin
::
pluginReady
,
this
,
&
SetupView
::
_pluginReady
);
if
(
_autoPilotPlugin
->
pluginIsReady
())
{
if
(
_autoPilotPlugin
->
pluginIsReady
())
{
_
setConnectedView
();
_
pluginReady
();
}
}
}
else
{
_setDisconnectedView
();
}
}
}
}
void
SetupView
::
_pluginReady
(
void
)
void
SetupView
::
_pluginReady
(
void
)
{
{
_setConnectedView
();
_ui
->
buttonHolder
->
setAutoPilot
(
_autoPilotPlugin
);
}
_summaryButtonClicked
();
QObject
*
button
=
_ui
->
buttonHolder
->
rootObject
()
->
findChild
<
QObject
*>
(
"summaryButton"
);
void
SetupView
::
_setViewConnections
(
void
)
{
QObject
*
button
=
rootObject
()
->
findChild
<
QObject
*>
(
"firmwareButton"
);
Q_ASSERT
(
button
);
Q_ASSERT
(
button
);
connect
(
button
,
SIGNAL
(
clicked
()),
this
,
SLOT
(
_firmwareButtonClicked
()));
button
->
setProperty
(
"checked"
,
true
);
button
=
rootObject
()
->
findChild
<
QObject
*>
(
"parametersButton"
);
if
(
button
)
{
connect
(
button
,
SIGNAL
(
clicked
()),
this
,
SLOT
(
_parametersButtonClicked
()));
}
}
}
void
SetupView
::
_
setDisconnectedView
(
void
)
void
SetupView
::
_
changeSetupWidget
(
QWidget
*
newWidget
)
{
{
setSource
(
QUrl
::
fromUserInput
(
"qrc:qml/SetupViewDisconnected.qml"
));
if
(
_currentSetupWidget
)
{
_setViewConnections
();
delete
_currentSetupWidget
;
}
}
_currentSetupWidget
=
newWidget
;
void
SetupView
::
_setConnectedView
(
void
)
_ui
->
setupWidgetLayout
->
addWidget
(
newWidget
);
{
Q_ASSERT
(
_uasCurrent
);
Q_ASSERT
(
_autoPilotPlugin
);
setAutoPilot
(
_autoPilotPlugin
);
setSource
(
QUrl
::
fromUserInput
(
"qrc:qml/SetupViewConnected.qml"
));
disconnect
(
_autoPilotPlugin
);
_setViewConnections
();
connect
((
QObject
*
)
rootObject
(),
SIGNAL
(
buttonClicked
(
QVariant
)),
this
,
SLOT
(
_setupButtonClicked
(
QVariant
)));
}
}
void
SetupView
::
_firmwareButtonClicked
(
void
)
void
SetupView
::
_firmwareButtonClicked
(
void
)
...
@@ -125,24 +133,27 @@ void SetupView::_firmwareButtonClicked(void)
...
@@ -125,24 +133,27 @@ void SetupView::_firmwareButtonClicked(void)
return
;
return
;
}
}
SetupWidgetHolder
*
dialog
=
new
SetupWidgetHolder
(
MainWindow
::
instance
());
PX4FirmwareUpgrade
*
setup
=
new
PX4FirmwareUpgrade
(
this
);
dialog
->
setModal
(
true
);
_changeSetupWidget
(
setup
);
dialog
->
setWindowTitle
(
"Firmware Upgrade"
);
PX4FirmwareUpgrade
*
setup
=
new
PX4FirmwareUpgrade
(
dialog
);
dialog
->
setInnerWidget
(
setup
);
dialog
->
exec
();
}
}
void
SetupView
::
_parametersButtonClicked
(
void
)
void
SetupView
::
_parametersButtonClicked
(
void
)
{
{
SetupWidgetHolder
*
dialog
=
new
SetupWidgetHolder
(
MainWindow
::
instance
());
ParameterEditor
*
setup
=
new
ParameterEditor
(
_uasCurrent
,
QStringList
(),
this
);
dialog
->
setModal
(
true
);
_changeSetupWidget
(
setup
);
dialog
->
setWindowTitle
(
"Parameter Editor"
);
}
void
SetupView
::
_summaryButtonClicked
(
void
)
{
Q_ASSERT
(
_autoPilotPlugin
);
ParameterEditor
*
setup
=
new
ParameterEditor
(
_uasCurrent
,
QStringList
(),
dialog
);
QGCQmlWidgetHolder
*
summary
=
new
QGCQmlWidgetHolder
;
dialog
->
setInnerWidget
(
setup
);
Q_CHECK_PTR
(
summary
);
dialog
->
exec
();
summary
->
setAutoPilot
(
_autoPilotPlugin
);
summary
->
setSource
(
QUrl
::
fromUserInput
(
"qrc:/qml/VehicleSummary.qml"
));
_changeSetupWidget
(
summary
);
}
}
void
SetupView
::
_setupButtonClicked
(
const
QVariant
&
component
)
void
SetupView
::
_setupButtonClicked
(
const
QVariant
&
component
)
...
@@ -161,15 +172,5 @@ void SetupView::_setupButtonClicked(const QVariant& component)
...
@@ -161,15 +172,5 @@ void SetupView::_setupButtonClicked(const QVariant& component)
return
;
return
;
}
}
SetupWidgetHolder
dialog
(
MainWindow
::
instance
());
_changeSetupWidget
(
vehicle
->
setupWidget
());
dialog
.
setModal
(
true
);
dialog
.
setWindowTitle
(
vehicle
->
name
());
QWidget
*
setupWidget
=
vehicle
->
setupWidget
();
dialog
.
resize
(
setupWidget
->
minimumSize
());
dialog
.
setInnerWidget
(
setupWidget
);
dialog
.
exec
();
delete
setupWidget
;
}
}
src/VehicleSetup/SetupView.h
View file @
af38a105
...
@@ -24,18 +24,22 @@
...
@@ -24,18 +24,22 @@
#ifndef SETUPVIEW_H
#ifndef SETUPVIEW_H
#define SETUPVIEW_H
#define SETUPVIEW_H
#include "UASInterface.h"
#include "UASInterface.h"
#include "ParameterEditor.h"
#include "ParameterEditor.h"
#include "VehicleComponent.h"
#include "VehicleComponent.h"
#include "QGCQuickWidget.h"
#include "AutoPilotPlugin.h"
#include "AutoPilotPlugin.h"
#include <QWidget>
/// @file
/// @file
/// @brief This class is used to display the UI for the VehicleComponent objects.
/// @brief This class is used to display the UI for the VehicleComponent objects.
/// @author Don Gagne <don@thegagnes.com>
/// @author Don Gagne <don@thegagnes.com>
class
SetupView
:
public
QGCQuickWidget
namespace
Ui
{
class
SetupView
;
}
class
SetupView
:
public
QWidget
{
{
Q_OBJECT
Q_OBJECT
...
@@ -48,16 +52,18 @@ private slots:
...
@@ -48,16 +52,18 @@ private slots:
void
_pluginReady
(
void
);
void
_pluginReady
(
void
);
void
_firmwareButtonClicked
(
void
);
void
_firmwareButtonClicked
(
void
);
void
_parametersButtonClicked
(
void
);
void
_parametersButtonClicked
(
void
);
void
_summaryButtonClicked
(
void
);
void
_setupButtonClicked
(
const
QVariant
&
component
);
void
_setupButtonClicked
(
const
QVariant
&
component
);
private:
private:
void
_setConnectedView
(
void
);
void
_changeSetupWidget
(
QWidget
*
newWidget
);
void
_setDisconnectedView
(
void
);
void
_setViewConnections
(
void
);
UASInterface
*
_uasCurrent
;
///< Currently active UAS
UASInterface
*
_uasCurrent
;
///< Currently active UAS
bool
_initComplete
;
///< true: parameters are ready and ui has been setup
bool
_initComplete
;
///< true: parameters are ready and ui has been setup
AutoPilotPlugin
*
_autoPilotPlugin
;
AutoPilotPlugin
*
_autoPilotPlugin
;
QWidget
*
_currentSetupWidget
;
Ui
::
SetupView
*
_ui
;
};
};
#endif
#endif
src/VehicleSetup/SetupView.ui
0 → 100644
View file @
af38a105
<?xml version="1.0" encoding="UTF-8"?>
<ui
version=
"4.0"
>
<class>
SetupView
</class>
<widget
class=
"QWidget"
name=
"SetupView"
>
<property
name=
"geometry"
>
<rect>
<x>
0
</x>
<y>
0
</y>
<width>
946
</width>
<height>
821
</height>
</rect>
</property>
<property
name=
"windowTitle"
>
<string>
Form
</string>
</property>
<layout
class=
"QHBoxLayout"
name=
"horizontalLayout"
>
<item>
<widget
class=
"QGCQuickWidget"
name=
"buttonHolder"
>
<property
name=
"sizePolicy"
>
<sizepolicy
hsizetype=
"Fixed"
vsizetype=
"Preferred"
>
<horstretch>
0
</horstretch>
<verstretch>
0
</verstretch>
</sizepolicy>
</property>
<property
name=
"minimumSize"
>
<size>
<width>
160
</width>
<height>
0
</height>
</size>
</property>
<property
name=
"maximumSize"
>
<size>
<width>
160
</width>
<height>
16777215
</height>
</size>
</property>
<property
name=
"resizeMode"
>
<enum>
QGCQuickWidget::SizeRootObjectToView
</enum>
</property>
</widget>
</item>
<item>
<widget
class=
"QWidget"
name=
"setupWidget"
>
<property
name=
"geometry"
>
<rect>
<x>
0
</x>
<y>
0
</y>
<width>
400
</width>
<height>
300
</height>
</rect>
</property>
<property
name=
"windowTitle"
>
<string>
Form
</string>
</property>
<property
name=
"autoFillBackground"
>
<bool>
true
</bool>
</property>
<layout
class=
"QVBoxLayout"
name=
"verticalLayout_2"
>
<item>
<layout
class=
"QVBoxLayout"
name=
"setupWidgetLayout"
/>
</item>
<item>
<spacer
name=
"verticalSpacer"
>
<property
name=
"orientation"
>
<enum>
Qt::Vertical
</enum>
</property>
<property
name=
"sizeHint"
stdset=
"0"
>
<size>
<width>
20
</width>
<height>
40
</height>
</size>
</property>
</spacer>
</item>
</layout>
</widget>
</item>
</layout>
</widget>
<customwidgets>
<customwidget>
<class>
QGCQuickWidget
</class>
<extends>
QQuickWidget
</extends>
<header>
QGCQuickWidget.h
</header>
<container>
1
</container>
</customwidget>
</customwidgets>
<resources/>
<connections/>
</ui>
src/VehicleSetup/SetupViewButtons.qml
0 → 100644
View file @
af38a105
import
QtQuick
2.2
import
QtQuick
.
Controls
1.2
import
QtQuick
.
Controls
.
Styles
1.2
import
QGroundControl
.
FactSystem
1.0
import
QGroundControl
.
Controls
1.0
Rectangle
{
id
:
topLevel
QGCPalette
{
id
:
palette
;
colorGroup
:
QGCPalette
.
Active
}
color
:
palette
.
window
signal
firmwareButtonClicked
;
signal
summaryButtonClicked
;
signal
parametersButtonClicked
;
signal
setupButtonClicked
(
variant
component
);
ExclusiveGroup
{
id
:
setupButtonGroup
}
Component
{
id
:
disconnectedButtons
Column
{
spacing
:
10
SetupButton
{
id
:
firmwareButton
;
objectName
:
"
firmwareButton
"
width
:
parent
.
width
text
:
"
FIRMWARE
"
setupIndicator
:
false
exclusiveGroup
:
setupButtonGroup
onClicked
:
topLevel
.
firmwareButtonClicked
()
}
}
}
Component
{
id
:
connectedButtons
Column
{
spacing
:
10
SetupButton
{
id
:
summaryButton
;
objectName
:
"
summaryButton
"
width
:
parent
.
width
text
:
"
VEHICLE SUMMARY
"
setupIndicator
:
false
exclusiveGroup
:
setupButtonGroup
onClicked
:
topLevel
.
summaryButtonClicked
()
}
SetupButton
{
id
:
firmwareButton
;
objectName
:
"
firmwareButton
"
width
:
parent
.
width
text
:
"
FIRMWARE
"
setupIndicator
:
false
exclusiveGroup
:
setupButtonGroup
onClicked
:
topLevel
.
firmwareButtonClicked
()
}
Repeater
{
model
:
autopilot
.
components
SetupButton
{
width
:
parent
.
width
text
:
modelData
.
name
.
toUpperCase
()
setupComplete
:
modelData
.
setupComplete
exclusiveGroup
:
setupButtonGroup
onClicked
:
topLevel
.
setupButtonClicked
(
modelData
)
}
}
SetupButton
{
width
:
parent
.
width
text
:
"
PARAMETERS
"
setupIndicator
:
false
exclusiveGroup
:
setupButtonGroup
onClicked
:
topLevel
.
parametersButtonClicked
()
}
}
}
Loader
{
anchors.fill
:
parent
sourceComponent
:
autopilot
?
connectedButtons
:
disconnectedButtons
}
}
src/VehicleSetup/SetupWidgetHolder.ui
deleted
100644 → 0
View file @
1da6c502
<?xml version="1.0" encoding="UTF-8"?>
<ui
version=
"4.0"
>
<class>
SetupWidgetHolder
</class>
<widget
class=
"QDialog"
name=
"SetupWidgetHolder"
>
<property
name=
"geometry"
>
<rect>
<x>
0
</x>
<y>
0
</y>
<width>
400
</width>
<height>
300
</height>
</rect>
</property>
<property
name=
"windowTitle"
>
<string>
Form
</string>
</property>
<property
name=
"autoFillBackground"
>
<bool>
true
</bool>
</property>
<layout
class=
"QVBoxLayout"
name=
"verticalLayout_2"
>
<item>
<layout
class=
"QVBoxLayout"
name=
"setupWidgetLayout"
/>
</item>
<item>
<spacer
name=
"verticalSpacer"
>
<property
name=
"orientation"
>
<enum>
Qt::Vertical
</enum>
</property>
<property
name=
"sizeHint"
stdset=
"0"
>
<size>
<width>
20
</width>
<height>
40
</height>
</size>
</property>
</spacer>
</item>
</layout>
</widget>
<resources/>
<connections/>
</ui>
src/VehicleSetup/
SetupViewConnected
.qml
→
src/VehicleSetup/
VehicleSummary
.qml
View file @
af38a105
...
@@ -4,34 +4,29 @@ import QtQuick.Controls.Styles 1.2
...
@@ -4,34 +4,29 @@ import QtQuick.Controls.Styles 1.2
import
QGroundControl
.
FactSystem
1.0
import
QGroundControl
.
FactSystem
1.0
Rectangle
{
Rectangle
{
width
:
600
height
:
400
QGCPalette
{
id
:
palette
;
colorGroup
:
QGCPalette
.
Active
}
QGCPalette
{
id
:
palette
;
colorGroup
:
QGCPalette
.
Active
}
id
:
topLevel
id
:
topLevel
objectName
:
"
topLevel
"
objectName
:
"
topLevel
"
color
:
palette
.
window
color
:
palette
.
window
signal
buttonClicked
(
variant
component
);
Image
{
Image
{
anchors.fill
:
parent
anchors.fill
:
parent
fillMode
:
Image
.
PreserveAspectFit
fillMode
:
Image
.
PreserveAspectFit
smooth
:
true
smooth
:
true
source
:
autopilot
.
setupBackgroundImage
;
source
:
autopilot
.
setupBackgroundImage
;
}
}
Column
{
Column
{
anchors.margins
:
20
anchors.margins
:
20
anchors.fill
:
parent
anchors.fill
:
parent
spacing
:
5
spacing
:
5
Rectangle
{
id
:
header
;
color
:
"
lightblue
"
;
radius
:
10.0
;
width
:
parent
.
width
;
height
:
titleText
.
height
+
20
;
opacity
:
0.8
;
Text
{
id
:
titleText
;
anchors.centerIn
:
parent
;
font.pointSize
:
24
;
text
:
"
Vehicle Setup
"
}
}
Flow
{
Flow
{
width
:
parent
.
width
;
width
:
parent
.
width
;
height
:
parent
.
height
-
header
.
height
-
footer
.
height
height
:
parent
.
height
spacing
:
5
spacing
:
5
Repeater
{
Repeater
{
...
@@ -54,9 +49,8 @@ Rectangle {
...
@@ -54,9 +49,8 @@ Rectangle {
border.color
:
"
#888
"
border.color
:
"
#888
"
radius
:
10
radius
:
10
color
:
control
.
activeFocus
?
"
#47b
"
:
"
white
"
color
:
"
white
"
opacity
:
control
.
hovered
||
control
.
activeFocus
?
1
:
0.8
opacity
:
0.8
Behavior
on
opacity
{
NumberAnimation
{
duration
:
100
}}
Text
{
Text
{
id
:
titleBar
id
:
titleBar
...
@@ -108,23 +102,8 @@ Rectangle {
...
@@ -108,23 +102,8 @@ Rectangle {
label
:
Item
{}
label
:
Item
{}
}
}
onClicked
:
topLevel
.
buttonClicked
(
modelData
)
}
}
}
}
}
}
Rectangle
{
id
:
footer
;
color
:
"
lightblue
"
;
radius
:
10.0
;
width
:
parent
.
width
;
height
:
titleText
.
height
+
20
;
opacity
:
0.8
;
property
real
spacing
:
(
width
-
firmwareButton
.
width
-
parametersButton
.
width
)
/
3
Button
{
id
:
firmwareButton
;
objectName
:
"
firmwareButton
"
;
x
:
parent
.
spacing
;
anchors.verticalCenter
:
parent
.
verticalCenter
;
text
:
"
Firmware Upgrade
"
}
Button
{
id
:
parametersButton
;
objectName
:
"
parametersButton
"
x
:
firmwareButton
.
width
+
(
parent
.
spacing
*
2
);
anchors.verticalCenter
:
parent
.
verticalCenter
;
text
:
"
Parameters
"
}
}
}
}
}
}
src/test.qml
View file @
af38a105
import
QtQuick
2.2
import
QtQuick
2.2
import
QtQuick
.
Controls
1.2
import
QtQuick
.
Controls
1.2
import
QtQuick
.
Controls
.
Styles
1.2
import
QtQuick
.
Controls
.
Styles
1.2
//
import QGroundControl.FactControls 1.0
import
QGroundControl
.
FactControls
1.0
Row
{
width
:
200
Rectangle
{
Text
{
id
:
firstCol
;
text
:
"
Col 1
"
}
QGCPalette
{
id
:
palette
;
colorGroup
:
enabled
?
QGCPalette
.
Active
:
QGCPalette
.
Disabled
}
Text
{
horizontalAlignment
:
Text
.
AlignRight
;
width
:
parent
.
width
-
firstCol
.
contentWidth
;
text
:
"
Col 2
"
}
width
:
100
height
:
100
color
:
"
#e43f3f
"
// palette.windowText
}
}
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