views:

1059

answers:

2

I've been having issues with this for far too long. This code should output dx,dy,dz for the accelerometer, and a running total of the dx. It should also output azimuth, pitch, and roll.

I've used info from http://bit.ly/codeUsed, but to no avail.

This code does not correctly output pitch, azimuth, or roll. It outputs 0.0, -0.0, -0.0 for the last three textviews, respectively.

Please restore my sanity by helping me

switch (event.sensor.getType()) {
            case Sensor.TYPE_ACCELEROMETER:
                accelerometerValues = event.values.clone();
            case Sensor.TYPE_MAGNETIC_FIELD:
                geomagneticMatrix = event.values.clone();
                sensorReady = true;
                break;
            default:
                break;
        }   

        if (geomagneticMatrix != null && accelerometerValues != null && sensorReady) {
            sensorReady = false;

            float[] R = new float[16];
            float[] I = new float[16];

            SensorManager.getRotationMatrix(R, I, accelerometerValues, geomagneticMatrix);

            float[] actual_orientation = new float[3];
            SensorManager.getOrientation(R, actual_orientation);

            tvXCoordinate.setText(accelerometerValues[0] + "");
            tvYCoordinate.setText(accelerometerValues[1] + "");
            tvZCoordinate.setText(accelerometerValues[2] + "");

            floatXTotal += accelerometerValues[0];
            tvXTotal.setText(floatXTotal + "");

            tvAzimuth.setText(actual_orientation[0] + "");
            tvPitch.setText(actual_orientation[1] + "");
            tvRoll.setText(actual_orientation[2] + "");
        }
+1  A: 

I might be missing something (and you may have solved this already), but to me it looks like your switch statement is incorrect:

switch (event.sensor.getType()) {
        case Sensor.TYPE_ACCELEROMETER:
            accelerometerValues = event.values.clone();
        case Sensor.TYPE_MAGNETIC_FIELD:
            geomagneticMatrix = event.values.clone();
            sensorReady = true;
            break;
        default:
            break;
    }

If your sensor event is TYPE_ACCELEROMETER the values from the event will be cloned to both accelerometerValues and geomagneticMatrix and sensorReady will be set to true. I think you may need to change the order of this block, or possibly add a break; after your first case.

aganders3
+1  A: 

The reason you're getting 0.0, -0.0, -0.0 from getOrientation() is that getRotationMatrix() doesn't always get a valid result. You need to check getRotationMatrix()'s return value, which will be false if the result is invalid, or true if it succeeded.

Added: Actually, that didn't come out right. You're getting an invalid result for the reason aganders pointed out. Checking the return value would simply be an indication that you were in fact getting an invalid result.