diff --git a/src/FlightDisplay/FlightDisplayViewMap.qml b/src/FlightDisplay/FlightDisplayViewMap.qml index 943f6c3c5ead7a225202f5e3764ea47c1905a5fd..cff60f287f3fba817d190d9fdd1368ac1f398f21 100644 --- a/src/FlightDisplay/FlightDisplayViewMap.qml +++ b/src/FlightDisplay/FlightDisplayViewMap.qml @@ -60,8 +60,12 @@ FlightMap { // When the user pans the map we stop responding to vehicle coordinate updates until the panRecenterTimer fires onUserPannedChanged: { - _disableVehicleTracking = true - panRecenterTimer.start() + if (userPanned) { + console.log("user panned") + userPanned = false + _disableVehicleTracking = true + panRecenterTimer.restart() + } } function pointInRect(point, rect) { diff --git a/src/FlightDisplay/GuidedActionsController.qml b/src/FlightDisplay/GuidedActionsController.qml index e19ff89306c1420495eb5a0c27ad25184b3259fb..64c1e1fb53fc0440cb4b0c8370285bb631ef2d42 100644 --- a/src/FlightDisplay/GuidedActionsController.qml +++ b/src/FlightDisplay/GuidedActionsController.qml @@ -87,8 +87,8 @@ Item { property bool showTakeoff: _activeVehicle && _activeVehicle.guidedModeSupported && !_vehicleFlying && !_activeVehicle.fixedWing property bool showLand: _activeVehicle && _activeVehicle.guidedModeSupported && _vehicleArmed && !_activeVehicle.fixedWing && !_vehicleInLandMode property bool showStartMission: _activeVehicle && _missionAvailable && !_missionActive && !_vehicleFlying - property bool showContinueMission: _activeVehicle && _missionAvailable && !_missionActive && _vehicleFlying - property bool showResumeMission: _activeVehicle && !_vehicleFlying && _missionAvailable && _resumeMissionIndex > 0 + property bool showContinueMission: _activeVehicle && _missionAvailable && !_missionActive && _vehicleFlying && (_currentMissionIndex < missionController.visualItems.count - 1) + property bool showResumeMission: _activeVehicle && !_vehicleFlying && _missionAvailable && _resumeMissionIndex > 0 && (_resumeMissionIndex < missionController.visualItems.count - 2) property bool showPause: _activeVehicle && _vehicleArmed && _activeVehicle.pauseVehicleSupported && _vehicleFlying && !_vehiclePaused property bool showChangeAlt: (_activeVehicle && _vehicleFlying) && _activeVehicle.guidedModeSupported && _vehicleArmed && !_missionActive property bool showOrbit: !_hideOrbit && _activeVehicle && _vehicleFlying && _activeVehicle.orbitModeSupported && _vehicleArmed && !_missionActive @@ -105,11 +105,14 @@ Item { property bool _vehicleInMissionMode: false property bool _vehicleInRTLMode: false property bool _vehicleInLandMode: false + property int _currentMissionIndex: missionController.currentMissionIndex property int _resumeMissionIndex: missionController.resumeMissionIndex property bool _hideEmergenyStop: !QGroundControl.corePlugin.options.guidedBarShowEmergencyStop property bool _hideOrbit: !QGroundControl.corePlugin.options.guidedBarShowOrbit property var _actionData + on_CurrentMissionIndexChanged: console.log("_currentMissionIndex", _currentMissionIndex) + on_FlightModeChanged: { _vehiclePaused = _flightMode === _activeVehicle.pauseFlightMode _vehicleInRTLMode = _flightMode === _activeVehicle.rtlFlightMode diff --git a/src/MissionManager/MissionController.cc b/src/MissionManager/MissionController.cc index a8bf784866f041a6c53cc82446a8f948e19f8fff..158c7b902a3c3d892c87275b5d2f69590e7bbf7d 100644 --- a/src/MissionManager/MissionController.cc +++ b/src/MissionManager/MissionController.cc @@ -1528,6 +1528,19 @@ int MissionController::resumeMissionIndex(void) const return resumeIndex; } +int MissionController::currentMissionIndex(void) const +{ + if (_editMode) { + return -1; + } else { + int currentIndex = _missionManager->currentIndex(); + if (!_controllerVehicle->firmwarePlugin()->sendHomePositionToVehicle()) { + currentIndex++; + } + return currentIndex; + } +} + void MissionController::_currentMissionIndexChanged(int sequenceNumber) { if (!_editMode) { @@ -1539,6 +1552,7 @@ void MissionController::_currentMissionIndexChanged(int sequenceNumber) VisualMissionItem* item = qobject_cast(_visualItems->get(i)); item->setIsCurrentItem(item->sequenceNumber() == sequenceNumber); } + emit currentMissionIndexChanged(currentMissionIndex()); } } diff --git a/src/MissionManager/MissionController.h b/src/MissionManager/MissionController.h index 2721663bc6d28d862165b5cac6879b0301a80749..b784ace6113b500946b3d10139f93a4879e31dd8 100644 --- a/src/MissionManager/MissionController.h +++ b/src/MissionManager/MissionController.h @@ -70,7 +70,8 @@ public: Q_PROPERTY(double progressPct READ progressPct NOTIFY progressPctChanged) - Q_PROPERTY(int resumeMissionIndex READ resumeMissionIndex NOTIFY resumeMissionIndexChanged) + 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(double missionDistance READ missionDistance NOTIFY missionDistanceChanged) Q_PROPERTY(double missionTime READ missionTime NOTIFY missionTimeChanged) @@ -134,7 +135,7 @@ public: QGeoCoordinate plannedHomePosition (void) const; double progressPct (void) const { return _progressPct; } - /// Returns the item index two which a mission should be resumed. -1 indicates resume mission not available. + int currentMissionIndex(void) const; int resumeMissionIndex(void) const; double missionDistance (void) const { return _missionFlightStatus.totalDistance; } @@ -166,6 +167,7 @@ signals: void batteriesRequiredChanged(int batteriesRequired); void plannedHomePositionChanged(QGeoCoordinate plannedHomePosition); void progressPctChanged(double progressPct); + void currentMissionIndexChanged(int currentMissionIndex); private slots: void _newMissionItemsAvailableFromVehicle(bool removeAllRequested);