diff --git a/src/uas/UAS.cc b/src/uas/UAS.cc index 3076f3292dce9b4a3be6129fe3f3f2344361b1c8..9b1556426ae96e977b789db38f517ab0ee581a09 100644 --- a/src/uas/UAS.cc +++ b/src/uas/UAS.cc @@ -3325,45 +3325,55 @@ QString UAS::getAudioModeTextFor(int id) return mode; } +/** +* The mode returned can be auto, stabilized, test, manual, preflight or unknown. +* @return the short text of the mode for the id given. +*/ /** * The mode returned can be auto, stabilized, test, manual, preflight or unknown. * @return the short text of the mode for the id given. */ QString UAS::getShortModeTextFor(int id) { - QString mode; + QString mode = ""; uint8_t modeid = id; - qDebug() << "MODE:" << modeid; // BASE MODE DECODING - if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_AUTO) - { - mode += "|AUTO"; - } - else if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_GUIDED) - { - mode += "|VECTOR"; - } - if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_STABILIZE) - { - mode += "|STABILIZED"; - } - else if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_TEST) - { - mode += "|TEST"; - } - else if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_MANUAL) - { - mode += "|MANUAL"; - } - else if (modeid == 0) + + if (modeid == 0) { mode = "|PREFLIGHT"; } - else + else { + if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_AUTO){ + mode += "|AUTO"; + } + + if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_MANUAL){ + mode += "|MANUAL"; + } + + if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_GUIDED){ + mode += "|VECTOR"; + } + + if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_STABILIZE){ + mode += "|STABILIZED"; + } + + + if (modeid & (uint8_t)MAV_MODE_FLAG_DECODE_POSITION_TEST){ + mode += "|TEST"; + } + + + } + + if (mode.length() == 0) { mode = "|UNKNOWN"; + qDebug() << __FILE__ << __LINE__ << " Unknown modeid: " << modeid; } // ARMED STATE DECODING @@ -3382,6 +3392,8 @@ QString UAS::getShortModeTextFor(int id) mode.prepend("HIL:"); } + qDebug() << "MODE: " << modeid << " " << mode; + return mode; }