App freezes while recording accelerometer data: Android

1.1k Views Asked by At

I'm simply trying to record accelerometer data and write a file in sdcard with a button click. While running the app in my Nexus S (with 4.1.2), it freezes after a minute. I tried to run it in Galaxy Nexus phone and it works smoothly. For some reasons I have to work in Nexus S. Can anyone suggest me what might be the reason of crashing. I tried to see the log, but it does not through any error message.

Here's my code:

final SensorEventListener mySensorEventListener = new SensorEventListener() { 
    public void onSensorChanged(SensorEvent sensorEvent) {
        if (sensorEvent.sensor.getType() == Sensor.TYPE_ACCELEROMETER) {
            xAxis_lateralA = sensorEvent.values[0]; 
            yAxis_longitudinalA = sensorEvent.values[1]; 
            zAxis_verticalA = sensorEvent.values[2]; // TODO apply the acceleration changes to your application.
            textView.append("\nACC_x = "+ xAxis_lateralA + ", ACC_y = "+yAxis_longitudinalA+ ", ACC_z = " + zAxis_verticalA);

            acc += "\n"+miliSec()+", "+xAxis_lateralA + ", "+ yAxis_longitudinalA+", "+zAxis_verticalA;

            try {
                File myFile = new File("/sdcard/acc.txt");
                myFile.createNewFile();
                FileOutputStream fOut = new FileOutputStream(myFile);
                OutputStreamWriter myOutWriter = new OutputStreamWriter(fOut);
                myOutWriter.append(acc);
                myOutWriter.close();
                fOut.close();

            } catch (Exception e) {
                Toast.makeText(getBaseContext(), e.getMessage(), Toast.LENGTH_SHORT).show();
            }
        }
    }

    @Override
    public void onAccuracyChanged(Sensor sensor, int accuracy) {
        // TODO Auto-generated method stub

    }
};

startButton.setOnClickListener(new OnClickListener() {
    public void onClick(View v) {
        Toast.makeText(getBaseContext(),"Done writing SD 'acc.txt'",Toast.LENGTH_SHORT).show();
        sm = (SensorManager)getSystemService(Context.SENSOR_SERVICE); 
        int sensorType = Sensor.TYPE_ACCELEROMETER; 
        sm.registerListener(mySensorEventListener,sm.getDefaultSensor(sensorType), SensorManager.SENSOR_DELAY_NORMAL);

    }// onClick
}); // btnWriteSDFile 


stopButton = (Button) findViewById(R.id.stopButton);

stopButton.setOnClickListener(new OnClickListener() {

    public void onClick(View v) {

        int sensorType = Sensor.TYPE_ACCELEROMETER;
        sm.unregisterListener(mySensorEventListener, sm.getDefaultSensor(sensorType));
        Toast.makeText(getBaseContext(), "Stopped Recording",Toast.LENGTH_SHORT).show();
        finish();

    }// onClick
}); // btnstopButton
1

There are 1 best solutions below

0
nayab On

Issue is due to the way your writing values to text file.

You are opening/writing/closiing the file for everytime you get sensor reading.

Even for Sensor reading frequency of 50Hz it takes lot computation,writing these in text for 50 times/second is not efficient.

Use BufferedWriter ,it gives better performance.