Commit 36377fa7 authored by Don Gagne's avatar Don Gagne

Fixes for relative altitude signalling

parent 78115454
...@@ -74,8 +74,8 @@ public: ...@@ -74,8 +74,8 @@ public:
void applyNewAltitude (double newAltitude) final { Q_UNUSED(newAltitude); /* no action */ } void applyNewAltitude (double newAltitude) final { Q_UNUSED(newAltitude); /* no action */ }
double specifiedFlightSpeed (void) final; double specifiedFlightSpeed (void) final;
bool coordinateHasRelativeAltitude (void) const final { return true; } bool coordinateHasRelativeAltitude (void) const final { return false; }
bool exitCoordinateHasRelativeAltitude (void) const final { return true; } bool exitCoordinateHasRelativeAltitude (void) const final { return false; }
bool exitCoordinateSameAsEntry (void) const final { return true; } bool exitCoordinateSameAsEntry (void) const final { return true; }
void setDirty (bool dirty) final; void setDirty (bool dirty) final;
......
...@@ -604,6 +604,7 @@ void SimpleMissionItem::_syncAltitudeRelativeToHomeToFrame(const QVariant& value ...@@ -604,6 +604,7 @@ void SimpleMissionItem::_syncAltitudeRelativeToHomeToFrame(const QVariant& value
if (!_syncingAltitudeRelativeToHomeAndFrame) { if (!_syncingAltitudeRelativeToHomeAndFrame) {
_syncingAltitudeRelativeToHomeAndFrame = true; _syncingAltitudeRelativeToHomeAndFrame = true;
_missionItem.setFrame(value.toBool() ? MAV_FRAME_GLOBAL_RELATIVE_ALT : MAV_FRAME_GLOBAL); _missionItem.setFrame(value.toBool() ? MAV_FRAME_GLOBAL_RELATIVE_ALT : MAV_FRAME_GLOBAL);
emit coordinateHasRelativeAltitudeChanged(value.toBool());
_syncingAltitudeRelativeToHomeAndFrame = false; _syncingAltitudeRelativeToHomeAndFrame = false;
} }
} }
...@@ -613,6 +614,7 @@ void SimpleMissionItem::_syncFrameToAltitudeRelativeToHome(void) ...@@ -613,6 +614,7 @@ void SimpleMissionItem::_syncFrameToAltitudeRelativeToHome(void)
if (!_syncingAltitudeRelativeToHomeAndFrame) { if (!_syncingAltitudeRelativeToHomeAndFrame) {
_syncingAltitudeRelativeToHomeAndFrame = true; _syncingAltitudeRelativeToHomeAndFrame = true;
_altitudeRelativeToHomeFact.setRawValue(relativeAltitude()); _altitudeRelativeToHomeFact.setRawValue(relativeAltitude());
emit coordinateHasRelativeAltitudeChanged(_altitudeRelativeToHomeFact.rawValue().toBool());
_syncingAltitudeRelativeToHomeAndFrame = false; _syncingAltitudeRelativeToHomeAndFrame = false;
} }
} }
......
...@@ -86,6 +86,7 @@ void SimpleMissionItemTest::init(void) ...@@ -86,6 +86,7 @@ void SimpleMissionItemTest::init(void)
rgSimpleItemSignals[rawEditChangedIndex] = SIGNAL(rawEditChanged(bool)); rgSimpleItemSignals[rawEditChangedIndex] = SIGNAL(rawEditChanged(bool));
rgSimpleItemSignals[cameraSectionChangedIndex] = SIGNAL(rawEditChanged(bool)); rgSimpleItemSignals[cameraSectionChangedIndex] = SIGNAL(rawEditChanged(bool));
rgSimpleItemSignals[speedSectionChangedIndex] = SIGNAL(rawEditChanged(bool)); rgSimpleItemSignals[speedSectionChangedIndex] = SIGNAL(rawEditChanged(bool));
rgSimpleItemSignals[coordinateHasRelativeAltitudeChangedIndex] = SIGNAL(coordinateHasRelativeAltitudeChanged(bool));
MissionItem missionItem(1, // sequence number MissionItem missionItem(1, // sequence number
MAV_CMD_NAV_WAYPOINT, MAV_CMD_NAV_WAYPOINT,
...@@ -231,13 +232,14 @@ void SimpleMissionItemTest::_testSignals(void) ...@@ -231,13 +232,14 @@ void SimpleMissionItemTest::_testSignals(void)
// frameChanged // frameChanged
// dirtyChanged // dirtyChanged
// friendlyEditAllowedChanged - this signal is not very smart on when it gets sent // friendlyEditAllowedChanged - this signal is not very smart on when it gets sent
// coordinateHasRelativeAltitudeChanged
missionItem.setFrame(MAV_FRAME_GLOBAL_RELATIVE_ALT); missionItem.setFrame(MAV_FRAME_GLOBAL_RELATIVE_ALT);
QVERIFY(_spyVisualItem->checkNoSignals()); QVERIFY(_spyVisualItem->checkNoSignals());
QVERIFY(_spySimpleItem->checkNoSignals()); QVERIFY(_spySimpleItem->checkNoSignals());
missionItem.setFrame(MAV_FRAME_GLOBAL); missionItem.setFrame(MAV_FRAME_GLOBAL);
QVERIFY(_spySimpleItem->checkOnlySignalByMask(frameChangedMask | dirtyChangedMask | friendlyEditAllowedChangedMask)); QVERIFY(_spySimpleItem->checkOnlySignalByMask(frameChangedMask | dirtyChangedMask | friendlyEditAllowedChangedMask | coordinateHasRelativeAltitudeChangedMask));
_spySimpleItem->clearAllSignals(); _spySimpleItem->clearAllSignals();
_spyVisualItem->clearAllSignals(); _spyVisualItem->clearAllSignals();
......
...@@ -41,6 +41,7 @@ private: ...@@ -41,6 +41,7 @@ private:
rawEditChangedIndex, rawEditChangedIndex,
cameraSectionChangedIndex, cameraSectionChangedIndex,
speedSectionChangedIndex, speedSectionChangedIndex,
coordinateHasRelativeAltitudeChangedIndex,
maxSignalIndex, maxSignalIndex,
}; };
...@@ -51,7 +52,8 @@ private: ...@@ -51,7 +52,8 @@ private:
headingDegreesChangedMask = 1 << headingDegreesChangedIndex, headingDegreesChangedMask = 1 << headingDegreesChangedIndex,
rawEditChangedMask = 1 << rawEditChangedIndex, rawEditChangedMask = 1 << rawEditChangedIndex,
cameraSectionChangedMask = 1 << cameraSectionChangedIndex, cameraSectionChangedMask = 1 << cameraSectionChangedIndex,
speedSectionChangedMask = 1 << speedSectionChangedIndex speedSectionChangedMask = 1 << speedSectionChangedIndex,
coordinateHasRelativeAltitudeChangedMask = 1 << coordinateHasRelativeAltitudeChangedIndex,
}; };
static const size_t cSimpleItemSignals = maxSignalIndex; static const size_t cSimpleItemSignals = maxSignalIndex;
......
...@@ -102,7 +102,7 @@ public: ...@@ -102,7 +102,7 @@ public:
virtual bool isSimpleItem (void) const = 0; virtual bool isSimpleItem (void) const = 0;
virtual bool isStandaloneCoordinate (void) const = 0; virtual bool isStandaloneCoordinate (void) const = 0;
virtual bool specifiesCoordinate (void) const = 0; virtual bool specifiesCoordinate (void) const = 0;
virtual bool specifiesAltitudeOnly (void) const = 0;; virtual bool specifiesAltitudeOnly (void) const = 0;
virtual QString commandDescription (void) const = 0; virtual QString commandDescription (void) const = 0;
virtual QString commandName (void) const = 0; virtual QString commandName (void) const = 0;
virtual QString abbreviation (void) const = 0; virtual QString abbreviation (void) const = 0;
......
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