MediaRecorder se bloquea al iniciar

He buscado muchos temas pero no una respuesta directa.

Tengo este código:

recorder = new MediaRecorder(); recorder.setAudioSource(MediaRecorder.AudioSource.MIC); recorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP); recorder.setOutputFile(mFileName); recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); if(!mStartRecording) { btn.setText("Stop Recording"); try { recorder.prepare(); } catch (IOException e) { e.printStackTrace(); } recorder.start(); mStartRecording = true; } else { btn.setText("Start Recording"); mStartRecording = false; recorder.stop(); recorder.reset(); recorder.release(); recorder = null; } 

Y he añadido:

 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> <uses-permission android:name="android.permission.STORAGE" /> <uses-permission android:name="android.permission.RECORD_AUDIO" /> 

(Vio en algún lugar que añadir STORAGE lo resolvió, no es bueno para mí)

Estoy desarrollando en API Nivel 7 (Android 2.1)

Stack trace dice "start faild" Rastreo de la pila:

  04-26 19:27:41.955: D/dalvikvm(890): GC freed 809 objects / 58272 bytes in 433ms 04-26 19:27:44.772: D/dalvikvm(890): GC freed 95 objects / 3936 bytes in 371ms 04-26 19:28:54.973: E/MediaRecorder(890): start failed: -1 04-26 19:28:54.993: D/AndroidRuntime(890): Shutting down VM 04-26 19:28:54.993: W/dalvikvm(890): threadid=3: thread exiting with uncaught exception (group=0x4001b188) 04-26 19:28:54.993: E/AndroidRuntime(890): Uncaught handler: thread main exiting due to uncaught exception 04-26 19:28:55.105: E/AndroidRuntime(890): java.lang.IllegalStateException: Could not execute method of the activity 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.View$1.onClick(View.java:2031) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.View.performClick(View.java:2364) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.View.onTouchEvent(View.java:4179) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.widget.TextView.onTouchEvent(TextView.java:6541) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.View.dispatchTouchEvent(View.java:3709) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:884) 04-26 19:28:55.105: E/AndroidRuntime(890): at com.android.internal.policy.impl.PhoneWindow$DecorView.superDispatchTouchEvent(PhoneWindow.java:1659) 04-26 19:28:55.105: E/AndroidRuntime(890): at com.android.internal.policy.impl.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1107) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.app.Activity.dispatchTouchEvent(Activity.java:2061) 04-26 19:28:55.105: E/AndroidRuntime(890): at com.android.internal.policy.impl.PhoneWindow$DecorView.dispatchTouchEvent(PhoneWindow.java:1643) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.ViewRoot.handleMessage(ViewRoot.java:1691) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.os.Handler.dispatchMessage(Handler.java:99) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.os.Looper.loop(Looper.java:123) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.app.ActivityThread.main(ActivityThread.java:4363) 04-26 19:28:55.105: E/AndroidRuntime(890): at java.lang.reflect.Method.invokeNative(Native Method) 04-26 19:28:55.105: E/AndroidRuntime(890): at java.lang.reflect.Method.invoke(Method.java:521) 04-26 19:28:55.105: E/AndroidRuntime(890): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 04-26 19:28:55.105: E/AndroidRuntime(890): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 04-26 19:28:55.105: E/AndroidRuntime(890): at dalvik.system.NativeStart.main(Native Method) 04-26 19:28:55.105: E/AndroidRuntime(890): Caused by: java.lang.reflect.InvocationTargetException 04-26 19:28:55.105: E/AndroidRuntime(890): at shibby.whisper.WhisperGameActivity.recordAudio(WhisperGameActivity.java:94) 04-26 19:28:55.105: E/AndroidRuntime(890): at java.lang.reflect.Method.invokeNative(Native Method) 04-26 19:28:55.105: E/AndroidRuntime(890): at java.lang.reflect.Method.invoke(Method.java:521) 04-26 19:28:55.105: E/AndroidRuntime(890): at android.view.View$1.onClick(View.java:2026) 04-26 19:28:55.105: E/AndroidRuntime(890): ... 21 more 04-26 19:28:55.105: E/AndroidRuntime(890): Caused by: java.lang.RuntimeException: start failed. 04-26 19:28:55.105: E/AndroidRuntime(890): at android.media.MediaRecorder.start(Native Method) 04-26 19:28:55.105: E/AndroidRuntime(890): ... 25 more 04-26 19:28:55.223: I/dalvikvm(890): threadid=7: reacting to signal 3 04-26 19:28:55.335: I/dalvikvm(890): Wrote stack trace to '/data/anr/traces.txt' 04-26 19:28:57.123: I/Process(890): Sending signal. PID: 890 SIG: 9 

Por favor ayuda.

De acuerdo, lo tengo. Supongo que inicializó mStartRecording a true.

Así su if está entrando en el bloque de else . En él, se detiene una nueva instancia de MediaRecorder y el diagrama de estado no lo permite.

Haz de tu grabadora de medios un campo de tu clase. E inicialice correctamente su variable booleana mStartRecording a false. Re instanciate su grabadora de medios sólo si su campo es nulo.

 if( recorder == null ) { recorder = new MediaRecorder(); recorder.setAudioSource(MediaRecorder.AudioSource.MIC); recorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP); recorder.setOutputFile(mFileName); recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); }//if if(!mStartRecording) { btn.setText("Stop Recording"); try { recorder.prepare(); recorder.start(); mStartRecording = true; } catch (IOException e) { e.printStackTrace(); }//catch } else { btn.setText("Start Recording"); mStartRecording = false; recorder.stop(); recorder.reset(); recorder.release(); recorder = null; }//else 

Trate de poner la función de start en el mismo bloque que la función de prepare . IllegalStateException vez hay una excepción de bloqueo de preparar de la ejecución y va directamente a comenzar causando así una IllegalStateException .

  recorder.setAudioSource(MediaRecorder.AudioSource.MIC); recorder.setOutputFormat(output_formats[currentFormat]); recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); recorder.setOutputFile(getFilename()); try { recorder.prepare(); recorder.start(); } catch (IllegalStateException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } 

Estoy utilizando el siguiente código, funciona perfectamente para mí ..

 protected void startRecording() { // TODO Auto-generated method stub i++; mFileName = Environment.getExternalStorageDirectory().getAbsolutePath(); mFileName += "/audiorecordtest"+i+".3gp"; recorder = new MediaRecorder(); recorder.setAudioSource(MediaRecorder.AudioSource.MIC); recorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP); recorder.setOutputFile(mFileName); recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); try { recorder.prepare(); } catch (IllegalStateException e) { // TODO Auto-generated catch block Toast.makeText(getApplicationContext(), "IllegalStateException called", Toast.LENGTH_LONG).show(); } catch (IOException e) { // TODO Auto-generated catch block Toast.makeText(getApplicationContext(), "prepare() failed", Toast.LENGTH_LONG).show(); } recorder.start(); } private void stopRecording() { recorder.stop(); recorder.release(); recorder = null; } 

Intente encender su grabadora sólo cuando esté preparada:

  try { recorder.prepare(); recorder.start(); mStartRecording = true; } catch (IOException e) { Log.e( LOG_TAG, "Error when preparing or starting recorder", e); } 

Estos métodos deben ordenar el orden en que se ejecutará. Aquí:

 recorder.setAudioSource(MediaRecorder.AudioSource.MIC); recorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP); recorder.setOutputFile(mFileName); recorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB); 

Yo tuve el mismo problema. Esto es porque había perdido una barra mientras que fijaba el nombre de fichero para el audio registrado.

cambio

 this.fileName = Environment.getExternalStorageDirectory().getAbsolutePath(); this.fileName += "yourfilename.3gp"; 

a

 this.fileName = Environment.getExternalStorageDirectory().getAbsolutePath(); this.fileName += "/yourfilename.3gp"; 

Tuve el mismo problema debido a mi SurfaceView se ha hecho invisible. Así que hazlo visible

  mSurfaceView.setVisibility(View.VISIBLE); 
  • La clase MediaRecorder comienza a grabar audio después de un ligero retraso
  • La parada del mediarecorder de Android falló
  • Android MediaRecorder stop () no se llama
  • Problema de MediaRecorder en Android Lollipop
  • MediaRecorder - setOrientationHint () excepción / error
  • Interrumpir la grabación de medios mediante programación. Camera.apk de samsung galaxy tiene `this.mMediaRecorder.pause ();` no funciona en mi código
  • ¿Cómo usar setCamera (MediaRecorder)?
  • ¿Cómo transmitir flujo de la videocámara a través de la red, la producción de archivo de vídeo válido, utilizando Android?
  • Problemas con la clase MediaRecorder para grabar audio - prepare () da una excepción - Permiso denegado
  • Android MediaRecorder setCaptureRate () y velocidad de reproducción de vídeo
  • Android Mediarecorder duración del video grabado diferente de la duración esperada
  • FlipAndroid es un fan de Google para Android, Todo sobre Android Phones, Android Wear, Android Dev y Aplicaciones para Android Aplicaciones.