I want to use MediaRecorder to record voice, my code is:
public void record(View v) { Log.d(TAG, "record"); this.mediaRecorder.setAudioChannels(1); this.mediaRecorder.setAudioSamplingRate(44100); this.mediaRecorder.setAudioEncodingBitRate(64000); this.mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC); this.mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4); this.mediaRecorder.setOutputFile(this.file.getAbsolutePath()); this.mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AAC); try { this.mediaRecorder.prepare(); this.mediaRecorder.start(); // update the buttons this.setButtonsEnabled(false, true, false); } catch (IOException e) { Log.e(TAG, "Failed to record()", e); } }
Or
public void record(View v) { Log.d(TAG, "record"); this.mediaRecorder = new MediaRecorder(); this.mediaRecorder.setAudioChannels(1); this.mediaRecorder.setAudioSamplingRate(8000); this.mediaRecorder.setAudioEncodingBitRate(16); this.mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC); this.mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.RAW_AMR); this.mediaRecorder.setOutputFile(this.file.getAbsolutePath()); this.mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); try { this.mediaRecorder.prepare(); this.mediaRecorder.start(); // update the buttons this.setButtonsEnabled(false, true, false); } catch (IOException e) { Log.e(TAG, "Failed to record()", e); } }
On a Samsung all is OK, but on a Dell two methods do not succeed
Here is logcat:
02-01 13:56:51.094: E/AudioRecorderDemoActivity(1397): Failed to record() 02-01 13:56:51.094: E/AudioRecorderDemoActivity(1397): java.io.IOException: prepare failed. 02-01 13:56:51.094: E/AudioRecorderDemoActivity(1397): at android.media.MediaRecorder._prepare(Native Method) 02-01 13:56:51.094: E/AudioRecorderDemoActivity(1397): at android.media.MediaRecorder.prepare(MediaRecorder.java:524) 02-01 13:56:51.094: E/AudioRecorderDemoActivity(1397): at com.marakana.android.audiorecorderdemo.AudioRecorderDemoActivity.record(AudioRecorderDemoActivity.java:69) 02-01 14:05:20.074: E/AndroidRuntime(1790): FATAL EXCEPTION: main 02-01 14:05:20.074: E/AndroidRuntime(1790): java.lang.IllegalStateException: Could not execute method of the activity