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
f726b74a
Unverified
Commit
f726b74a
authored
Oct 01, 2019
by
Don Gagne
Committed by
GitHub
Oct 01, 2019
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #7849 from DonLakeFlyer/APMAirframe
ArduPilot: Airframe Setup
parents
0cf4b6ee
6b6aa978
Changes
4
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
302 additions
and
209 deletions
+302
-209
APMAirframeComponent.qml
src/AutoPilotPlugins/APM/APMAirframeComponent.qml
+47
-6
APMAirframeComponentController.cc
src/AutoPilotPlugins/APM/APMAirframeComponentController.cc
+76
-39
APMAirframeComponentController.h
src/AutoPilotPlugins/APM/APMAirframeComponentController.h
+20
-14
FirmwareUpgrade.qml
src/VehicleSetup/FirmwareUpgrade.qml
+159
-150
No files found.
src/AutoPilotPlugins/APM/APMAirframeComponent.qml
View file @
f726b74a
...
...
@@ -106,8 +106,15 @@ SetupPage {
readonly
property
real
innerMargin
:
ScreenTools
.
defaultFontPixelWidth
MouseArea
{
anchors.fill
:
parent
onClicked
:
airframeCheckBox
.
checked
=
true
anchors.fill
:
parent
onClicked
:
{
if
(
!
airframeCheckBox
.
checked
||
!
combo
.
valid
)
{
if
(
_frameTypeAvailable
&&
object
.
defaultFrameType
!=
-
1
)
{
_frameType
.
rawValue
=
object
.
defaultFrameType
}
airframeCheckBox
.
checked
=
true
}
}
}
QGCLabel
{
...
...
@@ -116,12 +123,14 @@ SetupPage {
}
Rectangle
{
id
:
imageComboRect
anchors.topMargin
:
ScreenTools
.
defaultFontPixelHeight
/
2
anchors.top
:
title
.
bottom
anchors.bottom
:
parent
.
bottom
anchors.left
:
parent
.
left
anchors.right
:
parent
.
right
color
:
airframeCheckBox
.
checked
?
qgcPal
.
buttonHighlight
:
qgcPal
.
windowShade
opacity
:
combo
.
valid
?
1.0
:
0.5
ColumnLayout
{
anchors.margins
:
innerMargin
...
...
@@ -136,7 +145,7 @@ SetupPage {
smooth
:
true
antialiasing
:
true
sourceSize.width
:
width
source
:
object
.
imageResource
source
:
airframeCheckBox
.
checked
?
object
.
imageResource
:
object
.
imageResourceDefault
}
QGCCheckBox
{
...
...
@@ -160,15 +169,47 @@ SetupPage {
visible
:
airframeCheckBox
.
checked
&&
object
.
frameTypeSupported
}
Fact
ComboBox
{
QGC
ComboBox
{
id
:
combo
Layout.fillWidth
:
true
fact
:
_frameType
indexModel
:
false
model
:
object
.
frameTypeEnumStrings
visible
:
airframeCheckBox
.
checked
&&
object
.
frameTypeSupported
onActivated
:
_frameType
.
rawValue
=
object
.
frameTypeEnumValues
[
index
]
property
bool
valid
:
true
function
checkFrameType
(
value
)
{
return
value
==
_frameType
.
rawValue
}
function
selectFrameType
()
{
var
index
=
object
.
frameTypeEnumValues
.
findIndex
(
checkFrameType
)
if
(
index
==
-
1
&&
combo
.
visible
)
{
// Frame Class/Type is set to an invalid combination
combo
.
valid
=
false
}
else
{
combo
.
currentIndex
=
index
combo
.
valid
=
true
}
}
Component.onCompleted
:
selectFrameType
()
Connections
{
target
:
_frameTypeAvailable
?
_frameType
:
null
ignoreUnknownSignals
:
true
onRawValueChanged
:
combo
.
selectFrameType
()
}
}
}
}
QGCLabel
{
anchors.fill
:
imageComboRect
text
:
qsTr
(
"
Invalid setting for FRAME_TYPE. Click to Reset.
"
)
wrapMode
:
Text
.
WordWrap
visible
:
!
combo
.
valid
}
}
}
// Repeater - summary boxes
}
// Flow - summary boxes
...
...
src/AutoPilotPlugins/APM/APMAirframeComponentController.cc
View file @
f726b74a
...
...
@@ -70,23 +70,35 @@ typedef struct {
}
FrameToImageInfo_t
;
static
const
FrameToImageInfo_t
s_rgFrameToImageCopter
[]
=
{
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_PLUS
,
"QuadRotorPlus"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_X
,
"QuadRotorX"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_V
,
"QuadRotorWide"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_H
,
"QuadRotorH"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_V_TAIL
,
"QuadRotorVTail"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_A_TAIL
,
"QuadRotorATail"
},
{
FRAME_CLASS_HEX
,
FRAME_TYPE_PLUS
,
"HexaRotorPlus"
},
{
FRAME_CLASS_HEX
,
FRAME_TYPE_X
,
"HexaRotorX"
},
{
FRAME_CLASS_OCTA
,
FRAME_TYPE_PLUS
,
"OctoRotorPlus"
},
{
FRAME_CLASS_OCTA
,
FRAME_TYPE_X
,
"OctoRotorX"
},
{
FRAME_CLASS_OCTAQUAD
,
FRAME_TYPE_PLUS
,
"OctoRotorPlusCoaxial"
},
{
FRAME_CLASS_OCTAQUAD
,
FRAME_TYPE_X
,
"OctoRotorXCoaxial"
},
{
FRAME_CLASS_Y6
,
FRAME_TYPE_Y6B
,
"Y6B"
},
{
FRAME_CLASS_Y6
,
FRAME_TYPE_Y6F
,
"AirframeUnknown"
},
{
FRAME_CLASS_Y6
,
-
1
,
"Y6A"
},
{
FRAME_CLASS_HELI
,
-
1
,
"Helicopter"
},
{
FRAME_CLASS_TRI
,
-
1
,
"YPlus"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_X
,
"QuadRotorX"
},
// Default
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_PLUS
,
"QuadRotorPlus"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_V
,
"QuadRotorWide"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_H
,
"QuadRotorH"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_V_TAIL
,
"QuadRotorVTail"
},
{
FRAME_CLASS_QUAD
,
FRAME_TYPE_A_TAIL
,
"QuadRotorATail"
},
{
FRAME_CLASS_HEX
,
FRAME_TYPE_X
,
"HexaRotorX"
},
// Default
{
FRAME_CLASS_HEX
,
FRAME_TYPE_PLUS
,
"HexaRotorPlus"
},
{
FRAME_CLASS_OCTA
,
FRAME_TYPE_X
,
"OctoRotorX"
},
// Default
{
FRAME_CLASS_OCTA
,
FRAME_TYPE_PLUS
,
"OctoRotorPlus"
},
{
FRAME_CLASS_OCTA
,
FRAME_TYPE_V
,
"AirframeUnknown"
},
{
FRAME_CLASS_OCTA
,
FRAME_TYPE_H
,
"AirframeUnknown"
},
{
FRAME_CLASS_OCTAQUAD
,
FRAME_TYPE_X
,
"OctoRotorXCoaxial"
},
// Default
{
FRAME_CLASS_OCTAQUAD
,
FRAME_TYPE_PLUS
,
"OctoRotorPlusCoaxial"
},
{
FRAME_CLASS_OCTAQUAD
,
FRAME_TYPE_V
,
"AirframeUnknown"
},
{
FRAME_CLASS_OCTAQUAD
,
FRAME_TYPE_H
,
"AirframeUnknown"
},
{
FRAME_CLASS_Y6
,
FRAME_TYPE_Y6B
,
"Y6B"
},
// Default
{
FRAME_CLASS_Y6
,
FRAME_TYPE_Y6F
,
"AirframeUnknown"
},
{
FRAME_CLASS_Y6
,
-
1
,
"Y6A"
},
{
FRAME_CLASS_DODECAHEXA
,
FRAME_TYPE_X
,
"AirframeUnknown"
},
// Default
{
FRAME_CLASS_DODECAHEXA
,
FRAME_TYPE_PLUS
,
"AirframeUnknown"
},
{
FRAME_CLASS_HELI
,
-
1
,
"Helicopter"
},
{
FRAME_CLASS_TRI
,
-
1
,
"YPlus"
},
};
static
const
FrameToImageInfo_t
s_rgFrameToImageRover
[]
=
{
...
...
@@ -94,14 +106,16 @@ static const FrameToImageInfo_t s_rgFrameToImageRover[] = {
{
FRAME_CLASS_BOAT
,
-
1
,
"Boat"
},
};
static
QString
s_findImageResourceCopter
(
int
frameClass
,
int
frameType
)
/// Returns the image resource for the frameClass, frameType pair
/// @param[in,out] frameType Specified frame type, or -1 to match first item in list (frameType found will be returned)
static
QString
s_findImageResourceCopter
(
int
frameClass
,
int
&
frameType
)
{
for
(
size_t
i
=
0
;
i
<
sizeof
(
s_rgFrameToImageCopter
)
/
sizeof
(
s_rgFrameToImageCopter
[
0
]);
i
++
)
{
const
FrameToImageInfo_t
*
pFrameToImageInfo
=
&
s_rgFrameToImageCopter
[
i
];
if
(
pFrameToImageInfo
->
frameClass
==
frameClass
&&
pFrameToImageInfo
->
frameType
==
frameType
)
{
return
pFrameToImageInfo
->
imageResource
;
}
else
if
(
pFrameToImageInfo
->
frameClass
==
frameClass
&&
pFrameToImageInfo
->
frameType
==
-
1
)
{
if
(
(
pFrameToImageInfo
->
frameClass
==
frameClass
&&
frameType
==
-
1
)
||
(
pFrameToImageInfo
->
frameClass
==
frameClass
&&
pFrameToImageInfo
->
frameType
==
frameType
))
{
frameType
=
pFrameToImageInfo
->
frameType
;
return
pFrameToImageInfo
->
imageResource
;
}
}
...
...
@@ -154,32 +168,19 @@ void APMAirframeComponentController::_fillFrameClasses()
for
(
int
i
=
1
;
i
<
_frameClassFact
->
enumStrings
().
count
();
i
++
)
{
QString
frameClassName
=
_frameClassFact
->
enumStrings
()[
i
];
int
frameClass
=
_frameClassFact
->
enumValues
()[
i
].
toInt
();
int
defaultFrameType
;
if
(
frameClass
==
FRAME_CLASS_HELI
)
{
// Heli requires it's own firmware variant. You can't switch to Heli from a Copter variant firmware.
continue
;
}
if
(
frameTypeNotSupported
.
contains
(
frameClass
))
{
defaultFrameType
=
-
1
;
}
else
{
defaultFrameType
=
FRAME_TYPE_X
;
}
_frameClassModel
->
append
(
new
APMFrameClass
(
frameClassName
,
true
/* copter */
,
frameClass
,
_frameTypeFact
,
defaultFrameType
,
_frameClassModel
));
_frameClassModel
->
append
(
new
APMFrameClass
(
frameClassName
,
true
/* copter */
,
frameClass
,
_frameTypeFact
,
_frameClassModel
));
}
}
else
if
(
qobject_cast
<
ArduRoverFirmwarePlugin
*>
(
fwPlugin
))
{
for
(
int
i
=
1
;
i
<
_frameClassFact
->
enumStrings
().
count
();
i
++
)
{
QString
frameClassName
=
_frameClassFact
->
enumStrings
()[
i
];
int
frameClass
=
_frameClassFact
->
enumValues
()[
i
].
toInt
();
int
defaultFrameType
;
if
(
_frameTypeFact
)
{
defaultFrameType
=
FRAME_TYPE_UNDEFINED
;
}
else
{
defaultFrameType
=
-
1
;
}
_frameClassModel
->
append
(
new
APMFrameClass
(
frameClassName
,
false
/* copter */
,
frameClass
,
_frameTypeFact
,
defaultFrameType
,
_frameClassModel
));
_frameClassModel
->
append
(
new
APMFrameClass
(
frameClassName
,
false
/* copter */
,
frameClass
,
_frameTypeFact
,
_frameClassModel
));
}
}
}
...
...
@@ -270,19 +271,55 @@ void APMAirframeComponentController::_paramFileDownloadError(QString errorMsg)
qgcApp
()
->
restoreOverrideCursor
();
}
APMFrameClass
::
APMFrameClass
(
const
QString
&
name
,
bool
copter
,
int
frameClass
,
Fact
*
frameTypeFact
,
int
defaultFrameType
,
QObject
*
parent
)
APMFrameClass
::
APMFrameClass
(
const
QString
&
name
,
bool
copter
,
int
frameClass
,
Fact
*
frameTypeFact
,
QObject
*
parent
)
:
QObject
(
parent
)
,
_name
(
name
)
,
_copter
(
copter
)
,
_frameClass
(
frameClass
)
,
_defaultFrameType
(
defaultFrameType
)
,
_frameTypeSupported
(
defaultFrameType
!=
-
1
)
,
_defaultFrameType
(
-
1
)
,
_frameTypeSupported
(
false
)
,
_frameTypeFact
(
frameTypeFact
)
{
if
(
frameTypeFact
)
{
connect
(
frameTypeFact
,
&
Fact
::
rawValueChanged
,
this
,
&
APMFrameClass
::
imageResourceChanged
);
connect
(
frameTypeFact
,
&
Fact
::
rawValueChanged
,
this
,
&
APMFrameClass
::
frameTypeChanged
);
}
if
(
copter
)
{
QList
<
int
>
rgSupportedFrameTypes
;
for
(
size_t
i
=
0
;
i
<
sizeof
(
s_rgFrameToImageCopter
)
/
sizeof
(
s_rgFrameToImageCopter
[
0
]);
i
++
)
{
const
FrameToImageInfo_t
*
pFrameToImageInfo
=
&
s_rgFrameToImageCopter
[
i
];
if
(
pFrameToImageInfo
->
frameClass
==
frameClass
)
{
if
(
_defaultFrameType
==
-
1
)
{
// Default frame type/icon is the first item found to match frameClass
_defaultFrameType
=
pFrameToImageInfo
->
frameType
;
_imageResourceDefault
=
QStringLiteral
(
"/qmlimages/Airframe/%1"
).
arg
(
pFrameToImageInfo
->
imageResource
);
}
if
(
pFrameToImageInfo
->
frameType
!=
-
1
)
{
// The list includes the supported frame types for the class
rgSupportedFrameTypes
.
append
(
pFrameToImageInfo
->
frameType
);
}
}
}
if
(
_imageResourceDefault
.
isEmpty
())
{
_imageResourceDefault
=
QStringLiteral
(
"/qmlimages/Airframe/AirframeUnknown"
);
}
// Filter the enums
for
(
const
int
frameType
:
rgSupportedFrameTypes
)
{
int
index
=
frameTypeFact
->
enumValues
().
indexOf
(
frameType
);
if
(
index
!=
-
1
)
{
_frameTypeEnumValues
.
append
(
frameType
);
_frameTypeEnumStrings
.
append
(
frameTypeFact
->
enumStrings
()[
index
]);
}
}
}
// If the frameClass is not in the list then frame type is not supported
_frameTypeSupported
=
_defaultFrameType
!=
-
1
;
}
APMFrameClass
::~
APMFrameClass
()
...
...
src/AutoPilotPlugins/APM/APMAirframeComponentController.h
View file @
f726b74a
...
...
@@ -54,25 +54,31 @@ class APMFrameClass : public QObject
Q_OBJECT
public:
APMFrameClass
(
const
QString
&
name
,
bool
copter
,
int
frameClass
,
Fact
*
frameTypeFact
,
int
defaultFrameType
,
QObject
*
parent
=
nullptr
);
APMFrameClass
(
const
QString
&
name
,
bool
copter
,
int
frameClass
,
Fact
*
frameTypeFact
,
QObject
*
parent
=
nullptr
);
~
APMFrameClass
();
Q_PROPERTY
(
QString
name
MEMBER
_name
CONSTANT
)
Q_PROPERTY
(
int
frameClass
MEMBER
_frameClass
CONSTANT
)
Q_PROPERTY
(
int
frameType
READ
frameType
NOTIFY
frameTypeChanged
)
Q_PROPERTY
(
int
defaultFrameType
MEMBER
_defaultFrameType
CONSTANT
)
Q_PROPERTY
(
QString
imageResource
READ
imageResource
NOTIFY
imageResourceChanged
)
Q_PROPERTY
(
bool
frameTypeSupported
MEMBER
_frameTypeSupported
CONSTANT
)
Q_PROPERTY
(
QString
name
MEMBER
_name
CONSTANT
)
Q_PROPERTY
(
int
frameClass
MEMBER
_frameClass
CONSTANT
)
Q_PROPERTY
(
int
frameType
READ
frameType
NOTIFY
frameTypeChanged
)
Q_PROPERTY
(
QStringList
frameTypeEnumStrings
MEMBER
_frameTypeEnumStrings
CONSTANT
)
Q_PROPERTY
(
QVariantList
frameTypeEnumValues
MEMBER
_frameTypeEnumValues
CONSTANT
)
Q_PROPERTY
(
int
defaultFrameType
MEMBER
_defaultFrameType
CONSTANT
)
Q_PROPERTY
(
QString
imageResource
READ
imageResource
NOTIFY
imageResourceChanged
)
Q_PROPERTY
(
QString
imageResourceDefault
MEMBER
_imageResourceDefault
CONSTANT
)
Q_PROPERTY
(
bool
frameTypeSupported
MEMBER
_frameTypeSupported
CONSTANT
)
int
frameType
(
void
)
{
return
_frameTypeFact
->
rawValue
().
toInt
();
}
;
int
frameType
(
void
)
{
return
_frameTypeFact
->
rawValue
().
toInt
();
}
QString
imageResource
(
void
);
QString
_name
;
bool
_copter
;
QString
_imageResource
;
int
_frameClass
;
int
_defaultFrameType
;
bool
_frameTypeSupported
;
QString
_name
;
bool
_copter
;
QString
_imageResource
;
QString
_imageResourceDefault
;
int
_frameClass
;
QStringList
_frameTypeEnumStrings
;
QVariantList
_frameTypeEnumValues
;
int
_defaultFrameType
;
bool
_frameTypeSupported
;
signals:
void
imageResourceChanged
(
void
);
...
...
src/VehicleSetup/FirmwareUpgrade.qml
View file @
f726b74a
This diff is collapsed.
Click to expand it.
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