summaryrefslogtreecommitdiffstats
path: root/src/plugins/sensors/blackberry/bbcompass.cpp
diff options
context:
space:
mode:
authorThomas McGuire <thomas.mcguire.qnx@kdab.com>2012-07-19 13:22:16 +0200
committerQt by Nokia <qt-info@nokia.com>2012-07-23 00:19:24 +0200
commit1dfa6732e026c69472c821d83346cc66bcf3e476 (patch)
tree2a50d0c9643bedae073a4d8477cdc4af7260e49f /src/plugins/sensors/blackberry/bbcompass.cpp
parent505dbc8230414a31cd3def9f2d8b144b0e9444f4 (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.cpp16
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");
}