examples/sensors/panorama/magnetometercontroller.cpp
changeset 0 876b1a06bc25
equal deleted inserted replaced
-1:000000000000 0:876b1a06bc25
       
     1 
       
     2 
       
     3 #include "inputcontroller.h"
       
     4 #include "magnetometercontroller.h"
       
     5 #include "view.h"
       
     6 #include <qmagnetometer.h>
       
     7 
       
     8 MagnetometerController::MagnetometerController(): m_width(View::m_imageWidth){
       
     9     m_magnetometer.setProperty("returnGeoValues", true);
       
    10     m_magnetometer.connectToBackend();
       
    11     m_magnetometer.start();
       
    12     connect(&m_magnetometer, SIGNAL(readingChanged()), this, SLOT(update()));
       
    13 }
       
    14 
       
    15 
       
    16 MagnetometerController::~MagnetometerController(){
       
    17     m_magnetometer.stop();
       
    18     disconnect(&m_magnetometer);
       
    19 }
       
    20 
       
    21 
       
    22 void MagnetometerController::update()
       
    23 {
       
    24     qreal azimuth = -m_magnetometer.reading()->z();
       
    25     azimuth = azimuth<0?360+azimuth:azimuth;
       
    26     m_x = (int)(-azimuth * m_width/360);
       
    27 
       
    28 
       
    29     //TODO: consider provide y values based on x and y
       
    30 }
       
    31 
       
    32 
       
    33 
       
    34