Unverified Commit 8d42d087 authored by Don Gagne's avatar Don Gagne Committed by GitHub

Merge pull request #5931 from DonLakeFlyer/ROIFixes

Plan: ROI fixes
parents 73d856d5 b9e20a58
...@@ -51,9 +51,9 @@ ...@@ -51,9 +51,9 @@
} }
}, },
{ {
"id": 201, "id": 201,
"comment": "MAV_CMD_DO_SET_ROI", "comment": "MAV_CMD_DO_SET_ROI",
"paramRemove": "2,3" "paramRemove": "1,2,3"
}, },
{ {
"id": 205, "id": 205,
......
...@@ -237,33 +237,6 @@ ...@@ -237,33 +237,6 @@
}, },
{ "id": 32, "rawName": "MAV_CMD_DO_FOLLOW", "friendlyName": "Follow Me" }, { "id": 32, "rawName": "MAV_CMD_DO_FOLLOW", "friendlyName": "Follow Me" },
{ "id": 33, "rawName": "MAV_CMD_DO_FOLLOW_REPOSITION", "friendlyName": "Vehicle reposition" }, { "id": 33, "rawName": "MAV_CMD_DO_FOLLOW_REPOSITION", "friendlyName": "Vehicle reposition" },
{
"id": 80,
"rawName": "MAV_CMD_NAV_ROI",
"friendlyName": "Region of interest (nav)",
"description": "Sets the region of interest for cameras.",
"specifiesCoordinate": true,
"standaloneCoordinate": true,
"friendlyEdit": true,
"category": "Camera",
"param1": {
"label": "Mode",
"enumStrings": "None,Next waypoint,Mission item,Location,ROI item",
"enumValues": "0,1,2,3,4",
"default": 3,
"decimalPlaces": 0
},
"param2": {
"label": "Mission Index",
"default": 0,
"decimalPlaces": 0
},
"param3": {
"label": "ROI Index",
"default": 0,
"decimalPlaces": 0
}
},
{ {
"id": 81, "id": 81,
"rawName": "MAV_CMD_NAV_PATHPLANNING", "rawName": "MAV_CMD_NAV_PATHPLANNING",
......
...@@ -70,7 +70,9 @@ void MissionCommandTreeTest::_checkBaseValues(const MissionCommandUIInfo* uiInfo ...@@ -70,7 +70,9 @@ void MissionCommandTreeTest::_checkBaseValues(const MissionCommandUIInfo* uiInfo
QCOMPARE(uiInfo->isStandaloneCoordinate(), true); QCOMPARE(uiInfo->isStandaloneCoordinate(), true);
QCOMPARE(uiInfo->specifiesCoordinate(), true); QCOMPARE(uiInfo->specifiesCoordinate(), true);
for (int i=1; i<=7; i++) { for (int i=1; i<=7; i++) {
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i); bool showUI;
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i, showUI);
QVERIFY(showUI);
QVERIFY(paramInfo); QVERIFY(paramInfo);
QCOMPARE(paramInfo->decimalPlaces(), 1); QCOMPARE(paramInfo->decimalPlaces(), 1);
QCOMPARE(paramInfo->defaultValue(), 1.0); QCOMPARE(paramInfo->defaultValue(), 1.0);
...@@ -91,7 +93,9 @@ void MissionCommandTreeTest::_checkOverrideParamValues(const MissionCommandUIInf ...@@ -91,7 +93,9 @@ void MissionCommandTreeTest::_checkOverrideParamValues(const MissionCommandUIInf
{ {
QString overrideString = QString("override fw %1 %2").arg(command).arg(paramIndex); QString overrideString = QString("override fw %1 %2").arg(command).arg(paramIndex);
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(paramIndex); bool showUI;
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(paramIndex, showUI);
QVERIFY(showUI);
QVERIFY(paramInfo); QVERIFY(paramInfo);
QCOMPARE(paramInfo->decimalPlaces(), 1); QCOMPARE(paramInfo->decimalPlaces(), 1);
QCOMPARE(paramInfo->defaultValue(), 1.0); QCOMPARE(paramInfo->defaultValue(), 1.0);
...@@ -109,6 +113,7 @@ void MissionCommandTreeTest::_checkOverrideParamValues(const MissionCommandUIInf ...@@ -109,6 +113,7 @@ void MissionCommandTreeTest::_checkOverrideParamValues(const MissionCommandUIInf
// Verifies that values match settings for an override // Verifies that values match settings for an override
void MissionCommandTreeTest::_checkOverrideValues(const MissionCommandUIInfo* uiInfo, int command) void MissionCommandTreeTest::_checkOverrideValues(const MissionCommandUIInfo* uiInfo, int command)
{ {
bool showUI;
QString overrideString = QString("override fw %1").arg(command); QString overrideString = QString("override fw %1").arg(command);
QVERIFY(uiInfo != NULL); QVERIFY(uiInfo != NULL);
...@@ -121,9 +126,12 @@ void MissionCommandTreeTest::_checkOverrideValues(const MissionCommandUIInfo* ui ...@@ -121,9 +126,12 @@ void MissionCommandTreeTest::_checkOverrideValues(const MissionCommandUIInfo* ui
QCOMPARE(uiInfo->friendlyName(), _friendlyName(command)); QCOMPARE(uiInfo->friendlyName(), _friendlyName(command));
QCOMPARE(uiInfo->isStandaloneCoordinate(), false); QCOMPARE(uiInfo->isStandaloneCoordinate(), false);
QCOMPARE(uiInfo->specifiesCoordinate(), false); QCOMPARE(uiInfo->specifiesCoordinate(), false);
QVERIFY(uiInfo->getParamInfo(2) == NULL); QVERIFY(uiInfo->getParamInfo(2, showUI));
QVERIFY(uiInfo->getParamInfo(4) == NULL); QCOMPARE(showUI, false);
QVERIFY(uiInfo->getParamInfo(6) == NULL); QVERIFY(uiInfo->getParamInfo(4, showUI));
QCOMPARE(showUI, false);
QVERIFY(uiInfo->getParamInfo(6, showUI));
QCOMPARE(showUI, false);
_checkOverrideParamValues(uiInfo, command, 1); _checkOverrideParamValues(uiInfo, command, 1);
_checkOverrideParamValues(uiInfo, command, 3); _checkOverrideParamValues(uiInfo, command, 3);
_checkOverrideParamValues(uiInfo, command, 5); _checkOverrideParamValues(uiInfo, command, 5);
...@@ -131,6 +139,8 @@ void MissionCommandTreeTest::_checkOverrideValues(const MissionCommandUIInfo* ui ...@@ -131,6 +139,8 @@ void MissionCommandTreeTest::_checkOverrideValues(const MissionCommandUIInfo* ui
void MissionCommandTreeTest::testJsonLoad(void) void MissionCommandTreeTest::testJsonLoad(void)
{ {
bool showUI;
// Test loading from the bad command list // Test loading from the bad command list
MissionCommandList* commandList = _commandTree->_staticCommandTree[MAV_AUTOPILOT_GENERIC][MAV_TYPE_GENERIC]; MissionCommandList* commandList = _commandTree->_staticCommandTree[MAV_AUTOPILOT_GENERIC][MAV_TYPE_GENERIC];
QVERIFY(commandList != NULL); QVERIFY(commandList != NULL);
...@@ -148,14 +158,16 @@ void MissionCommandTreeTest::testJsonLoad(void) ...@@ -148,14 +158,16 @@ void MissionCommandTreeTest::testJsonLoad(void)
QCOMPARE(uiInfo->isStandaloneCoordinate(), false); QCOMPARE(uiInfo->isStandaloneCoordinate(), false);
QCOMPARE(uiInfo->specifiesCoordinate(), false); QCOMPARE(uiInfo->specifiesCoordinate(), false);
for (int i=1; i<=7; i++) { for (int i=1; i<=7; i++) {
QVERIFY(uiInfo->getParamInfo(i) == NULL); QVERIFY(uiInfo->getParamInfo(i, showUI) == NULL);
QCOMPARE(showUI, false);
} }
// Command 2 should all values defaulted for param 1 // Command 2 should all values defaulted for param 1
uiInfo = commandList->getUIInfo((MAV_CMD)2); uiInfo = commandList->getUIInfo((MAV_CMD)2);
QVERIFY(uiInfo != NULL); QVERIFY(uiInfo != NULL);
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(1); const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(1, showUI);
QVERIFY(paramInfo); QVERIFY(paramInfo);
QCOMPARE(showUI, true);
QCOMPARE(paramInfo->decimalPlaces(), -1); QCOMPARE(paramInfo->decimalPlaces(), -1);
QCOMPARE(paramInfo->defaultValue(), 0.0); QCOMPARE(paramInfo->defaultValue(), 0.0);
QCOMPARE(paramInfo->enumStrings().count(), 0); QCOMPARE(paramInfo->enumStrings().count(), 0);
...@@ -164,7 +176,8 @@ void MissionCommandTreeTest::testJsonLoad(void) ...@@ -164,7 +176,8 @@ void MissionCommandTreeTest::testJsonLoad(void)
QCOMPARE(paramInfo->param(), 1); QCOMPARE(paramInfo->param(), 1);
QVERIFY(paramInfo->units().isEmpty()); QVERIFY(paramInfo->units().isEmpty());
for (int i=2; i<=7; i++) { for (int i=2; i<=7; i++) {
QVERIFY(uiInfo->getParamInfo(i) == NULL); QVERIFY(uiInfo->getParamInfo(i, showUI) == NULL);
QCOMPARE(showUI, false);
} }
// Command 3 should have all values set // Command 3 should have all values set
......
...@@ -407,11 +407,15 @@ bool MissionCommandUIInfo::loadJsonInfo(const QJsonObject& jsonObject, bool requ ...@@ -407,11 +407,15 @@ bool MissionCommandUIInfo::loadJsonInfo(const QJsonObject& jsonObject, bool requ
return true; return true;
} }
const MissionCmdParamInfo* MissionCommandUIInfo::getParamInfo(int index) const const MissionCmdParamInfo* MissionCommandUIInfo::getParamInfo(int index, bool& showUI) const
{ {
if (!_paramRemoveList.contains(index) && _paramInfoMap.contains(index)) { const MissionCmdParamInfo* paramInfo = NULL;
return _paramInfoMap[index];
} else { if (_paramInfoMap.contains(index)) {
return NULL; paramInfo = _paramInfoMap[index];
} }
showUI = (paramInfo != NULL) && !_paramRemoveList.contains(index);
return paramInfo;
} }
...@@ -138,8 +138,11 @@ public: ...@@ -138,8 +138,11 @@ public:
/// @return true: success, false: failure, errorString set /// @return true: success, false: failure, errorString set
bool loadJsonInfo(const QJsonObject& jsonObject, bool requireFullObject, QString& errorString); bool loadJsonInfo(const QJsonObject& jsonObject, bool requireFullObject, QString& errorString);
/// Return param info for index, NULL for param should not be shown /// Retruns parameter information for specified parameter
const MissionCmdParamInfo* getParamInfo(int index) const; /// @param index paremeter index to retrieve, 1-7
/// @param showUI true: show parameter in editor, false: hide parameter in editor
/// @return Param info for index, NULL for none available
const MissionCmdParamInfo* getParamInfo(int index, bool& showUI) const;
private: private:
QString _loadErrorString(const QString& errorString) const; QString _loadErrorString(const QString& errorString) const;
......
...@@ -171,10 +171,10 @@ bool MissionItem::load(QTextStream &loadStream) ...@@ -171,10 +171,10 @@ bool MissionItem::load(QTextStream &loadStream)
{ {
const QStringList &wpParams = loadStream.readLine().split("\t"); const QStringList &wpParams = loadStream.readLine().split("\t");
if (wpParams.size() == 12) { if (wpParams.size() == 12) {
setCommand((MAV_CMD)wpParams[3].toInt()); // Has to be first since it triggers defaults to be set, which are then override by below set calls
setSequenceNumber(wpParams[0].toInt()); setSequenceNumber(wpParams[0].toInt());
setIsCurrentItem(wpParams[1].toInt() == 1 ? true : false); setIsCurrentItem(wpParams[1].toInt() == 1 ? true : false);
setFrame((MAV_FRAME)wpParams[2].toInt()); setFrame((MAV_FRAME)wpParams[2].toInt());
setCommand((MAV_CMD)wpParams[3].toInt());
setParam1(wpParams[4].toDouble()); setParam1(wpParams[4].toDouble());
setParam2(wpParams[5].toDouble()); setParam2(wpParams[5].toDouble());
setParam3(wpParams[6].toDouble()); setParam3(wpParams[6].toDouble());
...@@ -300,8 +300,8 @@ bool MissionItem::load(const QJsonObject& json, int sequenceNumber, QString& err ...@@ -300,8 +300,8 @@ bool MissionItem::load(const QJsonObject& json, int sequenceNumber, QString& err
} }
// Make sure to set these first since they can signal other changes // Make sure to set these first since they can signal other changes
setFrame((MAV_FRAME)convertedJson[_jsonFrameKey].toInt());
setCommand((MAV_CMD)convertedJson[_jsonCommandKey].toInt()); setCommand((MAV_CMD)convertedJson[_jsonCommandKey].toInt());
setFrame((MAV_FRAME)convertedJson[_jsonFrameKey].toInt());
_doJumpId = -1; _doJumpId = -1;
if (convertedJson.contains(_jsonDoJumpIdKey)) { if (convertedJson.contains(_jsonDoJumpIdKey)) {
......
...@@ -414,9 +414,10 @@ void SimpleMissionItem::_rebuildTextFieldFacts(void) ...@@ -414,9 +414,10 @@ void SimpleMissionItem::_rebuildTextFieldFacts(void)
const MissionCommandUIInfo* uiInfo = _commandTree->getUIInfo(_vehicle, command); const MissionCommandUIInfo* uiInfo = _commandTree->getUIInfo(_vehicle, command);
for (int i=1; i<=7; i++) { for (int i=1; i<=7; i++) {
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i); bool showUI;
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i, showUI);
if (paramInfo && paramInfo->enumStrings().count() == 0 && !paramInfo->nanUnchanged()) { if (showUI && paramInfo && paramInfo->enumStrings().count() == 0 && !paramInfo->nanUnchanged()) {
Fact* paramFact = rgParamFacts[i-1]; Fact* paramFact = rgParamFacts[i-1];
FactMetaData* paramMetaData = rgParamMetaData[i-1]; FactMetaData* paramMetaData = rgParamMetaData[i-1];
...@@ -458,9 +459,10 @@ void SimpleMissionItem::_rebuildNaNFacts(void) ...@@ -458,9 +459,10 @@ void SimpleMissionItem::_rebuildNaNFacts(void)
const MissionCommandUIInfo* uiInfo = _commandTree->getUIInfo(_vehicle, command); const MissionCommandUIInfo* uiInfo = _commandTree->getUIInfo(_vehicle, command);
for (int i=1; i<=7; i++) { for (int i=1; i<=7; i++) {
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i); bool showUI;
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i, showUI);
if (paramInfo && paramInfo->nanUnchanged()) { if (showUI && paramInfo && paramInfo->nanUnchanged()) {
// Show hide Heading field on waypoint based on vehicle yaw to next waypoint setting. This needs to come from the actual vehicle if it exists // Show hide Heading field on waypoint based on vehicle yaw to next waypoint setting. This needs to come from the actual vehicle if it exists
// and not _vehicle which is always offline. // and not _vehicle which is always offline.
Vehicle* firmwareVehicle = qgcApp()->toolbox()->multiVehicleManager()->activeVehicle(); Vehicle* firmwareVehicle = qgcApp()->toolbox()->multiVehicleManager()->activeVehicle();
...@@ -517,9 +519,10 @@ void SimpleMissionItem::_rebuildComboBoxFacts(void) ...@@ -517,9 +519,10 @@ void SimpleMissionItem::_rebuildComboBoxFacts(void)
} }
for (int i=1; i<=7; i++) { for (int i=1; i<=7; i++) {
const MissionCmdParamInfo* paramInfo = _commandTree->getUIInfo(_vehicle, command)->getParamInfo(i); bool showUI;
const MissionCmdParamInfo* paramInfo = _commandTree->getUIInfo(_vehicle, command)->getParamInfo(i, showUI);
if (paramInfo && paramInfo->enumStrings().count() != 0) { if (showUI && paramInfo && paramInfo->enumStrings().count() != 0) {
Fact* paramFact = rgParamFacts[i-1]; Fact* paramFact = rgParamFacts[i-1];
FactMetaData* paramMetaData = rgParamMetaData[i-1]; FactMetaData* paramMetaData = rgParamMetaData[i-1];
...@@ -635,7 +638,8 @@ void SimpleMissionItem::setDefaultsForCommand(void) ...@@ -635,7 +638,8 @@ void SimpleMissionItem::setDefaultsForCommand(void)
const MissionCommandUIInfo* uiInfo = _commandTree->getUIInfo(_vehicle, command); const MissionCommandUIInfo* uiInfo = _commandTree->getUIInfo(_vehicle, command);
if (uiInfo) { if (uiInfo) {
for (int i=1; i<=7; i++) { for (int i=1; i<=7; i++) {
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i); bool showUI;
const MissionCmdParamInfo* paramInfo = uiInfo->getParamInfo(i, showUI);
if (paramInfo) { if (paramInfo) {
Fact* rgParamFacts[7] = { &_missionItem._param1Fact, &_missionItem._param2Fact, &_missionItem._param3Fact, &_missionItem._param4Fact, &_missionItem._param5Fact, &_missionItem._param6Fact, &_missionItem._param7Fact }; Fact* rgParamFacts[7] = { &_missionItem._param1Fact, &_missionItem._param2Fact, &_missionItem._param3Fact, &_missionItem._param4Fact, &_missionItem._param5Fact, &_missionItem._param6Fact, &_missionItem._param7Fact };
rgParamFacts[paramInfo->param()-1]->setRawValue(paramInfo->defaultValue()); rgParamFacts[paramInfo->param()-1]->setRawValue(paramInfo->defaultValue());
......
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