Commit f9fed02a authored by DonLakeFlyer's avatar DonLakeFlyer

parent c133b717
...@@ -24,5 +24,5 @@ void CorridorScanPlanCreator::createPlan(const QGeoCoordinate& mapCenterCoord) ...@@ -24,5 +24,5 @@ void CorridorScanPlanCreator::createPlan(const QGeoCoordinate& mapCenterCoord)
VisualMissionItem* takeoffItem = _missionController->insertTakeoffItem(mapCenterCoord, -1); VisualMissionItem* takeoffItem = _missionController->insertTakeoffItem(mapCenterCoord, -1);
_missionController->insertComplexMissionItem(MissionController::patternCorridorScanName, mapCenterCoord, -1); _missionController->insertComplexMissionItem(MissionController::patternCorridorScanName, mapCenterCoord, -1);
_missionController->insertLandItem(mapCenterCoord, -1); _missionController->insertLandItem(mapCenterCoord, -1);
_missionController->setCurrentPlanViewIndex(takeoffItem->sequenceNumber(), true); _missionController->setCurrentPlanViewSeqNum(takeoffItem->sequenceNumber(), true);
} }
...@@ -68,7 +68,8 @@ MissionController::MissionController(PlanMasterController* masterController, QOb ...@@ -68,7 +68,8 @@ MissionController::MissionController(PlanMasterController* masterController, QOb
, _inRecalcSequence (false) , _inRecalcSequence (false)
, _appSettings (qgcApp()->toolbox()->settingsManager()->appSettings()) , _appSettings (qgcApp()->toolbox()->settingsManager()->appSettings())
, _progressPct (0) , _progressPct (0)
, _currentPlanViewIndex (-1) , _currentPlanViewSeqNum (-1)
, _currentPlanViewVIIndex (-1)
, _currentPlanViewItem (nullptr) , _currentPlanViewItem (nullptr)
, _splitSegment (nullptr) , _splitSegment (nullptr)
{ {
...@@ -380,7 +381,7 @@ VisualMissionItem* MissionController::_insertSimpleMissionItemWorker(QGeoCoordin ...@@ -380,7 +381,7 @@ VisualMissionItem* MissionController::_insertSimpleMissionItemWorker(QGeoCoordin
_recalcAllWithCoordinate(coordinate); _recalcAllWithCoordinate(coordinate);
if (makeCurrentItem) { if (makeCurrentItem) {
setCurrentPlanViewIndex(newItem->sequenceNumber(), true); setCurrentPlanViewSeqNum(newItem->sequenceNumber(), true);
} }
return newItem; return newItem;
...@@ -418,7 +419,7 @@ VisualMissionItem* MissionController::insertTakeoffItem(QGeoCoordinate /*coordin ...@@ -418,7 +419,7 @@ VisualMissionItem* MissionController::insertTakeoffItem(QGeoCoordinate /*coordin
_recalcAll(); _recalcAll();
if (makeCurrentItem) { if (makeCurrentItem) {
setCurrentPlanViewIndex(newItem->sequenceNumber(), true); setCurrentPlanViewSeqNum(newItem->sequenceNumber(), true);
} }
return newItem; return newItem;
...@@ -437,10 +438,24 @@ VisualMissionItem* MissionController::insertLandItem(QGeoCoordinate coordinate, ...@@ -437,10 +438,24 @@ VisualMissionItem* MissionController::insertLandItem(QGeoCoordinate coordinate,
VisualMissionItem* MissionController::insertROIMissionItem(QGeoCoordinate coordinate, int visualItemIndex, bool makeCurrentItem) VisualMissionItem* MissionController::insertROIMissionItem(QGeoCoordinate coordinate, int visualItemIndex, bool makeCurrentItem)
{ {
MAV_CMD command = _controllerVehicle->firmwarePlugin()->supportedMissionCommands().contains(MAV_CMD_DO_SET_ROI_LOCATION) ? SimpleMissionItem* simpleItem = qobject_cast<SimpleMissionItem*>(_insertSimpleMissionItemWorker(coordinate, MAV_CMD_DO_SET_ROI_LOCATION, visualItemIndex, makeCurrentItem));
MAV_CMD_DO_SET_ROI_LOCATION :
MAV_CMD_DO_SET_ROI; if (!_controllerVehicle->firmwarePlugin()->supportedMissionCommands().contains(MAV_CMD_DO_SET_ROI_LOCATION)) {
return _insertSimpleMissionItemWorker(coordinate, command, visualItemIndex, makeCurrentItem); simpleItem->setCommand(MAV_CMD_DO_SET_ROI) ;
simpleItem->missionItem().setParam1(MAV_ROI_LOCATION);
}
return simpleItem;
}
VisualMissionItem* MissionController::insertCancelROIMissionItem(int visualItemIndex, bool makeCurrentItem)
{
SimpleMissionItem* simpleItem = qobject_cast<SimpleMissionItem*>(_insertSimpleMissionItemWorker(QGeoCoordinate(), MAV_CMD_DO_SET_ROI_NONE, visualItemIndex, makeCurrentItem));
if (!_controllerVehicle->firmwarePlugin()->supportedMissionCommands().contains(MAV_CMD_DO_SET_ROI_NONE)) {
simpleItem->setCommand(MAV_CMD_DO_SET_ROI) ;
simpleItem->missionItem().setParam1(MAV_ROI_NONE);
}
return simpleItem;
} }
VisualMissionItem* MissionController::insertComplexMissionItem(QString itemName, QGeoCoordinate mapCenterCoordinate, int visualItemIndex, bool makeCurrentItem) VisualMissionItem* MissionController::insertComplexMissionItem(QString itemName, QGeoCoordinate mapCenterCoordinate, int visualItemIndex, bool makeCurrentItem)
...@@ -536,7 +551,7 @@ void MissionController::_insertComplexMissionItemWorker(const QGeoCoordinate& ma ...@@ -536,7 +551,7 @@ void MissionController::_insertComplexMissionItemWorker(const QGeoCoordinate& ma
_recalcAllWithCoordinate(mapCenterCoordinate); _recalcAllWithCoordinate(mapCenterCoordinate);
if (makeCurrentItem) { if (makeCurrentItem) {
setCurrentPlanViewIndex(complexItem->sequenceNumber(), true); setCurrentPlanViewSeqNum(complexItem->sequenceNumber(), true);
} }
} }
...@@ -1736,7 +1751,7 @@ void MissionController::_initAllVisualItems(void) ...@@ -1736,7 +1751,7 @@ void MissionController::_initAllVisualItems(void)
emit plannedHomePositionChanged(plannedHomePosition()); emit plannedHomePositionChanged(plannedHomePosition());
if (!_flyView) { if (!_flyView) {
setCurrentPlanViewIndex(0, true); setCurrentPlanViewSeqNum(0, true);
} }
setDirty(false); setDirty(false);
...@@ -2149,32 +2164,25 @@ void MissionController::_managerRemoveAllComplete(bool error) ...@@ -2149,32 +2164,25 @@ void MissionController::_managerRemoveAllComplete(bool error)
} }
} }
int MissionController::currentPlanViewIndex(void) const void MissionController::setCurrentPlanViewSeqNum(int sequenceNumber, bool force)
{
return _currentPlanViewIndex;
}
VisualMissionItem* MissionController::currentPlanViewItem(void) const
{
return _currentPlanViewItem;
}
void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force)
{ {
if (_visualItems && (force || sequenceNumber != _currentPlanViewIndex)) { if (_visualItems && (force || sequenceNumber != _currentPlanViewSeqNum)) {
bool foundLand = false; bool foundLand = false;
int takeoffIndex = -1; int takeoffIndex = -1;
int landIndex = -1; int landIndex = -1;
_splitSegment = nullptr; _splitSegment = nullptr;
_currentPlanViewItem = nullptr; _currentPlanViewItem = nullptr;
_currentPlanViewIndex = -1; _currentPlanViewSeqNum = -1;
_currentPlanViewVIIndex = -1;
_isInsertTakeoffValid = true; _isInsertTakeoffValid = true;
_isInsertLandValid = true; _isInsertLandValid = true;
_isROIActive = false;
_flyThroughCommandsAllowed = true; _flyThroughCommandsAllowed = true;
for (int i = 0; i < _visualItems->count(); i++) { for (int viIndex=0; viIndex<_visualItems->count(); viIndex++) {
VisualMissionItem* pVI = qobject_cast<VisualMissionItem*>(_visualItems->get(i)); VisualMissionItem* pVI = qobject_cast<VisualMissionItem*>(_visualItems->get(viIndex));
SimpleMissionItem* simpleItem = qobject_cast<SimpleMissionItem*>(pVI);
if (sequenceNumber != 0 && pVI->sequenceNumber() <= sequenceNumber) { if (sequenceNumber != 0 && pVI->sequenceNumber() <= sequenceNumber) {
if (pVI->specifiesCoordinate() && !pVI->isStandaloneCoordinate()) { if (pVI->specifiesCoordinate() && !pVI->isStandaloneCoordinate()) {
...@@ -2184,12 +2192,11 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force) ...@@ -2184,12 +2192,11 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force)
} }
if (qobject_cast<TakeoffMissionItem*>(pVI)) { if (qobject_cast<TakeoffMissionItem*>(pVI)) {
takeoffIndex = i; takeoffIndex = viIndex;
_isInsertTakeoffValid = false; _isInsertTakeoffValid = false;
} }
if (!foundLand) { if (!foundLand) {
SimpleMissionItem* simpleItem = qobject_cast<SimpleMissionItem*>(pVI);
if (simpleItem) { if (simpleItem) {
switch (simpleItem->mavCommand()) { switch (simpleItem->mavCommand()) {
case MAV_CMD_NAV_LAND: case MAV_CMD_NAV_LAND:
...@@ -2197,7 +2204,7 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force) ...@@ -2197,7 +2204,7 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force)
case MAV_CMD_DO_LAND_START: case MAV_CMD_DO_LAND_START:
case MAV_CMD_NAV_RETURN_TO_LAUNCH: case MAV_CMD_NAV_RETURN_TO_LAUNCH:
foundLand = true; foundLand = true;
landIndex = i; landIndex = viIndex;
break; break;
default: default:
break; break;
...@@ -2206,7 +2213,27 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force) ...@@ -2206,7 +2213,27 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force)
FixedWingLandingComplexItem* fwLanding = qobject_cast<FixedWingLandingComplexItem*>(pVI); FixedWingLandingComplexItem* fwLanding = qobject_cast<FixedWingLandingComplexItem*>(pVI);
if (fwLanding) { if (fwLanding) {
foundLand = true; foundLand = true;
landIndex = i; landIndex = viIndex;
}
}
}
// ROI state handling
if (simpleItem) {
if (pVI->sequenceNumber() <= sequenceNumber) {
if (_isROIActive) {
if (simpleItem->mavCommand() == MAV_CMD_DO_SET_ROI_NONE ||
(simpleItem->mavCommand() == MAV_CMD_DO_SET_ROI &&
simpleItem->missionItem().param1() == MAV_ROI_NONE)) {
_isROIActive = false;
}
} else {
if (simpleItem->mavCommand() == MAV_CMD_DO_SET_ROI_LOCATION ||
simpleItem->mavCommand() == MAV_CMD_DO_SET_ROI_WPNEXT_OFFSET ||
(simpleItem->mavCommand() == MAV_CMD_DO_SET_ROI &&
simpleItem->missionItem().param1() == MAV_ROI_LOCATION)) {
_isROIActive = true;
}
} }
} }
} }
...@@ -2214,11 +2241,12 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force) ...@@ -2214,11 +2241,12 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force)
if (pVI->sequenceNumber() == sequenceNumber) { if (pVI->sequenceNumber() == sequenceNumber) {
pVI->setIsCurrentItem(true); pVI->setIsCurrentItem(true);
_currentPlanViewItem = pVI; _currentPlanViewItem = pVI;
_currentPlanViewIndex = sequenceNumber; _currentPlanViewSeqNum = sequenceNumber;
_currentPlanViewVIIndex = viIndex;
if (pVI->specifiesCoordinate() && !pVI->isStandaloneCoordinate()) { if (pVI->specifiesCoordinate() && !pVI->isStandaloneCoordinate()) {
// Determine split segment used to display line split editing ui. // Determine split segment used to display line split editing ui.
for (int j=i-1; j>0; j--) { for (int j=viIndex-1; j>0; j--) {
VisualMissionItem* pPrev = qobject_cast<VisualMissionItem*>(_visualItems->get(j)); VisualMissionItem* pPrev = qobject_cast<VisualMissionItem*>(_visualItems->get(j));
if (pPrev->specifiesCoordinate() && !pPrev->isStandaloneCoordinate()) { if (pPrev->specifiesCoordinate() && !pPrev->isStandaloneCoordinate()) {
VisualItemPair splitPair(pPrev, pVI); VisualItemPair splitPair(pPrev, pVI);
...@@ -2252,11 +2280,13 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force) ...@@ -2252,11 +2280,13 @@ void MissionController::setCurrentPlanViewIndex(int sequenceNumber, bool force)
} }
} }
emit currentPlanViewIndexChanged(); emit currentPlanViewSeqNumChanged();
emit currentPlanViewVIIndexChanged();
emit currentPlanViewItemChanged(); emit currentPlanViewItemChanged();
emit splitSegmentChanged(); emit splitSegmentChanged();
emit isInsertTakeoffValidChanged(); emit isInsertTakeoffValidChanged();
emit isInsertLandValidChanged(); emit isInsertLandValidChanged();
emit isROIActiveChanged();
emit flyThroughCommandsAllowedChanged(); emit flyThroughCommandsAllowedChanged();
} }
} }
...@@ -2349,16 +2379,3 @@ bool MissionController::isEmpty(void) const ...@@ -2349,16 +2379,3 @@ bool MissionController::isEmpty(void) const
{ {
return _visualItems->count() <= 1; return _visualItems->count() <= 1;
} }
int MissionController::visualItemIndexFromSequenceNumber(int sequenceNumber) const
{
for (int i=0; i<_visualItems->count(); i++) {
const VisualMissionItem* vi = _visualItems->value<VisualMissionItem*>(i);
if (vi->sequenceNumber() == sequenceNumber) {
return i;
}
}
qWarning() << "MissionController::getVisualItemIndex visual item not found";
return 0;
}
...@@ -77,7 +77,8 @@ public: ...@@ -77,7 +77,8 @@ public:
Q_PROPERTY(int missionItemCount READ missionItemCount NOTIFY missionItemCountChanged) ///< True mission item command count (only valid in Fly View) Q_PROPERTY(int missionItemCount READ missionItemCount NOTIFY missionItemCountChanged) ///< True mission item command count (only valid in Fly View)
Q_PROPERTY(int currentMissionIndex READ currentMissionIndex NOTIFY currentMissionIndexChanged) Q_PROPERTY(int currentMissionIndex READ currentMissionIndex NOTIFY currentMissionIndexChanged)
Q_PROPERTY(int resumeMissionIndex READ resumeMissionIndex NOTIFY resumeMissionIndexChanged) ///< Returns the item index two which a mission should be resumed. -1 indicates resume mission not available. Q_PROPERTY(int resumeMissionIndex READ resumeMissionIndex NOTIFY resumeMissionIndexChanged) ///< Returns the item index two which a mission should be resumed. -1 indicates resume mission not available.
Q_PROPERTY(int currentPlanViewIndex READ currentPlanViewIndex NOTIFY currentPlanViewIndexChanged) Q_PROPERTY(int currentPlanViewSeqNum READ currentPlanViewSeqNum NOTIFY currentPlanViewSeqNumChanged)
Q_PROPERTY(int currentPlanViewVIIndex READ currentPlanViewVIIndex NOTIFY currentPlanViewVIIndexChanged)
Q_PROPERTY(VisualMissionItem* currentPlanViewItem READ currentPlanViewItem NOTIFY currentPlanViewItemChanged) Q_PROPERTY(VisualMissionItem* currentPlanViewItem READ currentPlanViewItem NOTIFY currentPlanViewItemChanged)
Q_PROPERTY(double missionDistance READ missionDistance NOTIFY missionDistanceChanged) Q_PROPERTY(double missionDistance READ missionDistance NOTIFY missionDistanceChanged)
Q_PROPERTY(double missionTime READ missionTime NOTIFY missionTimeChanged) Q_PROPERTY(double missionTime READ missionTime NOTIFY missionTimeChanged)
...@@ -94,6 +95,7 @@ public: ...@@ -94,6 +95,7 @@ public:
Q_PROPERTY(QString structureScanComplexItemName READ structureScanComplexItemName CONSTANT) Q_PROPERTY(QString structureScanComplexItemName READ structureScanComplexItemName CONSTANT)
Q_PROPERTY(bool isInsertTakeoffValid MEMBER _isInsertTakeoffValid NOTIFY isInsertTakeoffValidChanged) Q_PROPERTY(bool isInsertTakeoffValid MEMBER _isInsertTakeoffValid NOTIFY isInsertTakeoffValidChanged)
Q_PROPERTY(bool isInsertLandValid MEMBER _isInsertLandValid NOTIFY isInsertLandValidChanged) Q_PROPERTY(bool isInsertLandValid MEMBER _isInsertLandValid NOTIFY isInsertLandValidChanged)
Q_PROPERTY(bool isROIActive MEMBER _isROIActive NOTIFY isROIActiveChanged)
Q_PROPERTY(bool flyThroughCommandsAllowed MEMBER _flyThroughCommandsAllowed NOTIFY flyThroughCommandsAllowedChanged) Q_PROPERTY(bool flyThroughCommandsAllowed MEMBER _flyThroughCommandsAllowed NOTIFY flyThroughCommandsAllowedChanged)
Q_INVOKABLE void removeMissionItem(int index); Q_INVOKABLE void removeMissionItem(int index);
...@@ -126,6 +128,12 @@ public: ...@@ -126,6 +128,12 @@ public:
/// @return Newly created item /// @return Newly created item
Q_INVOKABLE VisualMissionItem* insertROIMissionItem(QGeoCoordinate coordinate, int visualItemIndex, bool makeCurrentItem = false); Q_INVOKABLE VisualMissionItem* insertROIMissionItem(QGeoCoordinate coordinate, int visualItemIndex, bool makeCurrentItem = false);
/// Add a new Cancel ROI mission item to the list
/// @param visualItemIndex: index to insert at, -1 for end of list
/// @param makeCurrentItem: true: Make this item the current item
/// @return Newly created item
Q_INVOKABLE VisualMissionItem* insertCancelROIMissionItem(int visualItemIndex, bool makeCurrentItem = false);
/// Add a new complex mission item to the list /// Add a new complex mission item to the list
/// @param itemName: Name of complex item to create (from complexMissionItemNames) /// @param itemName: Name of complex item to create (from complexMissionItemNames)
/// @param mapCenterCoordinate: coordinate for current center of map /// @param mapCenterCoordinate: coordinate for current center of map
...@@ -150,10 +158,7 @@ public: ...@@ -150,10 +158,7 @@ public:
/// Sets a new current mission item (PlanView). /// Sets a new current mission item (PlanView).
/// @param sequenceNumber - index for new item, -1 to clear current item /// @param sequenceNumber - index for new item, -1 to clear current item
Q_INVOKABLE void setCurrentPlanViewIndex(int sequenceNumber, bool force); Q_INVOKABLE void setCurrentPlanViewSeqNum(int sequenceNumber, bool force);
/// Returns the index of this item in the visual item list
Q_INVOKABLE int visualItemIndexFromSequenceNumber(int sequenceNumber) const;
/// Determines if the mission has all data needed to be saved or sent to the vehicle. /// Determines if the mission has all data needed to be saved or sent to the vehicle.
/// IMPORTANT NOTE: The return value is a VisualMissionItem::ReadForSaveState value. It is an int here to work around /// IMPORTANT NOTE: The return value is a VisualMissionItem::ReadForSaveState value. It is an int here to work around
...@@ -196,7 +201,7 @@ public: ...@@ -196,7 +201,7 @@ public:
QVariantList waypointPath (void) { return _waypointPath; } QVariantList waypointPath (void) { return _waypointPath; }
QStringList complexMissionItemNames (void) const; QStringList complexMissionItemNames (void) const;
QGeoCoordinate plannedHomePosition (void) const; QGeoCoordinate plannedHomePosition (void) const;
VisualMissionItem* currentPlanViewItem (void) const; VisualMissionItem* currentPlanViewItem (void) const { return _currentPlanViewItem; }
double progressPct (void) const { return _progressPct; } double progressPct (void) const { return _progressPct; }
QString surveyComplexItemName (void) const { return patternSurveyName; } QString surveyComplexItemName (void) const { return patternSurveyName; }
QString corridorScanComplexItemName (void) const { return patternCorridorScanName; } QString corridorScanComplexItemName (void) const { return patternCorridorScanName; }
...@@ -206,7 +211,8 @@ public: ...@@ -206,7 +211,8 @@ public:
int missionItemCount (void) const { return _missionItemCount; } int missionItemCount (void) const { return _missionItemCount; }
int currentMissionIndex (void) const; int currentMissionIndex (void) const;
int resumeMissionIndex (void) const; int resumeMissionIndex (void) const;
int currentPlanViewIndex (void) const; int currentPlanViewSeqNum (void) const { return _currentPlanViewSeqNum; }
int currentPlanViewVIIndex (void) const { return _currentPlanViewVIIndex; }
double missionDistance (void) const { return _missionFlightStatus.totalDistance; } double missionDistance (void) const { return _missionFlightStatus.totalDistance; }
double missionTime (void) const { return _missionFlightStatus.totalTime; } double missionTime (void) const { return _missionFlightStatus.totalTime; }
...@@ -249,12 +255,14 @@ signals: ...@@ -249,12 +255,14 @@ signals:
void plannedHomePositionChanged (QGeoCoordinate plannedHomePosition); void plannedHomePositionChanged (QGeoCoordinate plannedHomePosition);
void progressPctChanged (double progressPct); void progressPctChanged (double progressPct);
void currentMissionIndexChanged (int currentMissionIndex); void currentMissionIndexChanged (int currentMissionIndex);
void currentPlanViewIndexChanged (void); void currentPlanViewSeqNumChanged (void);
void currentPlanViewVIIndexChanged (void);
void currentPlanViewItemChanged (void); void currentPlanViewItemChanged (void);
void missionBoundingCubeChanged (void); void missionBoundingCubeChanged (void);
void missionItemCountChanged (int missionItemCount); void missionItemCountChanged (int missionItemCount);
void isInsertTakeoffValidChanged (void); void isInsertTakeoffValidChanged (void);
void isInsertLandValidChanged (void); void isInsertLandValidChanged (void);
void isROIActiveChanged (void);
void flyThroughCommandsAllowedChanged (void); void flyThroughCommandsAllowedChanged (void);
private slots: private slots:
...@@ -325,7 +333,8 @@ private: ...@@ -325,7 +333,8 @@ private:
MissionFlightStatus_t _missionFlightStatus; MissionFlightStatus_t _missionFlightStatus;
AppSettings* _appSettings; AppSettings* _appSettings;
double _progressPct; double _progressPct;
int _currentPlanViewIndex; int _currentPlanViewSeqNum;
int _currentPlanViewVIIndex;
VisualMissionItem* _currentPlanViewItem; VisualMissionItem* _currentPlanViewItem;
QTimer _updateTimer; QTimer _updateTimer;
QGCGeoBoundingCube _travelBoundingCube; QGCGeoBoundingCube _travelBoundingCube;
...@@ -333,6 +342,7 @@ private: ...@@ -333,6 +342,7 @@ private:
CoordinateVector* _splitSegment; CoordinateVector* _splitSegment;
bool _isInsertTakeoffValid = true; bool _isInsertTakeoffValid = true;
bool _isInsertLandValid = true; bool _isInsertLandValid = true;
bool _isROIActive = false;
bool _flyThroughCommandsAllowed = true; bool _flyThroughCommandsAllowed = true;
static const char* _settingsGroup; static const char* _settingsGroup;
......
...@@ -24,5 +24,5 @@ void StructureScanPlanCreator::createPlan(const QGeoCoordinate& mapCenterCoord) ...@@ -24,5 +24,5 @@ void StructureScanPlanCreator::createPlan(const QGeoCoordinate& mapCenterCoord)
VisualMissionItem* takeoffItem = _missionController->insertTakeoffItem(mapCenterCoord, -1); VisualMissionItem* takeoffItem = _missionController->insertTakeoffItem(mapCenterCoord, -1);
_missionController->insertComplexMissionItem(MissionController::patternStructureScanName, mapCenterCoord, -1)->setWizardMode(true); _missionController->insertComplexMissionItem(MissionController::patternStructureScanName, mapCenterCoord, -1)->setWizardMode(true);
_missionController->insertLandItem(mapCenterCoord, -1); _missionController->insertLandItem(mapCenterCoord, -1);
_missionController->setCurrentPlanViewIndex(takeoffItem->sequenceNumber(), true); _missionController->setCurrentPlanViewSeqNum(takeoffItem->sequenceNumber(), true);
} }
...@@ -25,5 +25,5 @@ void SurveyPlanCreator::createPlan(const QGeoCoordinate& mapCenterCoord) ...@@ -25,5 +25,5 @@ void SurveyPlanCreator::createPlan(const QGeoCoordinate& mapCenterCoord)
VisualMissionItem* takeoffItem = _missionController->insertTakeoffItem(mapCenterCoord, -1); VisualMissionItem* takeoffItem = _missionController->insertTakeoffItem(mapCenterCoord, -1);
_missionController->insertComplexMissionItem(MissionController::patternSurveyName, mapCenterCoord, -1); _missionController->insertComplexMissionItem(MissionController::patternSurveyName, mapCenterCoord, -1);
_missionController->insertLandItem(mapCenterCoord, -1); _missionController->insertLandItem(mapCenterCoord, -1);
_missionController->setCurrentPlanViewIndex(takeoffItem->sequenceNumber(), true); _missionController->setCurrentPlanViewSeqNum(takeoffItem->sequenceNumber(), true);
} }
...@@ -30,8 +30,6 @@ Rectangle { ...@@ -30,8 +30,6 @@ Rectangle {
signal clicked signal clicked
signal remove signal remove
signal insertWaypoint
signal insertComplexItem(string complexItemName)
signal selectNextNotReadyItem signal selectNextNotReadyItem
property var _masterController: masterController property var _masterController: masterController
......
...@@ -60,7 +60,7 @@ Rectangle { ...@@ -60,7 +60,7 @@ Rectangle {
orientation: ListView.Horizontal orientation: ListView.Horizontal
spacing: 0 spacing: 0
clip: true clip: true
currentIndex: _missionController.currentPlanViewIndex currentIndex: _missionController.currentPlanViewSeqNum
onCountChanged: { onCountChanged: {
var calcLength = (statusListView.count + 1) * (statusListView.count ? statusListView.contentItem.children[0].width : 1) var calcLength = (statusListView.count + 1) * (statusListView.count ? statusListView.contentItem.children[0].width : 1)
......
This diff is collapsed.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment