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
790d03b4
Commit
790d03b4
authored
Jan 30, 2018
by
DonLakeFlyer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Initial Corridor Scan support
parent
8bf441af
Changes
32
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
32 changed files
with
2393 additions
and
16 deletions
+2393
-16
UnitTest.qrc
UnitTest.qrc
+5
-4
qgroundcontrol.pro
qgroundcontrol.pro
+8
-0
qgroundcontrol.qrc
qgroundcontrol.qrc
+4
-0
CameraCalc.h
src/MissionManager/CameraCalc.h
+8
-0
ComplexMissionItem.h
src/MissionManager/ComplexMissionItem.h
+2
-2
CorridorScan.SettingsGroup.json
src/MissionManager/CorridorScan.SettingsGroup.json
+46
-0
CorridorScanComplexItem.cc
src/MissionManager/CorridorScanComplexItem.cc
+417
-0
CorridorScanComplexItem.h
src/MissionManager/CorridorScanComplexItem.h
+138
-0
CorridorScanComplexItemTest.cc
src/MissionManager/CorridorScanComplexItemTest.cc
+217
-0
CorridorScanComplexItemTest.h
src/MissionManager/CorridorScanComplexItemTest.h
+84
-0
MissionController.cc
src/MissionManager/MissionController.cc
+14
-1
MissionController.h
src/MissionManager/MissionController.h
+1
-0
QGCMapPolygon.cc
src/MissionManager/QGCMapPolygon.cc
+17
-1
QGCMapPolygon.h
src/MissionManager/QGCMapPolygon.h
+4
-1
QGCMapPolygonTest.cc
src/MissionManager/QGCMapPolygonTest.cc
+10
-4
QGCMapPolygonTest.h
src/MissionManager/QGCMapPolygonTest.h
+1
-0
QGCMapPolyline.cc
src/MissionManager/QGCMapPolyline.cc
+440
-0
QGCMapPolyline.h
src/MissionManager/QGCMapPolyline.h
+114
-0
QGCMapPolylineTest.cc
src/MissionManager/QGCMapPolylineTest.cc
+202
-0
QGCMapPolylineTest.h
src/MissionManager/QGCMapPolylineTest.h
+71
-0
QGCMapPolylineVisuals.qml
src/MissionManager/QGCMapPolylineVisuals.qml
+287
-0
StructureScanComplexItem.cc
src/MissionManager/StructureScanComplexItem.cc
+1
-1
SurveyMissionItem.cc
src/MissionManager/SurveyMissionItem.cc
+2
-2
PolygonAreaTest.kml
src/MissionManager/UnitTest/PolygonAreaTest.kml
+48
-0
PolygonBadCoordinatesNode.kml
src/MissionManager/UnitTest/PolygonBadCoordinatesNode.kml
+0
-0
PolygonBadXml.kml
src/MissionManager/UnitTest/PolygonBadXml.kml
+0
-0
PolygonGood.kml
src/MissionManager/UnitTest/PolygonGood.kml
+0
-0
PolygonMissingNode.kml
src/MissionManager/UnitTest/PolygonMissingNode.kml
+0
-0
CorridorScanEditor.qml
src/PlanView/CorridorScanEditor.qml
+122
-0
CorridorScanMapVisual.qml
src/PlanView/CorridorScanMapVisual.qml
+125
-0
QGroundControl.Controls.qmldir
src/QmlControls/QGroundControl.Controls.qmldir
+1
-0
UnitTestList.cc
src/qgcunittest/UnitTestList.cc
+4
-0
No files found.
UnitTest.qrc
View file @
790d03b4
...
@@ -9,9 +9,10 @@
...
@@ -9,9 +9,10 @@
<file alias="MavCmdInfoVTOL.json">src/MissionManager/UnitTest/MavCmdInfoVTOL.json</file>
<file alias="MavCmdInfoVTOL.json">src/MissionManager/UnitTest/MavCmdInfoVTOL.json</file>
<file alias="MissionPlanner.waypoints">src/MissionManager/UnitTest/MissionPlanner.waypoints</file>
<file alias="MissionPlanner.waypoints">src/MissionManager/UnitTest/MissionPlanner.waypoints</file>
<file alias="OldFileFormat.mission">src/MissionManager/UnitTest/OldFileFormat.mission</file>
<file alias="OldFileFormat.mission">src/MissionManager/UnitTest/OldFileFormat.mission</file>
<file alias="GoodPolygon.kml">src/MissionManager/UnitTest/GoodPolygon.kml</file>
<file alias="PolygonAreaTest.kml">src/MissionManager/UnitTest/PolygonAreaTest.kml</file>
<file alias="MissingPolygonNode.kml">src/MissionManager/UnitTest/MissingPolygonNode.kml</file>
<file alias="PolygonGood.kml">src/MissionManager/UnitTest/PolygonGood.kml</file>
<file alias="BadXml.kml">src/MissionManager/UnitTest/BadXml.kml</file>
<file alias="PolygonMissingNode.kml">src/MissionManager/UnitTest/PolygonMissingNode.kml</file>
<file alias="BadCoordinatesNode.kml">src/MissionManager/UnitTest/BadCoordinatesNode.kml</file>
<file alias="PolygonBadXml.kml">src/MissionManager/UnitTest/PolygonBadXml.kml</file>
<file alias="PolygonBadCoordinatesNode.kml">src/MissionManager/UnitTest/PolygonBadCoordinatesNode.kml</file>
</qresource>
</qresource>
</RCC>
</RCC>
qgroundcontrol.pro
View file @
790d03b4
...
@@ -415,6 +415,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
...
@@ -415,6 +415,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
src
/
FactSystem
/
FactSystemTestPX4
.
h
\
src
/
FactSystem
/
FactSystemTestPX4
.
h
\
src
/
FactSystem
/
ParameterManagerTest
.
h
\
src
/
FactSystem
/
ParameterManagerTest
.
h
\
src
/
MissionManager
/
CameraSectionTest
.
h
\
src
/
MissionManager
/
CameraSectionTest
.
h
\
src
/
MissionManager
/
CorridorScanComplexItemTest
.
h
\
src
/
MissionManager
/
MissionCommandTreeTest
.
h
\
src
/
MissionManager
/
MissionCommandTreeTest
.
h
\
src
/
MissionManager
/
MissionControllerManagerTest
.
h
\
src
/
MissionManager
/
MissionControllerManagerTest
.
h
\
src
/
MissionManager
/
MissionControllerTest
.
h
\
src
/
MissionManager
/
MissionControllerTest
.
h
\
...
@@ -423,6 +424,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
...
@@ -423,6 +424,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
src
/
MissionManager
/
MissionSettingsTest
.
h
\
src
/
MissionManager
/
MissionSettingsTest
.
h
\
src
/
MissionManager
/
PlanMasterControllerTest
.
h
\
src
/
MissionManager
/
PlanMasterControllerTest
.
h
\
src
/
MissionManager
/
QGCMapPolygonTest
.
h
\
src
/
MissionManager
/
QGCMapPolygonTest
.
h
\
src
/
MissionManager
/
QGCMapPolylineTest
.
h
\
src
/
MissionManager
/
SectionTest
.
h
\
src
/
MissionManager
/
SectionTest
.
h
\
src
/
MissionManager
/
SimpleMissionItemTest
.
h
\
src
/
MissionManager
/
SimpleMissionItemTest
.
h
\
src
/
MissionManager
/
SpeedSectionTest
.
h
\
src
/
MissionManager
/
SpeedSectionTest
.
h
\
...
@@ -452,6 +454,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
...
@@ -452,6 +454,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
src
/
FactSystem
/
FactSystemTestPX4
.
cc
\
src
/
FactSystem
/
FactSystemTestPX4
.
cc
\
src
/
FactSystem
/
ParameterManagerTest
.
cc
\
src
/
FactSystem
/
ParameterManagerTest
.
cc
\
src
/
MissionManager
/
CameraSectionTest
.
cc
\
src
/
MissionManager
/
CameraSectionTest
.
cc
\
src
/
MissionManager
/
CorridorScanComplexItemTest
.
cc
\
src
/
MissionManager
/
MissionCommandTreeTest
.
cc
\
src
/
MissionManager
/
MissionCommandTreeTest
.
cc
\
src
/
MissionManager
/
MissionControllerManagerTest
.
cc
\
src
/
MissionManager
/
MissionControllerManagerTest
.
cc
\
src
/
MissionManager
/
MissionControllerTest
.
cc
\
src
/
MissionManager
/
MissionControllerTest
.
cc
\
...
@@ -460,6 +463,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
...
@@ -460,6 +463,7 @@ DebugBuild { PX4FirmwarePlugin { PX4FirmwarePluginFactory { APMFirmwarePlugin {
src
/
MissionManager
/
MissionSettingsTest
.
cc
\
src
/
MissionManager
/
MissionSettingsTest
.
cc
\
src
/
MissionManager
/
PlanMasterControllerTest
.
cc
\
src
/
MissionManager
/
PlanMasterControllerTest
.
cc
\
src
/
MissionManager
/
QGCMapPolygonTest
.
cc
\
src
/
MissionManager
/
QGCMapPolygonTest
.
cc
\
src
/
MissionManager
/
QGCMapPolylineTest
.
cc
\
src
/
MissionManager
/
SectionTest
.
cc
\
src
/
MissionManager
/
SectionTest
.
cc
\
src
/
MissionManager
/
SimpleMissionItemTest
.
cc
\
src
/
MissionManager
/
SimpleMissionItemTest
.
cc
\
src
/
MissionManager
/
SpeedSectionTest
.
cc
\
src
/
MissionManager
/
SpeedSectionTest
.
cc
\
...
@@ -508,6 +512,7 @@ HEADERS += \
...
@@ -508,6 +512,7 @@ HEADERS += \
src
/
MissionManager
/
CameraSection
.
h
\
src
/
MissionManager
/
CameraSection
.
h
\
src
/
MissionManager
/
CameraSpec
.
h
\
src
/
MissionManager
/
CameraSpec
.
h
\
src
/
MissionManager
/
ComplexMissionItem
.
h
\
src
/
MissionManager
/
ComplexMissionItem
.
h
\
src
/
MissionManager
/
CorridorScanComplexItem
.
h
\
src
/
MissionManager
/
FixedWingLandingComplexItem
.
h
\
src
/
MissionManager
/
FixedWingLandingComplexItem
.
h
\
src
/
MissionManager
/
GeoFenceController
.
h
\
src
/
MissionManager
/
GeoFenceController
.
h
\
src
/
MissionManager
/
GeoFenceManager
.
h
\
src
/
MissionManager
/
GeoFenceManager
.
h
\
...
@@ -526,6 +531,7 @@ HEADERS += \
...
@@ -526,6 +531,7 @@ HEADERS += \
src
/
MissionManager
/
QGCFencePolygon
.
h
\
src
/
MissionManager
/
QGCFencePolygon
.
h
\
src
/
MissionManager
/
QGCMapCircle
.
h
\
src
/
MissionManager
/
QGCMapCircle
.
h
\
src
/
MissionManager
/
QGCMapPolygon
.
h
\
src
/
MissionManager
/
QGCMapPolygon
.
h
\
src
/
MissionManager
/
QGCMapPolyline
.
h
\
src
/
MissionManager
/
RallyPoint
.
h
\
src
/
MissionManager
/
RallyPoint
.
h
\
src
/
MissionManager
/
RallyPointController
.
h
\
src
/
MissionManager
/
RallyPointController
.
h
\
src
/
MissionManager
/
RallyPointManager
.
h
\
src
/
MissionManager
/
RallyPointManager
.
h
\
...
@@ -700,6 +706,7 @@ SOURCES += \
...
@@ -700,6 +706,7 @@ SOURCES += \
src
/
MissionManager
/
CameraSection
.
cc
\
src
/
MissionManager
/
CameraSection
.
cc
\
src
/
MissionManager
/
CameraSpec
.
cc
\
src
/
MissionManager
/
CameraSpec
.
cc
\
src
/
MissionManager
/
ComplexMissionItem
.
cc
\
src
/
MissionManager
/
ComplexMissionItem
.
cc
\
src
/
MissionManager
/
CorridorScanComplexItem
.
cc
\
src
/
MissionManager
/
FixedWingLandingComplexItem
.
cc
\
src
/
MissionManager
/
FixedWingLandingComplexItem
.
cc
\
src
/
MissionManager
/
GeoFenceController
.
cc
\
src
/
MissionManager
/
GeoFenceController
.
cc
\
src
/
MissionManager
/
GeoFenceManager
.
cc
\
src
/
MissionManager
/
GeoFenceManager
.
cc
\
...
@@ -718,6 +725,7 @@ SOURCES += \
...
@@ -718,6 +725,7 @@ SOURCES += \
src
/
MissionManager
/
QGCFencePolygon
.
cc
\
src
/
MissionManager
/
QGCFencePolygon
.
cc
\
src
/
MissionManager
/
QGCMapCircle
.
cc
\
src
/
MissionManager
/
QGCMapCircle
.
cc
\
src
/
MissionManager
/
QGCMapPolygon
.
cc
\
src
/
MissionManager
/
QGCMapPolygon
.
cc
\
src
/
MissionManager
/
QGCMapPolyline
.
cc
\
src
/
MissionManager
/
RallyPoint
.
cc
\
src
/
MissionManager
/
RallyPoint
.
cc
\
src
/
MissionManager
/
RallyPointController
.
cc
\
src
/
MissionManager
/
RallyPointController
.
cc
\
src
/
MissionManager
/
RallyPointManager
.
cc
\
src
/
MissionManager
/
RallyPointManager
.
cc
\
...
...
qgroundcontrol.qrc
View file @
790d03b4
...
@@ -18,6 +18,7 @@
...
@@ -18,6 +18,7 @@
<file alias="AnalyzeView.qml">src/AnalyzeView/AnalyzeView.qml</file>
<file alias="AnalyzeView.qml">src/AnalyzeView/AnalyzeView.qml</file>
<file alias="AppSettings.qml">src/ui/AppSettings.qml</file>
<file alias="AppSettings.qml">src/ui/AppSettings.qml</file>
<file alias="BluetoothSettings.qml">src/ui/preferences/BluetoothSettings.qml</file>
<file alias="BluetoothSettings.qml">src/ui/preferences/BluetoothSettings.qml</file>
<file alias="CorridorScanEditor.qml">src/PlanView/CorridorScanEditor.qml</file>
<file alias="CustomCommandWidget.qml">src/ViewWidgets/CustomCommandWidget.qml</file>
<file alias="CustomCommandWidget.qml">src/ViewWidgets/CustomCommandWidget.qml</file>
<file alias="DebugWindow.qml">src/ui/preferences/DebugWindow.qml</file>
<file alias="DebugWindow.qml">src/ui/preferences/DebugWindow.qml</file>
<file alias="ESP8266Component.qml">src/AutoPilotPlugins/Common/ESP8266Component.qml</file>
<file alias="ESP8266Component.qml">src/AutoPilotPlugins/Common/ESP8266Component.qml</file>
...
@@ -48,6 +49,7 @@
...
@@ -48,6 +49,7 @@
<file alias="QGroundControl/Controls/CameraCalc.qml">src/PlanView/CameraCalc.qml</file>
<file alias="QGroundControl/Controls/CameraCalc.qml">src/PlanView/CameraCalc.qml</file>
<file alias="QGroundControl/Controls/CameraSection.qml">src/PlanView/CameraSection.qml</file>
<file alias="QGroundControl/Controls/CameraSection.qml">src/PlanView/CameraSection.qml</file>
<file alias="QGroundControl/Controls/ClickableColor.qml">src/QmlControls/ClickableColor.qml</file>
<file alias="QGroundControl/Controls/ClickableColor.qml">src/QmlControls/ClickableColor.qml</file>
<file alias="QGroundControl/Controls/CorridorScanMapVisual.qml">src/PlanView/CorridorScanMapVisual.qml</file>
<file alias="QGroundControl/Controls/DropButton.qml">src/QmlControls/DropButton.qml</file>
<file alias="QGroundControl/Controls/DropButton.qml">src/QmlControls/DropButton.qml</file>
<file alias="QGroundControl/Controls/EditPositionDialog.qml">src/QmlControls/EditPositionDialog.qml</file>
<file alias="QGroundControl/Controls/EditPositionDialog.qml">src/QmlControls/EditPositionDialog.qml</file>
<file alias="QGroundControl/Controls/ExclusiveGroupItem.qml">src/QmlControls/ExclusiveGroupItem.qml</file>
<file alias="QGroundControl/Controls/ExclusiveGroupItem.qml">src/QmlControls/ExclusiveGroupItem.qml</file>
...
@@ -89,6 +91,7 @@
...
@@ -89,6 +91,7 @@
<file alias="QGroundControl/Controls/QGCMapLabel.qml">src/QmlControls/QGCMapLabel.qml</file>
<file alias="QGroundControl/Controls/QGCMapLabel.qml">src/QmlControls/QGCMapLabel.qml</file>
<file alias="QGroundControl/Controls/QGCMapCircleVisuals.qml">src/MissionManager/QGCMapCircleVisuals.qml</file>
<file alias="QGroundControl/Controls/QGCMapCircleVisuals.qml">src/MissionManager/QGCMapCircleVisuals.qml</file>
<file alias="QGroundControl/Controls/QGCMapPolygonVisuals.qml">src/MissionManager/QGCMapPolygonVisuals.qml</file>
<file alias="QGroundControl/Controls/QGCMapPolygonVisuals.qml">src/MissionManager/QGCMapPolygonVisuals.qml</file>
<file alias="QGroundControl/Controls/QGCMapPolylineVisuals.qml">src/MissionManager/QGCMapPolylineVisuals.qml</file>
<file alias="QGroundControl/Controls/QGCMouseArea.qml">src/QmlControls/QGCMouseArea.qml</file>
<file alias="QGroundControl/Controls/QGCMouseArea.qml">src/QmlControls/QGCMouseArea.qml</file>
<file alias="QGroundControl/Controls/QGCMovableItem.qml">src/QmlControls/QGCMovableItem.qml</file>
<file alias="QGroundControl/Controls/QGCMovableItem.qml">src/QmlControls/QGCMovableItem.qml</file>
<file alias="QGroundControl/Controls/QGCPipable.qml">src/QmlControls/QGCPipable.qml</file>
<file alias="QGroundControl/Controls/QGCPipable.qml">src/QmlControls/QGCPipable.qml</file>
...
@@ -202,6 +205,7 @@
...
@@ -202,6 +205,7 @@
<file alias="QGCMapCircle.Facts.json">src/MissionManager/QGCMapCircle.Facts.json</file>
<file alias="QGCMapCircle.Facts.json">src/MissionManager/QGCMapCircle.Facts.json</file>
<file alias="RTK.SettingsGroup.json">src/Settings/RTK.SettingsGroup.json</file>
<file alias="RTK.SettingsGroup.json">src/Settings/RTK.SettingsGroup.json</file>
<file alias="Survey.SettingsGroup.json">src/MissionManager/Survey.SettingsGroup.json</file>
<file alias="Survey.SettingsGroup.json">src/MissionManager/Survey.SettingsGroup.json</file>
<file alias="CorridorScan.SettingsGroup.json">src/MissionManager/CorridorScan.SettingsGroup.json</file>
<file alias="StructureScan.SettingsGroup.json">src/MissionManager/StructureScan.SettingsGroup.json</file>
<file alias="StructureScan.SettingsGroup.json">src/MissionManager/StructureScan.SettingsGroup.json</file>
<file alias="Units.SettingsGroup.json">src/Settings/Units.SettingsGroup.json</file>
<file alias="Units.SettingsGroup.json">src/Settings/Units.SettingsGroup.json</file>
<file alias="Video.SettingsGroup.json">src/Settings/Video.SettingsGroup.json</file>
<file alias="Video.SettingsGroup.json">src/Settings/Video.SettingsGroup.json</file>
...
...
src/MissionManager/CameraCalc.h
View file @
790d03b4
...
@@ -49,6 +49,14 @@ public:
...
@@ -49,6 +49,14 @@ public:
Fact
*
adjustedFootprintSide
(
void
)
{
return
&
_adjustedFootprintSideFact
;
}
Fact
*
adjustedFootprintSide
(
void
)
{
return
&
_adjustedFootprintSideFact
;
}
Fact
*
adjustedFootprintFrontal
(
void
)
{
return
&
_adjustedFootprintFrontalFact
;
}
Fact
*
adjustedFootprintFrontal
(
void
)
{
return
&
_adjustedFootprintFrontalFact
;
}
const
Fact
*
valueSetIsDistance
(
void
)
const
{
return
&
_valueSetIsDistanceFact
;
}
const
Fact
*
distanceToSurface
(
void
)
const
{
return
&
_distanceToSurfaceFact
;
}
const
Fact
*
imageDensity
(
void
)
const
{
return
&
_imageDensityFact
;
}
const
Fact
*
frontalOverlap
(
void
)
const
{
return
&
_frontalOverlapFact
;
}
const
Fact
*
sideOverlap
(
void
)
const
{
return
&
_sideOverlapFact
;
}
const
Fact
*
adjustedFootprintSide
(
void
)
const
{
return
&
_adjustedFootprintSideFact
;
}
const
Fact
*
adjustedFootprintFrontal
(
void
)
const
{
return
&
_adjustedFootprintFrontalFact
;
}
bool
isManualCamera
(
void
)
{
return
cameraName
()
==
manualCameraName
();
}
bool
isManualCamera
(
void
)
{
return
cameraName
()
==
manualCameraName
();
}
double
imageFootprintSide
(
void
)
const
{
return
_imageFootprintSide
;
}
double
imageFootprintSide
(
void
)
const
{
return
_imageFootprintSide
;
}
double
imageFootprintFrontal
(
void
)
const
{
return
_imageFootprintFrontal
;
}
double
imageFootprintFrontal
(
void
)
const
{
return
_imageFootprintFrontal
;
}
...
...
src/MissionManager/ComplexMissionItem.h
View file @
790d03b4
...
@@ -47,9 +47,9 @@ public:
...
@@ -47,9 +47,9 @@ public:
static
const
char
*
jsonComplexItemTypeKey
;
static
const
char
*
jsonComplexItemTypeKey
;
signals:
signals:
void
complexDistanceChanged
(
double
complexDistance
);
void
complexDistanceChanged
(
void
);
void
greatestDistanceToChanged
(
void
);
void
greatestDistanceToChanged
(
void
);
void
additionalTimeDelayChanged
(
double
additionalTimeDelay
);
void
additionalTimeDelayChanged
(
void
);
};
};
#endif
#endif
src/MissionManager/CorridorScan.SettingsGroup.json
0 → 100644
View file @
790d03b4
[
{
"name"
:
"Altitude"
,
"shortDescription"
:
"Altitude for the bottom layer of the structure scan."
,
"type"
:
"double"
,
"units"
:
"m"
,
"decimalPlaces"
:
1
,
"defaultValue"
:
50
},
{
"name"
:
"CorridorWidth"
,
"shortDescription"
:
"Corridor width. Specify 0 width for a single pass scan."
,
"type"
:
"double"
,
"units"
:
"m"
,
"min"
:
0
,
"decimalPlaces"
:
1
,
"defaultValue"
:
50
},
{
"name"
:
"Trigger distance"
,
"shortDescription"
:
"Distance between each triggering of the camera. 0 specifies not camera trigger."
,
"type"
:
"double"
,
"decimalPlaces"
:
2
,
"min"
:
0
,
"units"
:
"m"
,
"defaultValue"
:
25
},
{
"name"
:
"GridSpacing"
,
"shortDescription"
:
"Amount of spacing in between parallel grid lines."
,
"type"
:
"double"
,
"decimalPlaces"
:
2
,
"min"
:
0.1
,
"units"
:
"m"
,
"defaultValue"
:
30
},
{
"name"
:
"TurnaroundDist"
,
"shortDescription"
:
"Amount of additional distance to add outside the grid area for vehicle turnaround."
,
"type"
:
"double"
,
"decimalPlaces"
:
2
,
"min"
:
0
,
"units"
:
"m"
,
"defaultValue"
:
30
}
]
src/MissionManager/CorridorScanComplexItem.cc
0 → 100644
View file @
790d03b4
This diff is collapsed.
Click to expand it.
src/MissionManager/CorridorScanComplexItem.h
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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.
*
****************************************************************************/
#pragma once
#include "ComplexMissionItem.h"
#include "MissionItem.h"
#include "SettingsFact.h"
#include "QGCLoggingCategory.h"
#include "QGCMapPolyline.h"
#include "QGCMapPolygon.h"
#include "CameraCalc.h"
Q_DECLARE_LOGGING_CATEGORY
(
CorridorScanComplexItemLog
)
class
CorridorScanComplexItem
:
public
ComplexMissionItem
{
Q_OBJECT
public:
CorridorScanComplexItem
(
Vehicle
*
vehicle
,
QObject
*
parent
=
NULL
);
Q_PROPERTY
(
CameraCalc
*
cameraCalc
READ
cameraCalc
CONSTANT
)
Q_PROPERTY
(
QGCMapPolyline
*
corridorPolyline
READ
corridorPolyline
CONSTANT
)
Q_PROPERTY
(
QGCMapPolygon
*
corridorPolygon
READ
corridorPolygon
CONSTANT
)
Q_PROPERTY
(
Fact
*
corridorWidth
READ
corridorWidth
CONSTANT
)
Q_PROPERTY
(
int
cameraShots
READ
cameraShots
NOTIFY
cameraShotsChanged
)
Q_PROPERTY
(
double
timeBetweenShots
READ
timeBetweenShots
NOTIFY
timeBetweenShotsChanged
)
Q_PROPERTY
(
double
coveredArea
READ
coveredArea
NOTIFY
coveredAreaChanged
)
Q_PROPERTY
(
double
cameraMinTriggerInterval
MEMBER
_cameraMinTriggerInterval
NOTIFY
cameraMinTriggerIntervalChanged
)
Q_PROPERTY
(
QVariantList
transectPoints
READ
transectPoints
NOTIFY
transectPointsChanged
)
CameraCalc
*
cameraCalc
(
void
)
{
return
&
_cameraCalc
;
}
QGCMapPolyline
*
corridorPolyline
(
void
)
{
return
&
_corridorPolyline
;
}
QGCMapPolygon
*
corridorPolygon
(
void
)
{
return
&
_corridorPolygon
;
}
Fact
*
corridorWidth
(
void
)
{
return
&
_corridorWidthFact
;
}
QVariantList
transectPoints
(
void
)
{
return
_transectPoints
;
}
int
cameraShots
(
void
)
const
{
return
_cameraShots
;
}
double
timeBetweenShots
(
void
);
double
coveredArea
(
void
)
const
;
Q_INVOKABLE
void
rotateEntryPoint
(
void
);
// Overrides from ComplexMissionItem
double
complexDistance
(
void
)
const
final
{
return
_scanDistance
;
}
int
lastSequenceNumber
(
void
)
const
final
;
bool
load
(
const
QJsonObject
&
complexObject
,
int
sequenceNumber
,
QString
&
errorString
)
final
;
double
greatestDistanceTo
(
const
QGeoCoordinate
&
other
)
const
final
;
QString
mapVisualQML
(
void
)
const
final
{
return
QStringLiteral
(
"CorridorScanMapVisual.qml"
);
}
// Overrides from VisualMissionItem
bool
dirty
(
void
)
const
final
{
return
_dirty
;
}
bool
isSimpleItem
(
void
)
const
final
{
return
false
;
}
bool
isStandaloneCoordinate
(
void
)
const
final
{
return
false
;
}
bool
specifiesCoordinate
(
void
)
const
final
;
bool
specifiesAltitudeOnly
(
void
)
const
final
{
return
false
;
}
QString
commandDescription
(
void
)
const
final
{
return
tr
(
"Corridor Scan"
);
}
QString
commandName
(
void
)
const
final
{
return
tr
(
"Corridor Scan"
);
}
QString
abbreviation
(
void
)
const
final
{
return
"S"
;
}
QGeoCoordinate
coordinate
(
void
)
const
final
{
return
_coordinate
;
}
QGeoCoordinate
exitCoordinate
(
void
)
const
final
{
return
_exitCoordinate
;
}
int
sequenceNumber
(
void
)
const
final
{
return
_sequenceNumber
;
}
double
specifiedFlightSpeed
(
void
)
final
{
return
std
::
numeric_limits
<
double
>::
quiet_NaN
();
}
double
specifiedGimbalYaw
(
void
)
final
{
return
std
::
numeric_limits
<
double
>::
quiet_NaN
();
}
double
specifiedGimbalPitch
(
void
)
final
{
return
std
::
numeric_limits
<
double
>::
quiet_NaN
();
}
void
appendMissionItems
(
QList
<
MissionItem
*>&
items
,
QObject
*
missionItemParent
)
final
;
void
setMissionFlightStatus
(
MissionController
::
MissionFlightStatus_t
&
missionFlightStatus
)
final
;
void
applyNewAltitude
(
double
newAltitude
)
final
;
bool
coordinateHasRelativeAltitude
(
void
)
const
final
{
return
true
/*_altitudeRelative*/
;
}
bool
exitCoordinateHasRelativeAltitude
(
void
)
const
final
{
return
true
/*_altitudeRelative*/
;
}
bool
exitCoordinateSameAsEntry
(
void
)
const
final
{
return
false
;
}
void
setDirty
(
bool
dirty
)
final
;
void
setCoordinate
(
const
QGeoCoordinate
&
coordinate
)
final
{
Q_UNUSED
(
coordinate
);
}
void
setSequenceNumber
(
int
sequenceNumber
)
final
;
void
save
(
QJsonArray
&
missionItems
)
final
;
static
const
char
*
jsonComplexItemTypeValue
;
signals:
void
cameraShotsChanged
(
void
);
void
timeBetweenShotsChanged
(
void
);
void
cameraMinTriggerIntervalChanged
(
double
cameraMinTriggerInterval
);
void
altitudeRelativeChanged
(
bool
altitudeRelative
);
void
transectPointsChanged
(
void
);
void
coveredAreaChanged
(
void
);
private
slots
:
void
_setDirty
(
void
);
void
_polylineDirtyChanged
(
bool
dirty
);
void
_polylineCountChanged
(
int
count
);
void
_clearInternal
(
void
);
void
_updateCoordinateAltitudes
(
void
);
void
_signalLastSequenceNumberChanged
(
void
);
void
_rebuildCorridor
(
void
);
void
_rebuildTransects
(
void
);
private:
void
_setExitCoordinate
(
const
QGeoCoordinate
&
coordinate
);
void
_setScanDistance
(
double
scanDistance
);
void
_setCameraShots
(
int
cameraShots
);
double
_triggerDistance
(
void
)
const
;
int
_transectCount
(
void
)
const
;
void
_rebuildCorridorPolygon
(
void
);
int
_sequenceNumber
;
bool
_dirty
;
QGeoCoordinate
_coordinate
;
QGeoCoordinate
_exitCoordinate
;
QGCMapPolyline
_corridorPolyline
;
QGCMapPolygon
_corridorPolygon
;
Fact
_corridorWidthFact
;
QVariantList
_transectPoints
;
bool
_ignoreRecalc
;
double
_scanDistance
;
int
_cameraShots
;
double
_timeBetweenShots
;
double
_cameraMinTriggerInterval
;
double
_cruiseSpeed
;
CameraCalc
_cameraCalc
;
static
QMap
<
QString
,
FactMetaData
*>
_metaDataMap
;
static
const
char
*
_corridorWidthFactName
;
static
const
char
*
_jsonCameraCalcKey
;
};
src/MissionManager/CorridorScanComplexItemTest.cc
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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.
*
****************************************************************************/
#include "CorridorScanComplexItemTest.h"
#include "QGCApplication.h"
CorridorScanComplexItemTest
::
CorridorScanComplexItemTest
(
void
)
:
_offlineVehicle
(
NULL
)
{
_linePoints
<<
QGeoCoordinate
(
47.633550640000003
,
-
122.08982199
)
<<
QGeoCoordinate
(
47.634129020000003
,
-
122.08887249
)
<<
QGeoCoordinate
(
47.633619320000001
,
-
122.08811074
);
}
void
CorridorScanComplexItemTest
::
init
(
void
)
{
UnitTest
::
init
();
_offlineVehicle
=
new
Vehicle
(
MAV_AUTOPILOT_PX4
,
MAV_TYPE_QUADROTOR
,
qgcApp
()
->
toolbox
()
->
firmwarePluginManager
(),
this
);
_corridorItem
=
new
CorridorScanComplexItem
(
_offlineVehicle
,
this
);
// _corridorItem->setTurnaroundDist(0); // Unit test written for no turnaround distance
_corridorItem
->
setDirty
(
false
);
_mapPolyline
=
_corridorItem
->
corridorPolyline
();
_rgSignals
[
complexDistanceChangedIndex
]
=
SIGNAL
(
complexDistanceChanged
());
_rgSignals
[
greatestDistanceToChangedIndex
]
=
SIGNAL
(
greatestDistanceToChanged
());
_rgSignals
[
additionalTimeDelayChangedIndex
]
=
SIGNAL
(
additionalTimeDelayChanged
());
_rgSignals
[
transectPointsChangedIndex
]
=
SIGNAL
(
transectPointsChanged
());
_rgSignals
[
cameraShotsChangedIndex
]
=
SIGNAL
(
cameraShotsChanged
());
_rgSignals
[
coveredAreaChangedIndex
]
=
SIGNAL
(
coveredAreaChanged
());
_rgSignals
[
timeBetweenShotsChangedIndex
]
=
SIGNAL
(
timeBetweenShotsChanged
());
_rgSignals
[
dirtyChangedIndex
]
=
SIGNAL
(
dirtyChanged
(
bool
));
_multiSpy
=
new
MultiSignalSpy
();
QCOMPARE
(
_multiSpy
->
init
(
_corridorItem
,
_rgSignals
,
_cSignals
),
true
);
_rgCorridorPolygonSignals
[
corridorPolygonPathChangedIndex
]
=
SIGNAL
(
pathChanged
());
_multiSpyCorridorPolygon
=
new
MultiSignalSpy
();
QCOMPARE
(
_multiSpyCorridorPolygon
->
init
(
_corridorItem
->
corridorPolygon
(),
_rgCorridorPolygonSignals
,
_cCorridorPolygonSignals
),
true
);
}
void
CorridorScanComplexItemTest
::
cleanup
(
void
)
{
delete
_corridorItem
;
delete
_offlineVehicle
;
delete
_multiSpy
;
}
void
CorridorScanComplexItemTest
::
_testDirty
(
void
)
{
QVERIFY
(
!
_corridorItem
->
dirty
());
_corridorItem
->
setDirty
(
false
);
QVERIFY
(
!
_corridorItem
->
dirty
());
QVERIFY
(
_multiSpy
->
checkNoSignals
());
_corridorItem
->
setDirty
(
true
);
QVERIFY
(
_corridorItem
->
dirty
());
QVERIFY
(
_multiSpy
->
checkOnlySignalByMask
(
dirtyChangedMask
));
QVERIFY
(
_multiSpy
->
pullBoolFromSignalIndex
(
dirtyChangedIndex
));
_multiSpy
->
clearAllSignals
();
_corridorItem
->
setDirty
(
false
);
QVERIFY
(
!
_corridorItem
->
dirty
());
QVERIFY
(
_multiSpy
->
checkOnlySignalByMask
(
dirtyChangedMask
));
QVERIFY
(
!
_multiSpy
->
pullBoolFromSignalIndex
(
dirtyChangedIndex
));
_multiSpy
->
clearAllSignals
();
// These facts should set dirty when changed
QList
<
Fact
*>
rgFacts
;
#if 0
rgFacts << _corridorItem->gridAltitude() << _corridorItem->gridAngle() << _corridorItem->gridSpacing() << _corridorItem->turnaroundDist() << _corridorItem->cameraTriggerDistance() <<
_corridorItem->gridAltitudeRelative() << _corridorItem->cameraTriggerInTurnaround() << _corridorItem->hoverAndCapture();
#endif
rgFacts
<<
_corridorItem
->
corridorWidth
();
foreach
(
Fact
*
fact
,
rgFacts
)
{
qDebug
()
<<
fact
->
name
();
QVERIFY
(
!
_corridorItem
->
dirty
());
if
(
fact
->
typeIsBool
())
{
fact
->
setRawValue
(
!
fact
->
rawValue
().
toBool
());
}
else
{
fact
->
setRawValue
(
fact
->
rawValue
().
toDouble
()
+
1
);
}
QVERIFY
(
_multiSpy
->
checkSignalByMask
(
dirtyChangedMask
));
QVERIFY
(
_multiSpy
->
pullBoolFromSignalIndex
(
dirtyChangedIndex
));
_corridorItem
->
setDirty
(
false
);
_multiSpy
->
clearAllSignals
();
}
rgFacts
.
clear
();
// These facts should not change dirty bit
#if 0
rgFacts << _corridorItem->groundResolution() << _corridorItem->frontalOverlap() << _corridorItem->sideOverlap() << _corridorItem->cameraSensorWidth() << _corridorItem->cameraSensorHeight() <<
_corridorItem->cameraResolutionWidth() << _corridorItem->cameraResolutionHeight() << _corridorItem->cameraFocalLength() << _corridorItem->cameraOrientationLandscape() <<
_corridorItem->fixedValueIsAltitude() << _corridorItem->camera() << _corridorItem->manualGrid();
#endif
foreach
(
Fact
*
fact
,
rgFacts
)
{
qDebug
()
<<
fact
->
name
();
QVERIFY
(
!
_corridorItem
->
dirty
());
if
(
fact
->
typeIsBool
())
{
fact
->
setRawValue
(
!
fact
->
rawValue
().
toBool
());
}
else
{
fact
->
setRawValue
(
fact
->
rawValue
().
toDouble
()
+
1
);
}
QVERIFY
(
_multiSpy
->
checkNoSignalByMask
(
dirtyChangedMask
));
QVERIFY
(
!
_corridorItem
->
dirty
());
_multiSpy
->
clearAllSignals
();
}
rgFacts
.
clear
();
}
void
CorridorScanComplexItemTest
::
_testCameraTrigger
(
void
)
{
#if 0
QCOMPARE(_corridorItem->property("cameraTrigger").toBool(), true);
// Set up a grid
for (int i=0; i<3; i++) {
_mapPolyline->appendVertex(_linePoints[i]);
}
_corridorItem->setDirty(false);
_multiSpy->clearAllSignals();
int lastSeq = _corridorItem->lastSequenceNumber();
QVERIFY(lastSeq > 0);
// Turning off camera triggering should remove two camera trigger mission items, this should trigger:
// lastSequenceNumberChanged
// dirtyChanged
_corridorItem->setProperty("cameraTrigger", false);
QVERIFY(_multiSpy->checkOnlySignalByMask(lastSequenceNumberChangedMask | dirtyChangedMask | cameraTriggerChangedMask));
QCOMPARE(_multiSpy->pullIntFromSignalIndex(lastSequenceNumberChangedIndex), lastSeq - 2);
_corridorItem->setDirty(false);
_multiSpy->clearAllSignals();
// Turn on camera triggering and make sure things go back to previous count
_corridorItem->setProperty("cameraTrigger", true);
QVERIFY(_multiSpy->checkOnlySignalByMask(lastSequenceNumberChangedMask | dirtyChangedMask | cameraTriggerChangedMask));
QCOMPARE(_multiSpy->pullIntFromSignalIndex(lastSequenceNumberChangedIndex), lastSeq);
#endif
}
void
CorridorScanComplexItemTest
::
_setPolyline
(
void
)
{
for
(
int
i
=
0
;
i
<
_linePoints
.
count
();
i
++
)
{
QGeoCoordinate
&
vertex
=
_linePoints
[
i
];
_mapPolyline
->
appendVertex
(
vertex
);
}
}
#if 0
void CorridorScanComplexItemTest::_testEntryLocation(void)
{
_setPolygon();
for (double gridAngle=-360.0; gridAngle<=360.0; gridAngle++) {
_corridorItem->gridAngle()->setRawValue(gridAngle);
QList<QGeoCoordinate> rgSeenEntryCoords;
QList<int> rgEntryLocation;
rgEntryLocation << SurveyMissionItem::EntryLocationTopLeft
<< SurveyMissionItem::EntryLocationTopRight
<< SurveyMissionItem::EntryLocationBottomLeft
<< SurveyMissionItem::EntryLocationBottomRight;
// Validate that each entry location is unique
for (int i=0; i<rgEntryLocation.count(); i++) {
int entryLocation = rgEntryLocation[i];
_corridorItem->gridEntryLocation()->setRawValue(entryLocation);
QVERIFY(!rgSeenEntryCoords.contains(_corridorItem->coordinate()));
rgSeenEntryCoords << _corridorItem->coordinate();
}
rgSeenEntryCoords.clear();
}
}
#endif
void
CorridorScanComplexItemTest
::
_testItemCount
(
void
)
{
QList
<
MissionItem
*>
items
;
_setPolyline
();
// _corridorItem->cameraTriggerInTurnaround()->setRawValue(false);
_corridorItem
->
appendMissionItems
(
items
,
this
);
QCOMPARE
(
items
.
count
(),
_corridorItem
->
lastSequenceNumber
());
items
.
clear
();
}
void
CorridorScanComplexItemTest
::
_testPathChanges
(
void
)
{
_setPolyline
();
_corridorItem
->
setDirty
(
false
);
_multiSpy
->
clearAllSignals
();
_multiSpyCorridorPolygon
->
clearAllSignals
();
QGeoCoordinate
vertex
=
_mapPolyline
->
vertexCoordinate
(
1
);
vertex
.
setLatitude
(
vertex
.
latitude
()
+
0.01
);
_mapPolyline
->
adjustVertex
(
1
,
vertex
);
QVERIFY
(
_corridorItem
->
dirty
());
QVERIFY
(
_multiSpy
->
checkOnlySignalsByMask
(
dirtyChangedMask
|
transectPointsChangedMask
|
cameraShotsChangedMask
|
coveredAreaChangedMask
|
complexDistanceChangedMask
|
greatestDistanceToChangedMask
));
QVERIFY
(
_multiSpyCorridorPolygon
->
checkSignalsByMask
(
corridorPolygonPathChangedMask
));
_multiSpy
->
clearAllSignals
();
}
src/MissionManager/CorridorScanComplexItemTest.h
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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.
*
****************************************************************************/
#pragma once
#include "UnitTest.h"
#include "TCPLink.h"
#include "MultiSignalSpy.h"
#include "CorridorScanComplexItem.h"
#include <QGeoCoordinate>
class
CorridorScanComplexItemTest
:
public
UnitTest
{
Q_OBJECT
public:
CorridorScanComplexItemTest
(
void
);
protected:
void
init
(
void
)
final
;
void
cleanup
(
void
)
final
;
private
slots
:
void
_testDirty
(
void
);
void
_testCameraTrigger
(
void
);
// void _testEntryLocation(void);
void
_testItemCount
(
void
);
void
_testPathChanges
(
void
);
private:
void
_setPolyline
(
void
);
enum
{
complexDistanceChangedIndex
=
0
,
greatestDistanceToChangedIndex
,
additionalTimeDelayChangedIndex
,
transectPointsChangedIndex
,
cameraShotsChangedIndex
,
coveredAreaChangedIndex
,
timeBetweenShotsChangedIndex
,
dirtyChangedIndex
,
maxSignalIndex
};
enum
{
complexDistanceChangedMask
=
1
<<
complexDistanceChangedIndex
,
greatestDistanceToChangedMask
=
1
<<
greatestDistanceToChangedIndex
,
additionalTimeDelayChangedMask
=
1
<<
additionalTimeDelayChangedIndex
,
transectPointsChangedMask
=
1
<<
transectPointsChangedIndex
,
cameraShotsChangedMask
=
1
<<
cameraShotsChangedIndex
,
coveredAreaChangedMask
=
1
<<
coveredAreaChangedIndex
,
timeBetweenShotsChangedMask
=
1
<<
timeBetweenShotsChangedIndex
,
dirtyChangedMask
=
1
<<
dirtyChangedIndex
};
static
const
size_t
_cSignals
=
maxSignalIndex
;
const
char
*
_rgSignals
[
_cSignals
];
enum
{
corridorPolygonPathChangedIndex
=
0
,
maxCorridorPolygonSignalIndex
};
enum
{
corridorPolygonPathChangedMask
=
1
<<
corridorPolygonPathChangedIndex
,
};
static
const
size_t
_cCorridorPolygonSignals
=
maxCorridorPolygonSignalIndex
;
const
char
*
_rgCorridorPolygonSignals
[
_cCorridorPolygonSignals
];
Vehicle
*
_offlineVehicle
;
MultiSignalSpy
*
_multiSpy
;
MultiSignalSpy
*
_multiSpyCorridorPolygon
;
CorridorScanComplexItem
*
_corridorItem
;
QGCMapPolyline
*
_mapPolyline
;
QList
<
QGeoCoordinate
>
_linePoints
;
};
src/MissionManager/MissionController.cc
View file @
790d03b4
...
@@ -19,7 +19,7 @@
...
@@ -19,7 +19,7 @@
#include "SurveyMissionItem.h"
#include "SurveyMissionItem.h"
#include "FixedWingLandingComplexItem.h"
#include "FixedWingLandingComplexItem.h"
#include "StructureScanComplexItem.h"
#include "StructureScanComplexItem.h"
#include "
Structure
ScanComplexItem.h"
#include "
Corridor
ScanComplexItem.h"
#include "JsonHelper.h"
#include "JsonHelper.h"
#include "ParameterManager.h"
#include "ParameterManager.h"
#include "QGroundControlQmlGlobal.h"
#include "QGroundControlQmlGlobal.h"
...
@@ -63,6 +63,7 @@ MissionController::MissionController(PlanMasterController* masterController, QOb
...
@@ -63,6 +63,7 @@ MissionController::MissionController(PlanMasterController* masterController, QOb
,
_surveyMissionItemName
(
tr
(
"Survey"
))
,
_surveyMissionItemName
(
tr
(
"Survey"
))
,
_fwLandingMissionItemName
(
tr
(
"Fixed Wing Landing"
))
,
_fwLandingMissionItemName
(
tr
(
"Fixed Wing Landing"
))
,
_structureScanMissionItemName
(
tr
(
"Structure Scan"
))
,
_structureScanMissionItemName
(
tr
(
"Structure Scan"
))
,
_corridorScanMissionItemName
(
tr
(
"Corridor Scan"
))
,
_appSettings
(
qgcApp
()
->
toolbox
()
->
settingsManager
()
->
appSettings
())
,
_appSettings
(
qgcApp
()
->
toolbox
()
->
settingsManager
()
->
appSettings
())
,
_progressPct
(
0
)
,
_progressPct
(
0
)
,
_currentPlanViewIndex
(
-
1
)
,
_currentPlanViewIndex
(
-
1
)
...
@@ -416,6 +417,8 @@ int MissionController::insertComplexMissionItem(QString itemName, QGeoCoordinate
...
@@ -416,6 +417,8 @@ int MissionController::insertComplexMissionItem(QString itemName, QGeoCoordinate
newItem
=
new
FixedWingLandingComplexItem
(
_controllerVehicle
,
_visualItems
);
newItem
=
new
FixedWingLandingComplexItem
(
_controllerVehicle
,
_visualItems
);
}
else
if
(
itemName
==
_structureScanMissionItemName
)
{
}
else
if
(
itemName
==
_structureScanMissionItemName
)
{
newItem
=
new
StructureScanComplexItem
(
_controllerVehicle
,
_visualItems
);
newItem
=
new
StructureScanComplexItem
(
_controllerVehicle
,
_visualItems
);
}
else
if
(
itemName
==
_corridorScanMissionItemName
)
{
newItem
=
new
CorridorScanComplexItem
(
_controllerVehicle
,
_visualItems
);
}
else
{
}
else
{
qWarning
()
<<
"Internal error: Unknown complex item:"
<<
itemName
;
qWarning
()
<<
"Internal error: Unknown complex item:"
<<
itemName
;
return
sequenceNumber
;
return
sequenceNumber
;
...
@@ -697,6 +700,15 @@ bool MissionController::_loadJsonMissionFileV2(const QJsonObject& json, QmlObjec
...
@@ -697,6 +700,15 @@ bool MissionController::_loadJsonMissionFileV2(const QJsonObject& json, QmlObjec
nextSequenceNumber
=
structureItem
->
lastSequenceNumber
()
+
1
;
nextSequenceNumber
=
structureItem
->
lastSequenceNumber
()
+
1
;
qCDebug
(
MissionControllerLog
)
<<
"Structure Scan load complete: nextSequenceNumber"
<<
nextSequenceNumber
;
qCDebug
(
MissionControllerLog
)
<<
"Structure Scan load complete: nextSequenceNumber"
<<
nextSequenceNumber
;
visualItems
->
append
(
structureItem
);
visualItems
->
append
(
structureItem
);
}
else
if
(
complexItemType
==
CorridorScanComplexItem
::
jsonComplexItemTypeValue
)
{
qCDebug
(
MissionControllerLog
)
<<
"Loading Corridor Scan: nextSequenceNumber"
<<
nextSequenceNumber
;
CorridorScanComplexItem
*
corridorItem
=
new
CorridorScanComplexItem
(
_controllerVehicle
,
visualItems
);
if
(
!
corridorItem
->
load
(
itemObject
,
nextSequenceNumber
++
,
errorString
))
{
return
false
;
}
nextSequenceNumber
=
corridorItem
->
lastSequenceNumber
()
+
1
;
qCDebug
(
MissionControllerLog
)
<<
"Corridor Scan load complete: nextSequenceNumber"
<<
nextSequenceNumber
;
visualItems
->
append
(
corridorItem
);
}
else
if
(
complexItemType
==
MissionSettingsItem
::
jsonComplexItemTypeValue
)
{
}
else
if
(
complexItemType
==
MissionSettingsItem
::
jsonComplexItemTypeValue
)
{
qCDebug
(
MissionControllerLog
)
<<
"Loading Mission Settings: nextSequenceNumber"
<<
nextSequenceNumber
;
qCDebug
(
MissionControllerLog
)
<<
"Loading Mission Settings: nextSequenceNumber"
<<
nextSequenceNumber
;
MissionSettingsItem
*
settingsItem
=
new
MissionSettingsItem
(
_controllerVehicle
,
visualItems
);
MissionSettingsItem
*
settingsItem
=
new
MissionSettingsItem
(
_controllerVehicle
,
visualItems
);
...
@@ -1841,6 +1853,7 @@ QStringList MissionController::complexMissionItemNames(void) const
...
@@ -1841,6 +1853,7 @@ QStringList MissionController::complexMissionItemNames(void) const
QStringList
complexItems
;
QStringList
complexItems
;
complexItems
.
append
(
_surveyMissionItemName
);
complexItems
.
append
(
_surveyMissionItemName
);
complexItems
.
append
(
_corridorScanMissionItemName
);
if
(
_controllerVehicle
->
fixedWing
())
{
if
(
_controllerVehicle
->
fixedWing
())
{
complexItems
.
append
(
_fwLandingMissionItemName
);
complexItems
.
append
(
_fwLandingMissionItemName
);
}
}
...
...
src/MissionManager/MissionController.h
View file @
790d03b4
...
@@ -253,6 +253,7 @@ private:
...
@@ -253,6 +253,7 @@ private:
QString
_surveyMissionItemName
;
QString
_surveyMissionItemName
;
QString
_fwLandingMissionItemName
;
QString
_fwLandingMissionItemName
;
QString
_structureScanMissionItemName
;
QString
_structureScanMissionItemName
;
QString
_corridorScanMissionItemName
;
AppSettings
*
_appSettings
;
AppSettings
*
_appSettings
;
double
_progressPct
;
double
_progressPct
;
int
_currentPlanViewIndex
;
int
_currentPlanViewIndex
;
...
...
src/MissionManager/QGCMapPolygon.cc
View file @
790d03b4
...
@@ -362,7 +362,7 @@ QGeoCoordinate QGCMapPolygon::vertexCoordinate(int vertex) const
...
@@ -362,7 +362,7 @@ QGeoCoordinate QGCMapPolygon::vertexCoordinate(int vertex) const
}
}
}
}
QList
<
QPointF
>
QGCMapPolygon
::
nedPolygon
(
void
)
QList
<
QPointF
>
QGCMapPolygon
::
nedPolygon
(
void
)
const
{
{
QList
<
QPointF
>
nedPolygon
;
QList
<
QPointF
>
nedPolygon
;
...
@@ -515,3 +515,19 @@ bool QGCMapPolygon::loadKMLFile(const QString& kmlFile)
...
@@ -515,3 +515,19 @@ bool QGCMapPolygon::loadKMLFile(const QString& kmlFile)
return
true
;
return
true
;
}
}
double
QGCMapPolygon
::
area
(
void
)
const
{
// https://www.mathopenref.com/coordpolygonarea2.html
double
coveredArea
=
0.0
;
QList
<
QPointF
>
nedVertices
=
nedPolygon
();
for
(
int
i
=
0
;
i
<
nedVertices
.
count
();
i
++
)
{
if
(
i
!=
0
)
{
coveredArea
+=
nedVertices
[
i
-
1
].
x
()
*
nedVertices
[
i
].
y
()
-
nedVertices
[
i
].
x
()
*
nedVertices
[
i
-
1
].
y
();
}
else
{
coveredArea
+=
nedVertices
.
last
().
x
()
*
nedVertices
[
i
].
y
()
-
nedVertices
[
i
].
x
()
*
nedVertices
.
last
().
y
();
}
}
return
0.5
*
fabs
(
coveredArea
);
}
src/MissionManager/QGCMapPolygon.h
View file @
790d03b4
...
@@ -77,7 +77,10 @@ public:
...
@@ -77,7 +77,10 @@ public:
bool
loadFromJson
(
const
QJsonObject
&
json
,
bool
required
,
QString
&
errorString
);
bool
loadFromJson
(
const
QJsonObject
&
json
,
bool
required
,
QString
&
errorString
);
/// Convert polygon to NED and return (D is ignored)
/// Convert polygon to NED and return (D is ignored)
QList
<
QPointF
>
nedPolygon
(
void
);
QList
<
QPointF
>
nedPolygon
(
void
)
const
;
/// Returns the area of the polygon in meters squared
double
area
(
void
)
const
;
// Property methods
// Property methods
...
...
src/MissionManager/QGCMapPolygonTest.cc
View file @
790d03b4
...
@@ -205,17 +205,23 @@ void QGCMapPolygonTest::_testVertexManipulation(void)
...
@@ -205,17 +205,23 @@ void QGCMapPolygonTest::_testVertexManipulation(void)
void
QGCMapPolygonTest
::
_testKMLLoad
(
void
)
void
QGCMapPolygonTest
::
_testKMLLoad
(
void
)
{
{
QVERIFY
(
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/
GoodPolygon
.kml"
)));
QVERIFY
(
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/
PolygonGood
.kml"
)));
setExpectedMessageBox
(
QMessageBox
::
Ok
);
setExpectedMessageBox
(
QMessageBox
::
Ok
);
QVERIFY
(
!
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/BadXml.kml"
)));
QVERIFY
(
!
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/
Polygon
BadXml.kml"
)));
checkExpectedMessageBox
();
checkExpectedMessageBox
();
setExpectedMessageBox
(
QMessageBox
::
Ok
);
setExpectedMessageBox
(
QMessageBox
::
Ok
);
QVERIFY
(
!
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/
MissingPolygon
Node.kml"
)));
QVERIFY
(
!
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/
PolygonMissing
Node.kml"
)));
checkExpectedMessageBox
();
checkExpectedMessageBox
();
setExpectedMessageBox
(
QMessageBox
::
Ok
);
setExpectedMessageBox
(
QMessageBox
::
Ok
);
QVERIFY
(
!
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/BadCoordinatesNode.kml"
)));
QVERIFY
(
!
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/
Polygon
BadCoordinatesNode.kml"
)));
checkExpectedMessageBox
();
checkExpectedMessageBox
();
}
}
void
QGCMapPolygonTest
::
_testArea
(
void
)
{
QVERIFY
(
_mapPolygon
->
loadKMLFile
(
QStringLiteral
(
":/unittest/PolygonAreaTest.kml"
)));
QCOMPARE
(
_mapPolygon
->
area
(),
4620.05313465
);
}
src/MissionManager/QGCMapPolygonTest.h
View file @
790d03b4
...
@@ -30,6 +30,7 @@ private slots:
...
@@ -30,6 +30,7 @@ private slots:
void
_testDirty
(
void
);
void
_testDirty
(
void
);
void
_testVertexManipulation
(
void
);
void
_testVertexManipulation
(
void
);
void
_testKMLLoad
(
void
);
void
_testKMLLoad
(
void
);
void
_testArea
(
void
);
private:
private:
enum
{
enum
{
...
...
src/MissionManager/QGCMapPolyline.cc
0 → 100644
View file @
790d03b4
This diff is collapsed.
Click to expand it.
src/MissionManager/QGCMapPolyline.h
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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.
*
****************************************************************************/
#pragma once
#include <QObject>
#include <QGeoCoordinate>
#include <QVariantList>
#include "QmlObjectListModel.h"
class
QGCMapPolyline
:
public
QObject
{
Q_OBJECT
public:
QGCMapPolyline
(
QObject
*
parent
=
NULL
);
QGCMapPolyline
(
const
QGCMapPolyline
&
other
,
QObject
*
parent
=
NULL
);
const
QGCMapPolyline
&
operator
=
(
const
QGCMapPolyline
&
other
);
Q_PROPERTY
(
int
count
READ
count
NOTIFY
countChanged
)
Q_PROPERTY
(
QVariantList
path
READ
path
NOTIFY
pathChanged
)
Q_PROPERTY
(
QmlObjectListModel
*
pathModel
READ
qmlPathModel
CONSTANT
)
Q_PROPERTY
(
bool
dirty
READ
dirty
WRITE
setDirty
NOTIFY
dirtyChanged
)
Q_PROPERTY
(
bool
interactive
READ
interactive
WRITE
setInteractive
NOTIFY
interactiveChanged
)
Q_INVOKABLE
void
clear
(
void
);
Q_INVOKABLE
void
appendVertex
(
const
QGeoCoordinate
&
coordinate
);
Q_INVOKABLE
void
removeVertex
(
int
vertexIndex
);
/// Adjust the value for the specified coordinate
/// @param vertexIndex Polygon point index to modify (0-based)
/// @param coordinate New coordinate for point
Q_INVOKABLE
void
adjustVertex
(
int
vertexIndex
,
const
QGeoCoordinate
coordinate
);
/// Splits the line segment comprised of vertexIndex -> vertexIndex + 1
Q_INVOKABLE
void
splitSegment
(
int
vertexIndex
);
/// Offsets the current polyline edges by the specified distance in meters
/// @return Offset set of vertices
QList
<
QGeoCoordinate
>
offsetPolyline
(
double
distance
);
/// Loads a polyline from a KML file
/// @return true: success
Q_INVOKABLE
bool
loadKMLFile
(
const
QString
&
kmlFile
);
/// Returns the path in a list of QGeoCoordinate's format
QList
<
QGeoCoordinate
>
coordinateList
(
void
)
const
;
/// Returns the QGeoCoordinate for the vertex specified
QGeoCoordinate
vertexCoordinate
(
int
vertex
)
const
;
/// Saves the polyline to the json object.
/// @param json Json object to save to
void
saveToJson
(
QJsonObject
&
json
);
/// Load a polyline from json
/// @param json Json object to load from
/// @param required true: no polygon in object will generate error
/// @param errorString Error string if return is false
/// @return true: success, false: failure (errorString set)
bool
loadFromJson
(
const
QJsonObject
&
json
,
bool
required
,
QString
&
errorString
);
/// Convert polyline to NED and return (D is ignored)
QList
<
QPointF
>
nedPolyline
(
void
);
/// Returns the length of the polyline in meters
double
length
(
void
)
const
;
// Property methods
int
count
(
void
)
const
{
return
_polylinePath
.
count
();
}
bool
dirty
(
void
)
const
{
return
_dirty
;
}
void
setDirty
(
bool
dirty
);
bool
interactive
(
void
)
const
{
return
_interactive
;
}
QVariantList
path
(
void
)
const
{
return
_polylinePath
;
}
QmlObjectListModel
*
qmlPathModel
(
void
)
{
return
&
_polylineModel
;
}
QmlObjectListModel
&
pathModel
(
void
)
{
return
_polylineModel
;
}
void
setPath
(
const
QList
<
QGeoCoordinate
>&
path
);
void
setPath
(
const
QVariantList
&
path
);
void
setInteractive
(
bool
interactive
);
static
const
char
*
jsonPolylineKey
;
signals:
void
countChanged
(
int
count
);
void
pathChanged
(
void
);
void
dirtyChanged
(
bool
dirty
);
void
cleared
(
void
);
void
interactiveChanged
(
bool
interactive
);
private
slots
:
void
_polylineModelCountChanged
(
int
count
);
void
_polylineModelDirtyChanged
(
bool
dirty
);
private:
void
_init
(
void
);
QGeoCoordinate
_coordFromPointF
(
const
QPointF
&
point
)
const
;
QPointF
_pointFFromCoord
(
const
QGeoCoordinate
&
coordinate
)
const
;
QVariantList
_polylinePath
;
QmlObjectListModel
_polylineModel
;
bool
_dirty
;
bool
_interactive
;
};
src/MissionManager/QGCMapPolylineTest.cc
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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.
*
****************************************************************************/
#include "QGCMapPolylineTest.h"
#include "QGCApplication.h"
#include "QGCQGeoCoordinate.h"
QGCMapPolylineTest
::
QGCMapPolylineTest
(
void
)
{
_linePoints
<<
QGeoCoordinate
(
47.635638361473475
,
-
122.09269407980834
)
<<
QGeoCoordinate
(
47.635638361473475
,
-
122.08545246602667
)
<<
QGeoCoordinate
(
47.63057923872075
,
-
122.08545246602667
)
<<
QGeoCoordinate
(
47.63057923872075
,
-
122.09269407980834
);
}
void
QGCMapPolylineTest
::
init
(
void
)
{
UnitTest
::
init
();
_rgSignals
[
countChangedIndex
]
=
SIGNAL
(
countChanged
(
int
));
_rgSignals
[
pathChangedIndex
]
=
SIGNAL
(
pathChanged
());
_rgSignals
[
dirtyChangedIndex
]
=
SIGNAL
(
dirtyChanged
(
bool
));
_rgSignals
[
clearedIndex
]
=
SIGNAL
(
cleared
());
_rgModelSignals
[
modelCountChangedIndex
]
=
SIGNAL
(
countChanged
(
int
));
_rgModelSignals
[
modelDirtyChangedIndex
]
=
SIGNAL
(
dirtyChanged
(
bool
));
_mapPolyline
=
new
QGCMapPolyline
(
this
);
_pathModel
=
_mapPolyline
->
qmlPathModel
();
QVERIFY
(
_pathModel
);
_multiSpyPolyline
=
new
MultiSignalSpy
();
QCOMPARE
(
_multiSpyPolyline
->
init
(
_mapPolyline
,
_rgSignals
,
_cSignals
),
true
);
_multiSpyModel
=
new
MultiSignalSpy
();
QCOMPARE
(
_multiSpyModel
->
init
(
_pathModel
,
_rgModelSignals
,
_cModelSignals
),
true
);
}
void
QGCMapPolylineTest
::
cleanup
(
void
)
{
delete
_mapPolyline
;
delete
_multiSpyPolyline
;
delete
_multiSpyModel
;
}
void
QGCMapPolylineTest
::
_testDirty
(
void
)
{
// Check basic dirty bit set/get
QVERIFY
(
!
_mapPolyline
->
dirty
());
QVERIFY
(
!
_pathModel
->
dirty
());
_mapPolyline
->
setDirty
(
false
);
QVERIFY
(
!
_mapPolyline
->
dirty
());
QVERIFY
(
!
_pathModel
->
dirty
());
QVERIFY
(
_multiSpyPolyline
->
checkNoSignals
());
QVERIFY
(
_multiSpyModel
->
checkNoSignals
());
_mapPolyline
->
setDirty
(
true
);
QVERIFY
(
_mapPolyline
->
dirty
());
QVERIFY
(
!
_pathModel
->
dirty
());
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalByMask
(
dirtyChangedMask
));
QVERIFY
(
_multiSpyPolyline
->
pullBoolFromSignalIndex
(
dirtyChangedIndex
));
QVERIFY
(
_multiSpyModel
->
checkNoSignals
());
_multiSpyPolyline
->
clearAllSignals
();
_mapPolyline
->
setDirty
(
false
);
QVERIFY
(
!
_mapPolyline
->
dirty
());
QVERIFY
(
!
_pathModel
->
dirty
());
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalByMask
(
dirtyChangedMask
));
QVERIFY
(
!
_multiSpyPolyline
->
pullBoolFromSignalIndex
(
dirtyChangedIndex
));
QVERIFY
(
_multiSpyModel
->
checkNoSignals
());
_multiSpyPolyline
->
clearAllSignals
();
_pathModel
->
setDirty
(
true
);
QVERIFY
(
_pathModel
->
dirty
());
QVERIFY
(
_mapPolyline
->
dirty
());
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalByMask
(
dirtyChangedMask
));
QVERIFY
(
_multiSpyPolyline
->
pullBoolFromSignalIndex
(
dirtyChangedIndex
));
QVERIFY
(
_multiSpyModel
->
checkOnlySignalByMask
(
modelDirtyChangedMask
));
QVERIFY
(
_multiSpyModel
->
pullBoolFromSignalIndex
(
modelDirtyChangedIndex
));
_multiSpyPolyline
->
clearAllSignals
();
_multiSpyModel
->
clearAllSignals
();
_mapPolyline
->
setDirty
(
false
);
QVERIFY
(
!
_mapPolyline
->
dirty
());
QVERIFY
(
!
_pathModel
->
dirty
());
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalByMask
(
dirtyChangedMask
));
QVERIFY
(
!
_multiSpyPolyline
->
pullBoolFromSignalIndex
(
dirtyChangedIndex
));
QVERIFY
(
_multiSpyModel
->
checkOnlySignalByMask
(
modelDirtyChangedMask
));
QVERIFY
(
!
_multiSpyModel
->
pullBoolFromSignalIndex
(
modelDirtyChangedIndex
));
_multiSpyPolyline
->
clearAllSignals
();
_multiSpyModel
->
clearAllSignals
();
}
void
QGCMapPolylineTest
::
_testVertexManipulation
(
void
)
{
// Vertex addition testing
for
(
int
i
=
0
;
i
<
_linePoints
.
count
();
i
++
)
{
QCOMPARE
(
_mapPolyline
->
count
(),
i
);
_mapPolyline
->
appendVertex
(
_linePoints
[
i
]);
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalByMask
(
pathChangedMask
|
dirtyChangedMask
|
countChangedMask
));
QVERIFY
(
_multiSpyModel
->
checkOnlySignalByMask
(
modelDirtyChangedMask
|
modelCountChangedMask
));
QCOMPARE
(
_multiSpyPolyline
->
pullIntFromSignalIndex
(
countChangedIndex
),
i
+
1
);
QCOMPARE
(
_multiSpyModel
->
pullIntFromSignalIndex
(
modelCountChangedIndex
),
i
+
1
);
QVERIFY
(
_mapPolyline
->
dirty
());
QVERIFY
(
_pathModel
->
dirty
());
QCOMPARE
(
_mapPolyline
->
count
(),
i
+
1
);
QVariantList
vertexList
=
_mapPolyline
->
path
();
QCOMPARE
(
vertexList
.
count
(),
i
+
1
);
QCOMPARE
(
vertexList
[
i
].
value
<
QGeoCoordinate
>
(),
_linePoints
[
i
]);
QCOMPARE
(
_pathModel
->
count
(),
i
+
1
);
QCOMPARE
(
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
i
)
->
coordinate
(),
_linePoints
[
i
]);
_mapPolyline
->
setDirty
(
false
);
_multiSpyPolyline
->
clearAllSignals
();
_multiSpyModel
->
clearAllSignals
();
}
// Vertex adjustment testing
QGCQGeoCoordinate
*
geoCoord
=
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
1
);
QSignalSpy
coordSpy
(
geoCoord
,
SIGNAL
(
coordinateChanged
(
QGeoCoordinate
)));
QSignalSpy
coordDirtySpy
(
geoCoord
,
SIGNAL
(
dirtyChanged
(
bool
)));
QGeoCoordinate
adjustCoord
(
_linePoints
[
1
].
latitude
()
+
1
,
_linePoints
[
1
].
longitude
()
+
1
);
_mapPolyline
->
adjustVertex
(
1
,
adjustCoord
);
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalByMask
(
pathChangedMask
|
dirtyChangedMask
));
QVERIFY
(
_multiSpyModel
->
checkOnlySignalByMask
(
modelDirtyChangedMask
));
QCOMPARE
(
coordSpy
.
count
(),
1
);
QCOMPARE
(
coordDirtySpy
.
count
(),
1
);
QCOMPARE
(
geoCoord
->
coordinate
(),
adjustCoord
);
QVariantList
vertexList
=
_mapPolyline
->
path
();
QCOMPARE
(
vertexList
[
0
].
value
<
QGeoCoordinate
>
(),
_linePoints
[
0
]);
QCOMPARE
(
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
0
)
->
coordinate
(),
_linePoints
[
0
]);
QCOMPARE
(
vertexList
[
2
].
value
<
QGeoCoordinate
>
(),
_linePoints
[
2
]);
QCOMPARE
(
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
2
)
->
coordinate
(),
_linePoints
[
2
]);
QCOMPARE
(
vertexList
[
3
].
value
<
QGeoCoordinate
>
(),
_linePoints
[
3
]);
QCOMPARE
(
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
3
)
->
coordinate
(),
_linePoints
[
3
]);
_mapPolyline
->
setDirty
(
false
);
_multiSpyPolyline
->
clearAllSignals
();
_multiSpyModel
->
clearAllSignals
();
// Vertex removal testing
_mapPolyline
->
removeVertex
(
1
);
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalByMask
(
pathChangedMask
|
dirtyChangedMask
|
countChangedMask
));
QVERIFY
(
_multiSpyModel
->
checkOnlySignalByMask
(
modelDirtyChangedMask
|
modelCountChangedMask
));
QCOMPARE
(
_mapPolyline
->
count
(),
3
);
vertexList
=
_mapPolyline
->
path
();
QCOMPARE
(
vertexList
.
count
(),
3
);
QCOMPARE
(
_pathModel
->
count
(),
3
);
QCOMPARE
(
vertexList
[
0
].
value
<
QGeoCoordinate
>
(),
_linePoints
[
0
]);
QCOMPARE
(
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
0
)
->
coordinate
(),
_linePoints
[
0
]);
QCOMPARE
(
vertexList
[
1
].
value
<
QGeoCoordinate
>
(),
_linePoints
[
2
]);
QCOMPARE
(
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
1
)
->
coordinate
(),
_linePoints
[
2
]);
QCOMPARE
(
vertexList
[
2
].
value
<
QGeoCoordinate
>
(),
_linePoints
[
3
]);
QCOMPARE
(
_pathModel
->
value
<
QGCQGeoCoordinate
*>
(
2
)
->
coordinate
(),
_linePoints
[
3
]);
// Clear testing
_mapPolyline
->
clear
();
QVERIFY
(
_multiSpyPolyline
->
checkOnlySignalsByMask
(
pathChangedMask
|
dirtyChangedMask
|
countChangedMask
|
clearedMask
));
QVERIFY
(
_multiSpyModel
->
checkOnlySignalsByMask
(
modelDirtyChangedMask
|
modelCountChangedMask
));
QVERIFY
(
_mapPolyline
->
dirty
());
QVERIFY
(
_pathModel
->
dirty
());
QCOMPARE
(
_mapPolyline
->
count
(),
0
);
vertexList
=
_mapPolyline
->
path
();
QCOMPARE
(
vertexList
.
count
(),
0
);
QCOMPARE
(
_pathModel
->
count
(),
0
);
}
#if 0
void QGCMapPolylineTest::_testKMLLoad(void)
{
QVERIFY(_mapPolyline->loadKMLFile(QStringLiteral(":/unittest/PolygonGood.kml")));
setExpectedMessageBox(QMessageBox::Ok);
QVERIFY(!_mapPolyline->loadKMLFile(QStringLiteral(":/unittest/BadXml.kml")));
checkExpectedMessageBox();
setExpectedMessageBox(QMessageBox::Ok);
QVERIFY(!_mapPolyline->loadKMLFile(QStringLiteral(":/unittest/MissingPolygonNode.kml")));
checkExpectedMessageBox();
setExpectedMessageBox(QMessageBox::Ok);
QVERIFY(!_mapPolyline->loadKMLFile(QStringLiteral(":/unittest/BadCoordinatesNode.kml")));
checkExpectedMessageBox();
}
#endif
src/MissionManager/QGCMapPolylineTest.h
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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.
*
****************************************************************************/
#pragma once
#include "UnitTest.h"
#include "MultiSignalSpy.h"
#include "QGCMapPolyline.h"
#include "QmlObjectListModel.h"
class
QGCMapPolylineTest
:
public
UnitTest
{
Q_OBJECT
public:
QGCMapPolylineTest
(
void
);
protected:
void
init
(
void
)
final
;
void
cleanup
(
void
)
final
;
private
slots
:
void
_testDirty
(
void
);
void
_testVertexManipulation
(
void
);
// void _testKMLLoad(void);
private:
enum
{
countChangedIndex
=
0
,
pathChangedIndex
,
dirtyChangedIndex
,
clearedIndex
,
maxSignalIndex
};
enum
{
countChangedMask
=
1
<<
countChangedIndex
,
pathChangedMask
=
1
<<
pathChangedIndex
,
dirtyChangedMask
=
1
<<
dirtyChangedIndex
,
clearedMask
=
1
<<
clearedIndex
,
};
static
const
size_t
_cSignals
=
maxSignalIndex
;
const
char
*
_rgSignals
[
_cSignals
];
enum
{
modelCountChangedIndex
=
0
,
modelDirtyChangedIndex
,
maxModelSignalIndex
};
enum
{
modelCountChangedMask
=
1
<<
modelCountChangedIndex
,
modelDirtyChangedMask
=
1
<<
modelDirtyChangedIndex
,
};
static
const
size_t
_cModelSignals
=
maxModelSignalIndex
;
const
char
*
_rgModelSignals
[
_cModelSignals
];
MultiSignalSpy
*
_multiSpyPolyline
;
MultiSignalSpy
*
_multiSpyModel
;
QGCMapPolyline
*
_mapPolyline
;
QmlObjectListModel
*
_pathModel
;
QList
<
QGeoCoordinate
>
_linePoints
;
};
src/MissionManager/QGCMapPolylineVisuals.qml
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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
.
Controls
1.2
import
QtLocation
5.3
import
QtPositioning
5.3
import
QtQuick
.
Dialogs
1.2
import
QGroundControl
1.0
import
QGroundControl
.
ScreenTools
1.0
import
QGroundControl
.
Palette
1.0
import
QGroundControl
.
Controls
1.0
import
QGroundControl
.
FlightMap
1.0
/// QGCmapPolyline map visuals
Item
{
id
:
_root
property
var
qgcView
///< QGCView for popping dialogs
property
var
mapControl
///< Map control to place item in
property
var
mapPolyline
///< QGCMapPolyline object
property
bool
interactive
:
mapPolyline
.
interactive
property
int
lineWidth
:
3
property
color
lineColor
:
"
#be781c
"
property
var
_polylineComponent
property
var
_dragHandlesComponent
property
var
_splitHandlesComponent
property
real
_zorderDragHandle
:
QGroundControl
.
zOrderMapItems
+
3
// Highest to prevent splitting when items overlap
property
real
_zorderSplitHandle
:
QGroundControl
.
zOrderMapItems
+
2
function
addVisuals
()
{
_polylineComponent
=
polylineComponent
.
createObject
(
mapControl
)
mapControl
.
addMapItem
(
_polylineComponent
)
}
function
removeVisuals
()
{
_polylineComponent
.
destroy
()
}
function
addHandles
()
{
if
(
!
_dragHandlesComponent
)
{
_dragHandlesComponent
=
dragHandlesComponent
.
createObject
(
mapControl
)
_splitHandlesComponent
=
splitHandlesComponent
.
createObject
(
mapControl
)
}
}
function
removeHandles
()
{
if
(
_dragHandlesComponent
)
{
_dragHandlesComponent
.
destroy
()
_dragHandlesComponent
=
undefined
}
if
(
_splitHandlesComponent
)
{
_splitHandlesComponent
.
destroy
()
_splitHandlesComponent
=
undefined
}
}
/// Calculate the default/initial polyline
function
defaultPolylineVertices
()
{
var
x
=
map
.
centerViewport
.
x
+
(
map
.
centerViewport
.
width
/
2
)
var
yInset
=
map
.
centerViewport
.
height
/
4
var
topPointCoord
=
map
.
toCoordinate
(
Qt
.
point
(
x
,
map
.
centerViewport
.
y
+
yInset
),
false
/* clipToViewPort */
)
var
bottomPointCoord
=
map
.
toCoordinate
(
Qt
.
point
(
x
,
map
.
centerViewport
.
y
+
map
.
centerViewport
.
height
-
yInset
),
false
/* clipToViewPort */
)
return
[
topPointCoord
,
bottomPointCoord
]
}
/// Add an initial 2 point polyline
function
addInitialPolyline
()
{
if
(
mapPolyline
.
count
<
2
)
{
mapPolyline
.
clear
()
var
initialVertices
=
defaultPolylineVertices
()
mapPolyline
.
appendVertex
(
initialVertices
[
0
])
mapPolyline
.
appendVertex
(
initialVertices
[
1
])
}
}
/// Reset polyline back to initial default
function
resetPolyline
()
{
mapPolyline
.
clear
()
addInitialPolyline
()
}
onInteractiveChanged
:
{
if
(
interactive
)
{
addHandles
()
}
else
{
removeHandles
()
}
}
Component.onCompleted
:
{
addVisuals
()
if
(
interactive
)
{
addHandles
()
}
}
Component
.
onDestruction
:
{
removeVisuals
()
removeHandles
()
}
QGCPalette
{
id
:
qgcPal
}
QGCFileDialog
{
id
:
kmlLoadDialog
qgcView
:
_root
.
qgcView
folder
:
QGroundControl
.
settingsManager
.
appSettings
.
missionSavePath
title
:
qsTr
(
"
Select KML File
"
)
selectExisting
:
true
nameFilters
:
[
qsTr
(
"
KML files (*.kml)
"
)
]
onAcceptedForLoad
:
{
mapPolyline
.
loadKMLFile
(
file
)
close
()
}
}
Component
{
id
:
polylineComponent
MapPolyline
{
line.width
:
lineWidth
line.color
:
lineColor
path
:
mapPolyline
.
path
}
}
Component
{
id
:
splitHandleComponent
MapQuickItem
{
id
:
mapQuickItem
anchorPoint.x
:
splitHandle
.
width
/
2
anchorPoint.y
:
splitHandle
.
height
/
2
property
int
vertexIndex
sourceItem
:
Rectangle
{
id
:
splitHandle
width
:
ScreenTools
.
defaultFontPixelHeight
*
1.5
height
:
width
radius
:
width
/
2
border.color
:
"
white
"
color
:
"
transparent
"
opacity
:
.
50
z
:
_zorderSplitHandle
QGCLabel
{
anchors.horizontalCenter
:
parent
.
horizontalCenter
anchors.verticalCenter
:
parent
.
verticalCenter
text
:
"
+
"
}
QGCMouseArea
{
fillItem
:
parent
onClicked
:
mapPolyline
.
splitSegment
(
mapQuickItem
.
vertexIndex
)
}
}
}
}
Component
{
id
:
splitHandlesComponent
Repeater
{
model
:
mapPolyline
.
path
delegate
:
Item
{
property
var
_splitHandle
property
var
_vertices
:
mapPolyline
.
path
function
_setHandlePosition
()
{
var
nextIndex
=
index
+
1
var
distance
=
_vertices
[
index
].
distanceTo
(
_vertices
[
nextIndex
])
var
azimuth
=
_vertices
[
index
].
azimuthTo
(
_vertices
[
nextIndex
])
_splitHandle
.
coordinate
=
_vertices
[
index
].
atDistanceAndAzimuth
(
distance
/
2
,
azimuth
)
}
Component.onCompleted
:
{
if
(
index
+
1
<=
_vertices
.
length
-
1
)
{
_splitHandle
=
splitHandleComponent
.
createObject
(
mapControl
)
_splitHandle
.
vertexIndex
=
index
_setHandlePosition
()
mapControl
.
addMapItem
(
_splitHandle
)
}
}
Component
.
onDestruction
:
{
if
(
_splitHandle
)
{
_splitHandle
.
destroy
()
}
}
}
}
}
// Control which is used to drag polygon vertices
Component
{
id
:
dragAreaComponent
MissionItemIndicatorDrag
{
id
:
dragArea
z
:
_zorderDragHandle
property
int
polylineVertex
property
bool
_creationComplete
:
false
Component.onCompleted
:
_creationComplete
=
true
onItemCoordinateChanged
:
{
if
(
_creationComplete
)
{
// During component creation some bad coordinate values got through which screws up draw
mapPolyline
.
adjustVertex
(
polylineVertex
,
itemCoordinate
)
}
}
onClicked
:
mapPolyline
.
removeVertex
(
polylineVertex
)
}
}
Component
{
id
:
dragHandleComponent
MapQuickItem
{
id
:
mapQuickItem
anchorPoint.x
:
dragHandle
.
width
/
2
anchorPoint.y
:
dragHandle
.
height
/
2
z
:
_zorderDragHandle
property
int
polylineVertex
sourceItem
:
Rectangle
{
id
:
dragHandle
width
:
ScreenTools
.
defaultFontPixelHeight
*
1.5
height
:
width
radius
:
width
/
2
color
:
"
white
"
opacity
:
.
90
}
}
}
// Add all polygon vertex drag handles to the map
Component
{
id
:
dragHandlesComponent
Repeater
{
model
:
mapPolyline
.
pathModel
delegate
:
Item
{
property
var
_visuals
:
[
]
Component.onCompleted
:
{
var
dragHandle
=
dragHandleComponent
.
createObject
(
mapControl
)
dragHandle
.
coordinate
=
Qt
.
binding
(
function
()
{
return
object
.
coordinate
})
dragHandle
.
polylineVertex
=
Qt
.
binding
(
function
()
{
return
index
})
mapControl
.
addMapItem
(
dragHandle
)
var
dragArea
=
dragAreaComponent
.
createObject
(
mapControl
,
{
"
itemIndicator
"
:
dragHandle
,
"
itemCoordinate
"
:
object
.
coordinate
})
dragArea
.
polylineVertex
=
Qt
.
binding
(
function
()
{
return
index
})
_visuals
.
push
(
dragHandle
)
_visuals
.
push
(
dragArea
)
}
Component.onDestruction
:
{
for
(
var
i
=
0
;
i
<
_visuals
.
length
;
i
++
)
{
_visuals
[
i
].
destroy
()
}
_visuals
=
[
]
}
}
}
}
}
src/MissionManager/StructureScanComplexItem.cc
View file @
790d03b4
...
@@ -102,7 +102,7 @@ void StructureScanComplexItem::_setScanDistance(double scanDistance)
...
@@ -102,7 +102,7 @@ void StructureScanComplexItem::_setScanDistance(double scanDistance)
{
{
if
(
!
qFuzzyCompare
(
_scanDistance
,
scanDistance
))
{
if
(
!
qFuzzyCompare
(
_scanDistance
,
scanDistance
))
{
_scanDistance
=
scanDistance
;
_scanDistance
=
scanDistance
;
emit
complexDistanceChanged
(
_scanDistance
);
emit
complexDistanceChanged
();
}
}
}
}
...
...
src/MissionManager/SurveyMissionItem.cc
View file @
790d03b4
...
@@ -159,7 +159,7 @@ void SurveyMissionItem::_setSurveyDistance(double surveyDistance)
...
@@ -159,7 +159,7 @@ void SurveyMissionItem::_setSurveyDistance(double surveyDistance)
{
{
if
(
!
qFuzzyCompare
(
_surveyDistance
,
surveyDistance
))
{
if
(
!
qFuzzyCompare
(
_surveyDistance
,
surveyDistance
))
{
_surveyDistance
=
surveyDistance
;
_surveyDistance
=
surveyDistance
;
emit
complexDistanceChanged
(
_surveyDistance
);
emit
complexDistanceChanged
();
}
}
}
}
...
@@ -742,7 +742,7 @@ void SurveyMissionItem::_generateGrid(void)
...
@@ -742,7 +742,7 @@ void SurveyMissionItem::_generateGrid(void)
if
(
_hoverAndCaptureEnabled
())
{
if
(
_hoverAndCaptureEnabled
())
{
_additionalFlightDelaySeconds
=
cameraShots
*
_hoverAndCaptureDelaySeconds
;
_additionalFlightDelaySeconds
=
cameraShots
*
_hoverAndCaptureDelaySeconds
;
}
}
emit
additionalTimeDelayChanged
(
_additionalFlightDelaySeconds
);
emit
additionalTimeDelayChanged
();
emit
gridPointsChanged
();
emit
gridPointsChanged
();
...
...
src/MissionManager/UnitTest/PolygonAreaTest.kml
0 → 100755
View file @
790d03b4
<?xml version="1.0" encoding="UTF-8"?>
<kml
xmlns=
"http://www.opengis.net/kml/2.2"
xmlns:gx=
"http://www.google.com/kml/ext/2.2"
xmlns:kml=
"http://www.opengis.net/kml/2.2"
xmlns:atom=
"http://www.w3.org/2005/Atom"
>
<Document>
<name>
AreaTestPolygon.kmz
</name>
<StyleMap
id=
"m_ylw-pushpin"
>
<Pair>
<key>
normal
</key>
<styleUrl>
#s_ylw-pushpin
</styleUrl>
</Pair>
<Pair>
<key>
highlight
</key>
<styleUrl>
#s_ylw-pushpin_hl
</styleUrl>
</Pair>
</StyleMap>
<Style
id=
"s_ylw-pushpin"
>
<IconStyle>
<scale>
1.1
</scale>
<Icon>
<href>
http://maps.google.com/mapfiles/kml/pushpin/ylw-pushpin.png
</href>
</Icon>
<hotSpot
x=
"20"
y=
"2"
xunits=
"pixels"
yunits=
"pixels"
/>
</IconStyle>
</Style>
<Style
id=
"s_ylw-pushpin_hl"
>
<IconStyle>
<scale>
1.3
</scale>
<Icon>
<href>
http://maps.google.com/mapfiles/kml/pushpin/ylw-pushpin.png
</href>
</Icon>
<hotSpot
x=
"20"
y=
"2"
xunits=
"pixels"
yunits=
"pixels"
/>
</IconStyle>
</Style>
<Placemark>
<name>
Untitled Polygon
</name>
<styleUrl>
#m_ylw-pushpin
</styleUrl>
<Polygon>
<tessellate>
1
</tessellate>
<outerBoundaryIs>
<LinearRing>
<coordinates>
-122.1059149362712,47.65965281788451,0 -122.1044593196253,47.66002598220988,0 -122.1047336695092,47.66034166158975,0 -122.1061470943783,47.6599810708829,0 -122.1059149362712,47.65965281788451,0
</coordinates>
</LinearRing>
</outerBoundaryIs>
</Polygon>
</Placemark>
</Document>
</kml>
src/MissionManager/UnitTest/BadCoordinatesNode.kml
→
src/MissionManager/UnitTest/
Polygon
BadCoordinatesNode.kml
View file @
790d03b4
File moved
src/MissionManager/UnitTest/BadXml.kml
→
src/MissionManager/UnitTest/
Polygon
BadXml.kml
View file @
790d03b4
File moved
src/MissionManager/UnitTest/
GoodPolygon
.kml
→
src/MissionManager/UnitTest/
PolygonGood
.kml
View file @
790d03b4
File moved
src/MissionManager/UnitTest/
MissingPolygon
Node.kml
→
src/MissionManager/UnitTest/
PolygonMissing
Node.kml
View file @
790d03b4
File moved
src/PlanView/CorridorScanEditor.qml
0 → 100644
View file @
790d03b4
import
QtQuick
2.3
import
QtQuick
.
Controls
1.2
import
QtQuick
.
Controls
.
Styles
1.4
import
QtQuick
.
Dialogs
1.2
import
QtQuick
.
Extras
1.4
import
QtQuick
.
Layouts
1.2
import
QGroundControl
1.0
import
QGroundControl
.
ScreenTools
1.0
import
QGroundControl
.
Vehicle
1.0
import
QGroundControl
.
Controls
1.0
import
QGroundControl
.
FactControls
1.0
import
QGroundControl
.
Palette
1.0
import
QGroundControl
.
FlightMap
1.0
// Editor for Survery mission items
Rectangle
{
id
:
_root
height
:
visible
?
(
editorColumn
.
height
+
(
_margin
*
2
))
:
0
width
:
availableWidth
color
:
qgcPal
.
windowShadeDark
radius
:
_radius
// The following properties must be available up the hierarchy chain
//property real availableWidth ///< Width for control
//property var missionItem ///< Mission Item for editor
property
real
_margin
:
ScreenTools
.
defaultFontPixelWidth
/
2
property
real
_fieldWidth
:
ScreenTools
.
defaultFontPixelWidth
*
10.5
property
var
_vehicle
:
QGroundControl
.
multiVehicleManager
.
activeVehicle
?
QGroundControl
.
multiVehicleManager
.
activeVehicle
:
QGroundControl
.
multiVehicleManager
.
offlineEditingVehicle
function
polygonCaptureStarted
()
{
missionItem
.
clearPolygon
()
}
function
polygonCaptureFinished
(
coordinates
)
{
for
(
var
i
=
0
;
i
<
coordinates
.
length
;
i
++
)
{
missionItem
.
addPolygonCoordinate
(
coordinates
[
i
])
}
}
function
polygonAdjustVertex
(
vertexIndex
,
vertexCoordinate
)
{
missionItem
.
adjustPolygonCoordinate
(
vertexIndex
,
vertexCoordinate
)
}
function
polygonAdjustStarted
()
{
}
function
polygonAdjustFinished
()
{
}
QGCPalette
{
id
:
qgcPal
;
colorGroupEnabled
:
true
}
Column
{
id
:
editorColumn
anchors.margins
:
_margin
anchors.top
:
parent
.
top
anchors.left
:
parent
.
left
anchors.right
:
parent
.
right
spacing
:
_margin
QGCLabel
{
anchors.left
:
parent
.
left
anchors.right
:
parent
.
right
text
:
qsTr
(
"
WARNING WORK IN PROGRESS: BE VERY CAREFUL WHEN FLYING
"
)
wrapMode
:
Text
.
WordWrap
color
:
qgcPal
.
warningText
font.pointSize
:
ScreenTools
.
smallFontPointSize
}
QGCLabel
{
anchors.left
:
parent
.
left
anchors.right
:
parent
.
right
text
:
qsTr
(
"
WARNING: Photo interval is below minimum interval (%1 secs) supported by camera.
"
).
arg
(
missionItem
.
cameraMinTriggerInterval
.
toFixed
(
1
))
wrapMode
:
Text
.
WordWrap
color
:
qgcPal
.
warningText
visible
:
missionItem
.
cameraShots
>
0
&&
missionItem
.
cameraMinTriggerInterval
!==
0
&&
missionItem
.
cameraMinTriggerInterval
>
missionItem
.
timeBetweenShots
}
CameraCalc
{
cameraCalc
:
missionItem
.
cameraCalc
vehicleFlightIsFrontal
:
true
distanceToSurfaceLabel
:
qsTr
(
"
Altitude
"
)
frontalDistanceLabel
:
qsTr
(
"
Trigger Distance
"
)
sideDistanceLabel
:
qsTr
(
"
Spacing
"
)
}
SectionHeader
{
id
:
corridorHeader
text
:
qsTr
(
"
Corridor
"
)
}
GridLayout
{
anchors.left
:
parent
.
left
anchors.right
:
parent
.
right
columnSpacing
:
_margin
rowSpacing
:
_margin
columns
:
2
visible
:
corridorHeader
.
checked
QGCLabel
{
text
:
qsTr
(
"
Width
"
)
}
FactTextField
{
fact
:
missionItem
.
corridorWidth
Layout.fillWidth
:
true
}
}
SectionHeader
{
id
:
statsHeader
text
:
qsTr
(
"
Statistics
"
)
}
Grid
{
columns
:
2
columnSpacing
:
ScreenTools
.
defaultFontPixelWidth
visible
:
statsHeader
.
checked
QGCLabel
{
text
:
qsTr
(
"
Photo count
"
)
}
QGCLabel
{
text
:
missionItem
.
cameraShots
}
QGCLabel
{
text
:
qsTr
(
"
Photo interval
"
)
}
QGCLabel
{
text
:
missionItem
.
timeBetweenShots
.
toFixed
(
1
)
+
"
"
+
qsTr
(
"
secs
"
)
}
}
}
// Column
}
// Rectangle
src/PlanView/CorridorScanMapVisual.qml
0 → 100644
View file @
790d03b4
/****************************************************************************
*
* (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
.
Controls
1.2
import
QtLocation
5.3
import
QtPositioning
5.3
import
QGroundControl
1.0
import
QGroundControl
.
Controls
1.0
/// Corridor Scan Complex Mission Item visuals
Item
{
id
:
_root
property
var
map
///< Map control to place item in
property
var
qgcView
///< QGCView to use for popping dialogs
property
var
_missionItem
:
object
property
var
_entryCoordinate
property
var
_exitCoordinate
property
var
_transectLines
signal
clicked
(
int
sequenceNumber
)
function
_addVisualElements
()
{
_entryCoordinate
=
entryPointComponent
.
createObject
(
map
)
_exitCoordinate
=
exitPointComponent
.
createObject
(
map
)
_transectLines
=
transectsComponent
.
createObject
(
map
)
map
.
addMapItem
(
_entryCoordinate
)
map
.
addMapItem
(
_exitCoordinate
)
map
.
addMapItem
(
_transectLines
)
}
function
_destroyVisualElements
()
{
_entryCoordinate
.
destroy
()
_exitCoordinate
.
destroy
()
_transectLines
.
destroy
()
}
Component.onCompleted
:
{
mapPolylineVisuals
.
addInitialPolyline
()
_addVisualElements
()
}
Component.onDestruction
:
{
_destroyVisualElements
()
}
QGCMapPolygonVisuals
{
qgcView
:
_root
.
qgcView
mapControl
:
map
mapPolygon
:
object
.
corridorPolygon
interactive
:
false
interiorColor
:
"
green
"
interiorOpacity
:
0.25
}
QGCMapPolylineVisuals
{
id
:
mapPolylineVisuals
qgcView
:
_root
.
qgcView
mapControl
:
map
mapPolyline
:
object
.
corridorPolyline
interactive
:
_missionItem
.
isCurrentItem
lineWidth
:
3
lineColor
:
"
#be781c
"
}
// Entry point
Component
{
id
:
entryPointComponent
MapQuickItem
{
anchorPoint.x
:
sourceItem
.
anchorPointX
anchorPoint.y
:
sourceItem
.
anchorPointY
z
:
QGroundControl
.
zOrderMapItems
coordinate
:
_missionItem
.
coordinate
visible
:
_missionItem
.
coordinate
.
isValid
sourceItem
:
MissionItemIndexLabel
{
index
:
_missionItem
.
sequenceNumber
label
:
"
Entry
"
checked
:
_missionItem
.
isCurrentItem
onClicked
:
_root
.
clicked
(
_missionItem
.
sequenceNumber
)
}
}
}
// Exit point
Component
{
id
:
exitPointComponent
MapQuickItem
{
anchorPoint.x
:
sourceItem
.
anchorPointX
anchorPoint.y
:
sourceItem
.
anchorPointY
z
:
QGroundControl
.
zOrderMapItems
coordinate
:
_missionItem
.
exitCoordinate
visible
:
_missionItem
.
exitCoordinate
.
isValid
sourceItem
:
MissionItemIndexLabel
{
index
:
_missionItem
.
lastSequenceNumber
label
:
"
Exit
"
checked
:
_missionItem
.
isCurrentItem
onClicked
:
_root
.
clicked
(
_missionItem
.
sequenceNumber
)
}
}
}
// Transect lines
Component
{
id
:
transectsComponent
MapPolyline
{
line.color
:
"
white
"
line.width
:
2
path
:
_missionItem
.
transectPoints
}
}
}
src/QmlControls/QGroundControl.Controls.qmldir
View file @
790d03b4
...
@@ -48,6 +48,7 @@ QGCListView 1.0 QGCListView.qml
...
@@ -48,6 +48,7 @@ QGCListView 1.0 QGCListView.qml
QGCMapLabel 1.0 QGCMapLabel.qml
QGCMapLabel 1.0 QGCMapLabel.qml
QGCMapCircleVisuals 1.0 QGCMapCircleVisuals.qml
QGCMapCircleVisuals 1.0 QGCMapCircleVisuals.qml
QGCMapPolygonVisuals 1.0 QGCMapPolygonVisuals.qml
QGCMapPolygonVisuals 1.0 QGCMapPolygonVisuals.qml
QGCMapPolylineVisuals 1.0 QGCMapPolylineVisuals.qml
QGCMouseArea 1.0 QGCMouseArea.qml
QGCMouseArea 1.0 QGCMouseArea.qml
QGCMovableItem 1.0 QGCMovableItem.qml
QGCMovableItem 1.0 QGCMovableItem.qml
QGCPipable 1.0 QGCPipable.qml
QGCPipable 1.0 QGCPipable.qml
...
...
src/qgcunittest/UnitTestList.cc
View file @
790d03b4
...
@@ -40,6 +40,8 @@
...
@@ -40,6 +40,8 @@
#include "QGCMapPolygonTest.h"
#include "QGCMapPolygonTest.h"
#include "AudioOutputTest.h"
#include "AudioOutputTest.h"
#include "StructureScanComplexItemTest.h"
#include "StructureScanComplexItemTest.h"
#include "QGCMapPolylineTest.h"
#include "CorridorScanComplexItemTest.h"
UT_REGISTER_TEST
(
FactSystemTestGeneric
)
UT_REGISTER_TEST
(
FactSystemTestGeneric
)
UT_REGISTER_TEST
(
FactSystemTestPX4
)
UT_REGISTER_TEST
(
FactSystemTestPX4
)
...
@@ -67,6 +69,8 @@ UT_REGISTER_TEST(MissionSettingsTest)
...
@@ -67,6 +69,8 @@ UT_REGISTER_TEST(MissionSettingsTest)
UT_REGISTER_TEST
(
QGCMapPolygonTest
)
UT_REGISTER_TEST
(
QGCMapPolygonTest
)
UT_REGISTER_TEST
(
AudioOutputTest
)
UT_REGISTER_TEST
(
AudioOutputTest
)
UT_REGISTER_TEST
(
StructureScanComplexItemTest
)
UT_REGISTER_TEST
(
StructureScanComplexItemTest
)
UT_REGISTER_TEST
(
CorridorScanComplexItemTest
)
UT_REGISTER_TEST
(
QGCMapPolylineTest
)
// List of unit test which are currently disabled.
// List of unit test which are currently disabled.
// If disabling a new test, include reason in comment.
// If disabling a new test, include reason in comment.
...
...
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