diff options
Diffstat (limited to 'ftnoir_tracker_joystick/ftnoir_tracker_joystick.cpp')
| -rw-r--r-- | ftnoir_tracker_joystick/ftnoir_tracker_joystick.cpp | 21 | 
1 files changed, 6 insertions, 15 deletions
| diff --git a/ftnoir_tracker_joystick/ftnoir_tracker_joystick.cpp b/ftnoir_tracker_joystick/ftnoir_tracker_joystick.cpp index d3f5806b..54573af6 100644 --- a/ftnoir_tracker_joystick/ftnoir_tracker_joystick.cpp +++ b/ftnoir_tracker_joystick/ftnoir_tracker_joystick.cpp @@ -3,6 +3,7 @@  #undef NDEBUG  #include <QMutexLocker>  #include <stdlib.h> +#include <utility>  FTNoIR_Tracker::FTNoIR_Tracker() :      g_pDI(nullptr), @@ -10,8 +11,6 @@ FTNoIR_Tracker::FTNoIR_Tracker() :      iter(-1),      mtx(QMutex::Recursive)  { -    for (int i = 0; i < 6; i++) -        min_[i] = max_[i] = 0;      GUID bar = {0};  } @@ -51,8 +50,6 @@ static BOOL CALLBACK EnumObjectsCallback( const DIDEVICEOBJECTINSTANCE* pdidoi,  {      auto self = (FTNoIR_Tracker*) pContext; -    // For axes that are returned, set the DIPROP_RANGE property for the -    // enumerated axis in order to scale min/max values.      if( pdidoi->dwType & DIDFT_AXIS )      {          DIPROPRANGE diprg = {0}; @@ -60,15 +57,14 @@ static BOOL CALLBACK EnumObjectsCallback( const DIDEVICEOBJECTINSTANCE* pdidoi,          diprg.diph.dwHeaderSize = sizeof( DIPROPHEADER );          diprg.diph.dwHow = DIPH_BYID;          diprg.diph.dwObj = pdidoi->dwType; +	diprg.lMax = 65535; +	diprg.lMin = -65536;          // Set the range for the axis -        if( FAILED( self->g_pJoystick->GetProperty( DIPROP_RANGE, &diprg.diph ) ) ) +        if( FAILED( self->g_pJoystick->SetProperty( DIPROP_RANGE, &diprg.diph ) ) )              return DIENUM_STOP; -        self->min_[self->iter] = diprg.lMin; -        self->max_[self->iter] = diprg.lMax; -        qDebug() << "axis" << self->iter << diprg.lMin << diprg.lMax;          self->iter++;      } @@ -222,13 +218,8 @@ void FTNoIR_Tracker::GetHeadPoseData(double *data)          {              data[i] = 0;          } -        else { -            auto mid = (min_[idx] + max_[idx]) / 2; -            auto val = values[idx] - mid; - -            int scale = val > 0 ? abs(max_[idx] - mid) : -abs(mid - min_[idx]); -            data[i] = abs(val) * limits[i] / scale; -        } +	else +		data[i] = values[i] * limits[i] / AXIS_MAX;      }  } | 
