Unverified Commit c8672124 authored by Don Gagne's avatar Don Gagne Committed by GitHub

Merge pull request #6597 from DonLakeFlyer/SyncIndicator

Plan: Sync indicator fixes
parents 7c359b24 b83e16a0
...@@ -54,20 +54,21 @@ const char* MissionController::_jsonMavAutopilotKey = "MAV_AUTOPILOT"; ...@@ -54,20 +54,21 @@ const char* MissionController::_jsonMavAutopilotKey = "MAV_AUTOPILOT";
const int MissionController::_missionFileVersion = 2; const int MissionController::_missionFileVersion = 2;
MissionController::MissionController(PlanMasterController* masterController, QObject *parent) MissionController::MissionController(PlanMasterController* masterController, QObject *parent)
: PlanElementController(masterController, parent) : PlanElementController (masterController, parent)
, _missionManager(_managerVehicle->missionManager()) , _missionManager (_managerVehicle->missionManager())
, _visualItems(NULL) , _visualItems (NULL)
, _settingsItem(NULL) , _settingsItem (NULL)
, _firstItemsFromVehicle(false) , _firstItemsFromVehicle (false)
, _itemsRequested(false) , _itemsRequested (false)
, _surveyMissionItemName(tr("Survey")) , _inRecalcSequence (false)
, _fwLandingMissionItemName(tr("Fixed Wing Landing")) , _surveyMissionItemName (tr("Survey"))
, _structureScanMissionItemName(tr("Structure Scan")) , _fwLandingMissionItemName (tr("Fixed Wing Landing"))
, _corridorScanMissionItemName(tr("Corridor Scan")) , _structureScanMissionItemName (tr("Structure Scan"))
, _appSettings(qgcApp()->toolbox()->settingsManager()->appSettings()) , _corridorScanMissionItemName (tr("Corridor Scan"))
, _progressPct(0) , _appSettings (qgcApp()->toolbox()->settingsManager()->appSettings())
, _currentPlanViewIndex(-1) , _progressPct (0)
, _currentPlanViewItem(NULL) , _currentPlanViewIndex (-1)
, _currentPlanViewItem (NULL)
{ {
_resetMissionFlightStatus(); _resetMissionFlightStatus();
managerVehicleChanged(_managerVehicle); managerVehicleChanged(_managerVehicle);
...@@ -142,17 +143,17 @@ void MissionController::_init(void) ...@@ -142,17 +143,17 @@ void MissionController::_init(void)
// Called when new mission items have completed downloading from Vehicle // Called when new mission items have completed downloading from Vehicle
void MissionController::_newMissionItemsAvailableFromVehicle(bool removeAllRequested) void MissionController::_newMissionItemsAvailableFromVehicle(bool removeAllRequested)
{ {
qCDebug(MissionControllerLog) << "_newMissionItemsAvailableFromVehicle"; qCDebug(MissionControllerLog) << "_newMissionItemsAvailableFromVehicle flyView:count" << _flyView << _missionManager->missionItems().count();
// Fly view always reloads on _loadComplete // Fly view always reloads on _loadComplete
// Plan view only reloads on _loadComplete if specifically requested // Plan view only reloads on _loadComplete if specifically requested
if (_flyView || removeAllRequested || _itemsRequested) { if (_flyView || removeAllRequested || _itemsRequested || _visualItems->count() <= 1) {
// Fly Mode (accept if): // Fly Mode (accept if):
// - Always accepts new items from the vehicle so Fly view is kept up to date // - Always accepts new items from the vehicle so Fly view is kept up to date
// Edit Mode (accept if): // Edit Mode (accept if):
// - Either a load from vehicle was manually requested or // - Remove all was requested from Fly view (clear mission on flight end)
// - A load from vehicle was manually requested
// - The initial automatic load from a vehicle completed and the current editor is empty // - The initial automatic load from a vehicle completed and the current editor is empty
// - Remove all way requested from Fly view (clear mission on flight end)
QmlObjectListModel* newControllerMissionItems = new QmlObjectListModel(this); QmlObjectListModel* newControllerMissionItems = new QmlObjectListModel(this);
const QList<MissionItem*>& newMissionItems = _missionManager->missionItems(); const QList<MissionItem*>& newMissionItems = _missionManager->missionItems();
...@@ -1481,15 +1482,21 @@ void MissionController::_recalcMissionFlightStatus() ...@@ -1481,15 +1482,21 @@ void MissionController::_recalcMissionFlightStatus()
// This will update the sequence numbers to be sequential starting from 0 // This will update the sequence numbers to be sequential starting from 0
void MissionController::_recalcSequence(void) void MissionController::_recalcSequence(void)
{ {
if (_inRecalcSequence) {
// Don't let this call recurse due to signalling
return;
}
// Setup ascending sequence numbers for all visual items // Setup ascending sequence numbers for all visual items
_inRecalcSequence = true;
int sequenceNumber = 0; int sequenceNumber = 0;
for (int i=0; i<_visualItems->count(); i++) { for (int i=0; i<_visualItems->count(); i++) {
VisualMissionItem* item = qobject_cast<VisualMissionItem*>(_visualItems->get(i)); VisualMissionItem* item = qobject_cast<VisualMissionItem*>(_visualItems->get(i));
item->setSequenceNumber(sequenceNumber); item->setSequenceNumber(sequenceNumber);
sequenceNumber = item->lastSequenceNumber() + 1; sequenceNumber = item->lastSequenceNumber() + 1;
} }
_inRecalcSequence = false;
} }
// This will update the child item hierarchy // This will update the child item hierarchy
......
...@@ -267,6 +267,7 @@ private: ...@@ -267,6 +267,7 @@ private:
CoordVectHashTable _linesTable; CoordVectHashTable _linesTable;
bool _firstItemsFromVehicle; bool _firstItemsFromVehicle;
bool _itemsRequested; bool _itemsRequested;
bool _inRecalcSequence;
MissionFlightStatus_t _missionFlightStatus; MissionFlightStatus_t _missionFlightStatus;
QString _surveyMissionItemName; QString _surveyMissionItemName;
QString _fwLandingMissionItemName; QString _fwLandingMissionItemName;
......
...@@ -63,7 +63,6 @@ signals: ...@@ -63,7 +63,6 @@ signals:
void containsItemsChanged (bool containsItems); void containsItemsChanged (bool containsItems);
void syncInProgressChanged (bool syncInProgress); void syncInProgressChanged (bool syncInProgress);
void dirtyChanged (bool dirty); void dirtyChanged (bool dirty);
void vehicleChanged (Vehicle* vehicle);
void sendComplete (void); void sendComplete (void);
void removeAllComplete (void); void removeAllComplete (void);
......
...@@ -22,17 +22,17 @@ ...@@ -22,17 +22,17 @@
QGC_LOGGING_CATEGORY(PlanManagerLog, "PlanManagerLog") QGC_LOGGING_CATEGORY(PlanManagerLog, "PlanManagerLog")
PlanManager::PlanManager(Vehicle* vehicle, MAV_MISSION_TYPE planType) PlanManager::PlanManager(Vehicle* vehicle, MAV_MISSION_TYPE planType)
: _vehicle(vehicle) : _vehicle (vehicle)
, _planType(planType) , _planType (planType)
, _dedicatedLink(NULL) , _dedicatedLink (NULL)
, _ackTimeoutTimer(NULL) , _ackTimeoutTimer (NULL)
, _expectedAck(AckNone) , _expectedAck (AckNone)
, _transactionInProgress(TransactionNone) , _transactionInProgress (TransactionNone)
, _resumeMission(false) , _resumeMission (false)
, _lastMissionRequest(-1) , _lastMissionRequest (-1)
, _missionItemCountToRead(-1) , _missionItemCountToRead (-1)
, _currentMissionIndex(-1) , _currentMissionIndex (-1)
, _lastCurrentIndex(-1) , _lastCurrentIndex (-1)
{ {
_ackTimeoutTimer = new QTimer(this); _ackTimeoutTimer = new QTimer(this);
_ackTimeoutTimer->setSingleShot(true); _ackTimeoutTimer->setSingleShot(true);
...@@ -59,9 +59,8 @@ void PlanManager::_writeMissionItemsWorker(void) ...@@ -59,9 +59,8 @@ void PlanManager::_writeMissionItemsWorker(void)
_itemIndicesToWrite << i; _itemIndicesToWrite << i;
} }
_transactionInProgress = TransactionWrite;
_retryCount = 0; _retryCount = 0;
emit inProgressChanged(true); _setTransactionInProgress(TransactionWrite);
_connectToMavlink(); _connectToMavlink();
_writeMissionCount(); _writeMissionCount();
} }
...@@ -137,8 +136,7 @@ void PlanManager::loadFromVehicle(void) ...@@ -137,8 +136,7 @@ void PlanManager::loadFromVehicle(void)
} }
_retryCount = 0; _retryCount = 0;
_transactionInProgress = TransactionRead; _setTransactionInProgress(TransactionRead);
emit inProgressChanged(true);
_connectToMavlink(); _connectToMavlink();
_requestList(); _requestList();
} }
...@@ -822,12 +820,7 @@ void PlanManager::_finishTransaction(bool success, bool apmGuidedItemWrite) ...@@ -822,12 +820,7 @@ void PlanManager::_finishTransaction(bool success, bool apmGuidedItemWrite)
// First thing we do is clear the transaction. This way inProgesss is off when we signal transaction complete. // First thing we do is clear the transaction. This way inProgesss is off when we signal transaction complete.
TransactionType_t currentTransactionType = _transactionInProgress; TransactionType_t currentTransactionType = _transactionInProgress;
_transactionInProgress = TransactionNone; _setTransactionInProgress(TransactionNone);
if (currentTransactionType != TransactionNone) {
_transactionInProgress = TransactionNone;
qCDebug(PlanManagerLog) << QStringLiteral("inProgressChanged %1").arg(_planTypeString());
emit inProgressChanged(false);
}
switch (currentTransactionType) { switch (currentTransactionType) {
case TransactionRead: case TransactionRead:
...@@ -920,9 +913,8 @@ void PlanManager::removeAll(void) ...@@ -920,9 +913,8 @@ void PlanManager::removeAll(void)
emit lastCurrentIndexChanged(-1); emit lastCurrentIndexChanged(-1);
} }
_transactionInProgress = TransactionRemoveAll;
_retryCount = 0; _retryCount = 0;
emit inProgressChanged(true); _setTransactionInProgress(TransactionRemoveAll);
_removeAllWorker(); _removeAllWorker();
} }
...@@ -970,3 +962,12 @@ QString PlanManager::_planTypeString(void) ...@@ -970,3 +962,12 @@ QString PlanManager::_planTypeString(void)
return QStringLiteral("T:Unknown"); return QStringLiteral("T:Unknown");
} }
} }
void PlanManager::_setTransactionInProgress(TransactionType_t type)
{
if (_transactionInProgress != type) {
qCDebug(PlanManagerLog) << "_setTransactionInProgress" << _planTypeString() << type;
_transactionInProgress = type;
emit inProgressChanged(inProgress());
}
}
...@@ -153,6 +153,9 @@ protected: ...@@ -153,6 +153,9 @@ protected:
QList<MissionItem*> _writeMissionItems; ///< Set of mission items currently being written to vehicle QList<MissionItem*> _writeMissionItems; ///< Set of mission items currently being written to vehicle
int _currentMissionIndex; int _currentMissionIndex;
int _lastCurrentIndex; int _lastCurrentIndex;
private:
void _setTransactionInProgress(TransactionType_t type);
}; };
#endif #endif
...@@ -42,7 +42,6 @@ PlanMasterController::PlanMasterController(QObject* parent) ...@@ -42,7 +42,6 @@ PlanMasterController::PlanMasterController(QObject* parent)
, _loadRallyPoints (false) , _loadRallyPoints (false)
, _sendGeoFence (false) , _sendGeoFence (false)
, _sendRallyPoints (false) , _sendRallyPoints (false)
, _syncInProgress (false)
{ {
connect(&_missionController, &MissionController::dirtyChanged, this, &PlanMasterController::dirtyChanged); connect(&_missionController, &MissionController::dirtyChanged, this, &PlanMasterController::dirtyChanged);
connect(&_geoFenceController, &GeoFenceController::dirtyChanged, this, &PlanMasterController::dirtyChanged); connect(&_geoFenceController, &GeoFenceController::dirtyChanged, this, &PlanMasterController::dirtyChanged);
...@@ -123,15 +122,18 @@ void PlanMasterController::_activeVehicleChanged(Vehicle* activeVehicle) ...@@ -123,15 +122,18 @@ void PlanMasterController::_activeVehicleChanged(Vehicle* activeVehicle)
connect(_managerVehicle->geoFenceManager(), &GeoFenceManager::sendComplete, this, &PlanMasterController::_sendGeoFenceComplete); connect(_managerVehicle->geoFenceManager(), &GeoFenceManager::sendComplete, this, &PlanMasterController::_sendGeoFenceComplete);
connect(_managerVehicle->rallyPointManager(), &RallyPointManager::sendComplete, this, &PlanMasterController::_sendRallyPointsComplete); connect(_managerVehicle->rallyPointManager(), &RallyPointManager::sendComplete, this, &PlanMasterController::_sendRallyPointsComplete);
} }
if (newOffline != _offline) {
_offline = newOffline;
emit offlineEditingChanged(newOffline);
}
_missionController.managerVehicleChanged(_managerVehicle); _missionController.managerVehicleChanged(_managerVehicle);
_geoFenceController.managerVehicleChanged(_managerVehicle); _geoFenceController.managerVehicleChanged(_managerVehicle);
_rallyPointController.managerVehicleChanged(_managerVehicle); _rallyPointController.managerVehicleChanged(_managerVehicle);
// Vehicle changed so we need to signal everything
_offline = newOffline;
emit containsItemsChanged(containsItems());
emit syncInProgressChanged();
emit dirtyChanged(dirty());
emit offlineChanged(offline());
if (!_flyView) { if (!_flyView) {
if (!offline()) { if (!offline()) {
// We are in Plan view and we have a newly connected vehicle: // We are in Plan view and we have a newly connected vehicle:
...@@ -170,9 +172,7 @@ void PlanMasterController::loadFromVehicle(void) ...@@ -170,9 +172,7 @@ void PlanMasterController::loadFromVehicle(void)
qCWarning(PlanMasterControllerLog) << "PlanMasterController::loadFromVehicle called while syncInProgress"; qCWarning(PlanMasterControllerLog) << "PlanMasterController::loadFromVehicle called while syncInProgress";
} else { } else {
_loadGeoFence = true; _loadGeoFence = true;
_syncInProgress = true; qCDebug(PlanMasterControllerLog) << "PlanMasterController::loadFromVehicle calling _missionController.loadFromVehicle";
emit syncInProgressChanged(true);
qCDebug(PlanMasterControllerLog) << "PlanMasterController::loadFromVehicle _missionController.loadFromVehicle";
_missionController.loadFromVehicle(); _missionController.loadFromVehicle();
setDirty(false); setDirty(false);
} }
...@@ -185,7 +185,7 @@ void PlanMasterController::_loadMissionComplete(void) ...@@ -185,7 +185,7 @@ void PlanMasterController::_loadMissionComplete(void)
_loadGeoFence = false; _loadGeoFence = false;
_loadRallyPoints = true; _loadRallyPoints = true;
if (_geoFenceController.supported()) { if (_geoFenceController.supported()) {
qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadMissionComplete _geoFenceController.loadFromVehicle"; qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadMissionComplete calling _geoFenceController.loadFromVehicle";
_geoFenceController.loadFromVehicle(); _geoFenceController.loadFromVehicle();
} else { } else {
qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadMissionComplete GeoFence not supported skipping"; qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadMissionComplete GeoFence not supported skipping";
...@@ -201,7 +201,7 @@ void PlanMasterController::_loadGeoFenceComplete(void) ...@@ -201,7 +201,7 @@ void PlanMasterController::_loadGeoFenceComplete(void)
if (!_flyView && _loadRallyPoints) { if (!_flyView && _loadRallyPoints) {
_loadRallyPoints = false; _loadRallyPoints = false;
if (_rallyPointController.supported()) { if (_rallyPointController.supported()) {
qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadGeoFenceComplete _rallyPointController.loadFromVehicle"; qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadGeoFenceComplete calling _rallyPointController.loadFromVehicle";
_rallyPointController.loadFromVehicle(); _rallyPointController.loadFromVehicle();
} else { } else {
qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadMissionComplete Rally Points not supported skipping"; qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadMissionComplete Rally Points not supported skipping";
...@@ -214,10 +214,7 @@ void PlanMasterController::_loadGeoFenceComplete(void) ...@@ -214,10 +214,7 @@ void PlanMasterController::_loadGeoFenceComplete(void)
void PlanMasterController::_loadRallyPointsComplete(void) void PlanMasterController::_loadRallyPointsComplete(void)
{ {
if (!_flyView) { qCDebug(PlanMasterControllerLog) << "PlanMasterController::_loadRallyPointsComplete";
_syncInProgress = false;
emit syncInProgressChanged(false);
}
} }
void PlanMasterController::_sendMissionComplete(void) void PlanMasterController::_sendMissionComplete(void)
...@@ -252,11 +249,7 @@ void PlanMasterController::_sendGeoFenceComplete(void) ...@@ -252,11 +249,7 @@ void PlanMasterController::_sendGeoFenceComplete(void)
void PlanMasterController::_sendRallyPointsComplete(void) void PlanMasterController::_sendRallyPointsComplete(void)
{ {
if (_syncInProgress) {
qCDebug(PlanMasterControllerLog) << "PlanMasterController::sendToVehicle Rally Point send complete"; qCDebug(PlanMasterControllerLog) << "PlanMasterController::sendToVehicle Rally Point send complete";
_syncInProgress = false;
emit syncInProgressChanged(false);
}
} }
void PlanMasterController::sendToVehicle(void) void PlanMasterController::sendToVehicle(void)
...@@ -273,8 +266,6 @@ void PlanMasterController::sendToVehicle(void) ...@@ -273,8 +266,6 @@ void PlanMasterController::sendToVehicle(void)
} else { } else {
qCDebug(PlanMasterControllerLog) << "PlanMasterController::sendToVehicle start mission sendToVehicle"; qCDebug(PlanMasterControllerLog) << "PlanMasterController::sendToVehicle start mission sendToVehicle";
_sendGeoFence = true; _sendGeoFence = true;
_syncInProgress = true;
emit syncInProgressChanged(true);
_missionController.sendToVehicle(); _missionController.sendToVehicle();
setDirty(false); setDirty(false);
} }
...@@ -504,10 +495,7 @@ void PlanMasterController::sendPlanToVehicle(Vehicle* vehicle, const QString& fi ...@@ -504,10 +495,7 @@ void PlanMasterController::sendPlanToVehicle(Vehicle* vehicle, const QString& fi
void PlanMasterController::_showPlanFromManagerVehicle(void) void PlanMasterController::_showPlanFromManagerVehicle(void)
{ {
if (!_managerVehicle->initialPlanRequestComplete() && if (!_managerVehicle->initialPlanRequestComplete() && !syncInProgress()) {
!_missionController.syncInProgress() &&
!_geoFenceController.syncInProgress() &&
!_rallyPointController.syncInProgress()) {
// Something went wrong with initial load. All controllers are idle, so just force it off // Something went wrong with initial load. All controllers are idle, so just force it off
_managerVehicle->forceInitialPlanRequestComplete(); _managerVehicle->forceInitialPlanRequestComplete();
} }
...@@ -519,3 +507,10 @@ void PlanMasterController::_showPlanFromManagerVehicle(void) ...@@ -519,3 +507,10 @@ void PlanMasterController::_showPlanFromManagerVehicle(void)
} }
} }
} }
bool PlanMasterController::syncInProgress(void) const
{
return _missionController.syncInProgress() ||
_geoFenceController.syncInProgress() ||
_rallyPointController.syncInProgress();
}
...@@ -34,7 +34,7 @@ public: ...@@ -34,7 +34,7 @@ public:
Q_PROPERTY(RallyPointController* rallyPointController READ rallyPointController CONSTANT) Q_PROPERTY(RallyPointController* rallyPointController READ rallyPointController CONSTANT)
Q_PROPERTY(Vehicle* controllerVehicle MEMBER _controllerVehicle CONSTANT) Q_PROPERTY(Vehicle* controllerVehicle MEMBER _controllerVehicle CONSTANT)
Q_PROPERTY(bool offline READ offline NOTIFY offlineEditingChanged) ///< true: controller is not connected to an active vehicle Q_PROPERTY(bool offline READ offline NOTIFY offlineChanged) ///< true: controller is not connected to an active vehicle
Q_PROPERTY(bool containsItems READ containsItems NOTIFY containsItemsChanged) ///< true: Elemement is non-empty Q_PROPERTY(bool containsItems READ containsItems NOTIFY containsItemsChanged) ///< true: Elemement is non-empty
Q_PROPERTY(bool syncInProgress READ syncInProgress NOTIFY syncInProgressChanged) ///< true: Information is currently being saved/sent, false: no active save/send in progress Q_PROPERTY(bool syncInProgress READ syncInProgress NOTIFY syncInProgressChanged) ///< true: Information is currently being saved/sent, false: no active save/send in progress
Q_PROPERTY(bool dirty READ dirty WRITE setDirty NOTIFY dirtyChanged) ///< true: Unsaved/sent changes are present, false: no changes since last save/send Q_PROPERTY(bool dirty READ dirty WRITE setDirty NOTIFY dirtyChanged) ///< true: Unsaved/sent changes are present, false: no changes since last save/send
...@@ -74,7 +74,7 @@ public: ...@@ -74,7 +74,7 @@ public:
bool offline (void) const { return _offline; } bool offline (void) const { return _offline; }
bool containsItems (void) const; bool containsItems (void) const;
bool syncInProgress (void) const { return _syncInProgress; } bool syncInProgress (void) const;
bool dirty (void) const; bool dirty (void) const;
void setDirty (bool dirty); void setDirty (bool dirty);
QString fileExtension (void) const; QString fileExtension (void) const;
...@@ -90,10 +90,9 @@ public: ...@@ -90,10 +90,9 @@ public:
signals: signals:
void containsItemsChanged (bool containsItems); void containsItemsChanged (bool containsItems);
void syncInProgressChanged (bool syncInProgress); void syncInProgressChanged (void);
void dirtyChanged (bool dirty); void dirtyChanged (bool dirty);
void vehicleChanged (Vehicle* vehicle); void offlineChanged (bool offlineEditing);
void offlineEditingChanged (bool offlineEditing);
private slots: private slots:
void _activeVehicleChanged(Vehicle* activeVehicle); void _activeVehicleChanged(Vehicle* activeVehicle);
...@@ -119,7 +118,6 @@ private: ...@@ -119,7 +118,6 @@ private:
bool _loadRallyPoints; bool _loadRallyPoints;
bool _sendGeoFence; bool _sendGeoFence;
bool _sendRallyPoints; bool _sendRallyPoints;
bool _syncInProgress;
static const int _planFileVersion; static const int _planFileVersion;
static const char* _planFileType; static const char* _planFileType;
......
...@@ -310,6 +310,12 @@ Rectangle { ...@@ -310,6 +310,12 @@ Rectangle {
width: _controllerProgressPct * parent.width width: _controllerProgressPct * parent.width
color: qgcPal.colorGreen color: qgcPal.colorGreen
visible: false visible: false
onVisibleChanged: {
if (visible) {
largeProgressBar._userHide = false
}
}
} }
/* /*
......
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