diff options
author | Thomas McGuire <thomas.mcguire.qnx@kdab.com> | 2012-07-19 13:22:16 +0200 |
---|---|---|
committer | Qt by Nokia <qt-info@nokia.com> | 2012-07-23 00:19:24 +0200 |
commit | 1dfa6732e026c69472c821d83346cc66bcf3e476 (patch) | |
tree | 2a50d0c9643bedae073a4d8477cdc4af7260e49f /src/plugins/sensors/blackberry/bbcompass.cpp | |
parent | 505dbc8230414a31cd3def9f2d8b144b0e9444f4 (diff) |
Blackberry: Use the rotation matrix as the compass source
This fixes the direction flipping over when holding the device
upside-down.
Change-Id: I57bac63208d475d4091b47593b9768613eea30b0
Reviewed-by: Sean Harmer <sean.harmer@kdab.com>
Reviewed-by: Adam Parco <aparco@rim.com>
Reviewed-by: Lorn Potter <lorn.potter@nokia.com>
Diffstat (limited to 'src/plugins/sensors/blackberry/bbcompass.cpp')
-rw-r--r-- | src/plugins/sensors/blackberry/bbcompass.cpp | 16 |
1 files changed, 13 insertions, 3 deletions
diff --git a/src/plugins/sensors/blackberry/bbcompass.cpp b/src/plugins/sensors/blackberry/bbcompass.cpp index a77c99ad..9ada2cd5 100644 --- a/src/plugins/sensors/blackberry/bbcompass.cpp +++ b/src/plugins/sensors/blackberry/bbcompass.cpp @@ -39,16 +39,26 @@ ** ****************************************************************************/ #include "bbcompass.h" +#include "bbutil.h" + +using namespace BbUtil; BbCompass::BbCompass(QSensor *sensor) - : BbSensorBackend<QCompassReading>(devicePath(), SENSOR_TYPE_AZIMUTH_PITCH_ROLL, sensor) + : BbSensorBackend<QCompassReading>(devicePath(), SENSOR_TYPE_ROTATION_MATRIX, sensor) { setDescription(QLatin1String("Azimuth in degrees from magnetic north")); } bool BbCompass::updateReadingFromEvent(const sensor_event_t &event, QCompassReading *reading) { - reading->setAzimuth(event.apr.azimuth); + float xRad, yRad, zRad; + matrixToEulerZXY(event.rotation_matrix, xRad, yRad, zRad); + float azimuth = radiansToDegrees(zRad); + if (azimuth < 0) + azimuth = -azimuth; + else + azimuth = 360.0f - azimuth; + reading->setAzimuth(azimuth); switch (event.accuracy) { case SENSOR_ACCURACY_UNRELIABLE: @@ -75,5 +85,5 @@ bool BbCompass::updateReadingFromEvent(const sensor_event_t &event, QCompassRead QString BbCompass::devicePath() { - return QLatin1String("/dev/sensor/apr"); + return QLatin1String("/dev/sensor/rotMatrix"); } |