Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Q
qgroundcontrol
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Valentin Platzgummer
qgroundcontrol
Commits
58afdad9
Commit
58afdad9
authored
May 07, 2018
by
DonLakeFlyer
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Expose sensor status to Qml
parent
535ff2ab
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
52 additions
and
3 deletions
+52
-3
Vehicle.cc
src/Vehicle/Vehicle.cc
+12
-3
Vehicle.h
src/Vehicle/Vehicle.h
+40
-0
No files found.
src/Vehicle/Vehicle.cc
View file @
58afdad9
...
...
@@ -1278,9 +1278,18 @@ void Vehicle::_handleSysStatus(mavlink_message_t& message)
_lastAnnouncedLowBatteryPercent
=
sysStatus
.
battery_remaining
;
}
if
(
_onboardControlSensorsPresent
!=
sysStatus
.
onboard_control_sensors_present
)
{
_onboardControlSensorsPresent
=
sysStatus
.
onboard_control_sensors_present
;
emit
sensorsPresentBitsChanged
(
_onboardControlSensorsPresent
);
}
if
(
_onboardControlSensorsEnabled
!=
sysStatus
.
onboard_control_sensors_enabled
)
{
_onboardControlSensorsEnabled
=
sysStatus
.
onboard_control_sensors_enabled
;
emit
sensorsEnabledBitsChanged
(
_onboardControlSensorsEnabled
);
}
if
(
_onboardControlSensorsHealth
!=
sysStatus
.
onboard_control_sensors_health
)
{
_onboardControlSensorsHealth
=
sysStatus
.
onboard_control_sensors_health
;
emit
sensorsHealthBitsChanged
(
_onboardControlSensorsHealth
);
}
// ArduPilot firmare has a strange case when ARMING_REQUIRE=0. This means the vehicle is always armed but the motors are not
// really powered up until the safety button is pressed. Because of this we can't depend on the heartbeat to tell us the true
...
...
src/Vehicle/Vehicle.h
View file @
58afdad9
...
...
@@ -375,6 +375,37 @@ public:
~
Vehicle
();
/// Sensor bits from sensors*Bits properties
enum
MavlinkSysStatus
{
SysStatusSensor3dGyro
=
MAV_SYS_STATUS_SENSOR_3D_GYRO
,
SysStatusSensor3dAccel
=
MAV_SYS_STATUS_SENSOR_3D_ACCEL
,
SysStatusSensor3dMag
=
MAV_SYS_STATUS_SENSOR_3D_MAG
,
SysStatusSensorAsolutePressure
=
MAV_SYS_STATUS_SENSOR_ABSOLUTE_PRESSURE
,
SysStatusSensorDifferentialPressure
=
MAV_SYS_STATUS_SENSOR_DIFFERENTIAL_PRESSURE
,
SysStatusSensorGPS
=
MAV_SYS_STATUS_SENSOR_GPS
,
SysStatusSensorOpticalFlow
=
MAV_SYS_STATUS_SENSOR_OPTICAL_FLOW
,
SysStatusSensorVisionPosition
=
MAV_SYS_STATUS_SENSOR_VISION_POSITION
,
SysStatusSensorLaserPosition
=
MAV_SYS_STATUS_SENSOR_LASER_POSITION
,
SysStatusSensorExternalGroundTruth
=
MAV_SYS_STATUS_SENSOR_EXTERNAL_GROUND_TRUTH
,
SysStatusSensorAngularRateControl
=
MAV_SYS_STATUS_SENSOR_ANGULAR_RATE_CONTROL
,
SysStatusSensorAttitudeStabilization
=
MAV_SYS_STATUS_SENSOR_ATTITUDE_STABILIZATION
,
SysStatusSensorYawPosition
=
MAV_SYS_STATUS_SENSOR_YAW_POSITION
,
SysStatusSensorZAltitudeControl
=
MAV_SYS_STATUS_SENSOR_Z_ALTITUDE_CONTROL
,
SysStatusSensorXYPositionControl
=
MAV_SYS_STATUS_SENSOR_XY_POSITION_CONTROL
,
SysStatusSensorMotorOutputs
=
MAV_SYS_STATUS_SENSOR_MOTOR_OUTPUTS
,
SysStatusSensorRCReceiver
=
MAV_SYS_STATUS_SENSOR_RC_RECEIVER
,
SysStatusSensor3dGyro2
=
MAV_SYS_STATUS_SENSOR_3D_GYRO2
,
SysStatusSensor3dAccel2
=
MAV_SYS_STATUS_SENSOR_3D_ACCEL2
,
SysStatusSensor3dMag2
=
MAV_SYS_STATUS_SENSOR_3D_MAG2
,
SysStatusSensorGeoFence
=
MAV_SYS_STATUS_GEOFENCE
,
SysStatusSensorAHRS
=
MAV_SYS_STATUS_AHRS
,
SysStatusSensorTerrain
=
MAV_SYS_STATUS_TERRAIN
,
SysStatusSensorReverseMotor
=
MAV_SYS_STATUS_REVERSE_MOTOR
,
SysStatusSensorLogging
=
MAV_SYS_STATUS_LOGGING
,
SysStatusSensorBattery
=
MAV_SYS_STATUS_SENSOR_BATTERY
,
};
Q_ENUM
(
MavlinkSysStatus
)
Q_PROPERTY
(
int
id
READ
id
CONSTANT
)
Q_PROPERTY
(
AutoPilotPlugin
*
autopilot
MEMBER
_autopilotPlugin
CONSTANT
)
Q_PROPERTY
(
QGeoCoordinate
coordinate
READ
coordinate
NOTIFY
coordinateChanged
)
...
...
@@ -432,6 +463,9 @@ public:
Q_PROPERTY
(
QString
brandImageIndoor
READ
brandImageIndoor
NOTIFY
firmwareTypeChanged
)
Q_PROPERTY
(
QString
brandImageOutdoor
READ
brandImageOutdoor
NOTIFY
firmwareTypeChanged
)
Q_PROPERTY
(
QStringList
unhealthySensors
READ
unhealthySensors
NOTIFY
unhealthySensorsChanged
)
Q_PROPERTY
(
int
sensorsPresentBits
READ
sensorsPresentBits
NOTIFY
sensorsPresentBitsChanged
)
Q_PROPERTY
(
int
sensorsEnabledBits
READ
sensorsEnabledBits
NOTIFY
sensorsEnabledBitsChanged
)
Q_PROPERTY
(
int
sensorsHealthBits
READ
sensorsHealthBits
NOTIFY
sensorsHealthBitsChanged
)
Q_PROPERTY
(
QString
missionFlightMode
READ
missionFlightMode
CONSTANT
)
Q_PROPERTY
(
QString
pauseFlightMode
READ
pauseFlightMode
CONSTANT
)
Q_PROPERTY
(
QString
rtlFlightMode
READ
rtlFlightMode
CONSTANT
)
...
...
@@ -732,6 +766,9 @@ public:
QString
brandImageIndoor
()
const
;
QString
brandImageOutdoor
()
const
;
QStringList
unhealthySensors
()
const
;
int
sensorsPresentBits
()
const
{
return
_onboardControlSensorsPresent
;
}
int
sensorsEnabledBits
()
const
{
return
_onboardControlSensorsEnabled
;
}
int
sensorsHealthBits
()
const
{
return
_onboardControlSensorsHealth
;
}
QString
missionFlightMode
()
const
;
QString
pauseFlightMode
()
const
;
QString
rtlFlightMode
()
const
;
...
...
@@ -931,6 +968,9 @@ signals:
void
telemetryRNoiseChanged
(
int
value
);
void
autoDisarmChanged
(
void
);
void
flightModesChanged
(
void
);
void
sensorsPresentBitsChanged
(
int
sensorsPresentBits
);
void
sensorsEnabledBitsChanged
(
int
sensorsEnabledBits
);
void
sensorsHealthBitsChanged
(
int
sensorsHealthBits
);
void
firmwareVersionChanged
(
void
);
void
firmwareCustomVersionChanged
(
void
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment