Запись звука, используя MediaRecorder

Ответить
Anastasi
Сообщения: 10
Зарегистрирован: 09 апр 2013, 10:08

Запись звука, используя MediaRecorder

Сообщение Anastasi » 21 апр 2013, 08:22

Нужно написать свой диктофон. Взяла пример из книги "Программирование под Android" Зигарда Медникса, но он не работает - сначала нажимаю кнопку record, затем когда нажимаю stop выходит ошибка приложения - Произошла неожиданная остановка приложения, пожалуйста, подскажите в чем ошибка. Помогите написать простой диктофон.
Код приложения:

Код: Выделить всё

import java.io.File;
import android.media.MediaRecorder;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.Toast;

public class AudioRecorder extends Activity {
	private MediaRecorder mediaRecorder;
	String filePath;
	Button recordButton;
	Button stopButton;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		recordButton =  (Button) findViewById(R.id.bRecord);
		recordButton.setOnClickListener(new OnClickListener(){
			public void onClick(View v){
				record("/sdcard/audiorecordexample.3gpp");
			}
		});
		stopButton =  (Button) findViewById(R.id.bStop);
		stopButton.setOnClickListener(new OnClickListener(){
			public void onClick(View v){
				stopRecord();
			}
		});
	}
	private void record(String filePath){
		try{
			File mediafile = new File(filePath);
			if(mediafile.exists()){
				mediafile.delete();
			}
			mediafile = null;
		//кнопка записи исчезает
		recordButton.setVisibility(View.GONE);
		//появляется кнопка стоп
		stopButton.setVisibility(View.VISIBLE);
		//настраиваем средство записи медиа
		if(mediaRecorder == null) mediaRecorder = new MediaRecorder();
		mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
		mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
		mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
		mediaRecorder.setOutputFile(filePath);
		//готовим средство записи медиа
		mediaRecorder.prepare();
		//запускаем средство записи медиа
		mediaRecorder.start();
		} catch (Exception e){
			e.printStackTrace();
		}
	}
	private void stopRecord(){
		//останавливаем средство записи медиа
		mediaRecorder.stop();
		//заново устанавливаем средство записи медиа
		mediaRecorder.reset();
		//появляется кнопка записи
		recordButton.setVisibility(View.VISIBLE);
		//исчезает кнопка стоп
		stopButton.setVisibility(View.GONE);
	}
}
layout main:

Код: Выделить всё

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent" >
    <Button
        android:id="@+id/bRecord"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="onClick"
        android:text="Record" />
    <Button
        android:id="@+id/bStop"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:onClick="onClick"
        android:text="Stop" />

</LinearLayout>

Аватара пользователя
neoksi
Сообщения: 712
Зарегистрирован: 26 июл 2012, 10:42
Контактная информация:

Re: Запись звука, используя MediaRecorder

Сообщение neoksi » 21 апр 2013, 08:32

Лог ошибки в студию.

Anastasi
Сообщения: 10
Зарегистрирован: 09 апр 2013, 10:08

Re: Запись звука, используя MediaRecorder

Сообщение Anastasi » 21 апр 2013, 11:20

neoksi писал(а):Лог ошибки в студию.
Весь лог:

Код: Выделить всё

04-21 08:15:25.363: W/System.err(375): java.lang.RuntimeException: setAudioSource failed.
04-21 08:15:25.363: W/System.err(375): 	at android.media.MediaRecorder.setAudioSource(Native Method)
04-21 08:15:25.374: W/System.err(375): 	at com.sample.recordaudio.AudioRecorder.record(AudioRecorder.java:74)
04-21 08:15:25.374: W/System.err(375): 	at com.sample.recordaudio.AudioRecorder.access$0(AudioRecorder.java:61)
04-21 08:15:25.374: W/System.err(375): 	at com.sample.recordaudio.AudioRecorder$1.onClick(AudioRecorder.java:32)
04-21 08:15:25.374: W/System.err(375): 	at android.view.View.performClick(View.java:2485)
04-21 08:15:25.374: W/System.err(375): 	at android.view.View$PerformClick.run(View.java:9080)
04-21 08:15:25.374: W/System.err(375): 	at android.os.Handler.handleCallback(Handler.java:587)
04-21 08:15:25.374: W/System.err(375): 	at android.os.Handler.dispatchMessage(Handler.java:92)
04-21 08:15:25.374: W/System.err(375): 	at android.os.Looper.loop(Looper.java:123)
04-21 08:15:25.374: W/System.err(375): 	at android.app.ActivityThread.main(ActivityThread.java:3683)
04-21 08:15:25.374: W/System.err(375): 	at java.lang.reflect.Method.invokeNative(Native Method)
04-21 08:15:25.384: W/System.err(375): 	at java.lang.reflect.Method.invoke(Method.java:507)
04-21 08:15:25.384: W/System.err(375): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-21 08:15:25.384: W/System.err(375): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-21 08:15:25.384: W/System.err(375): 	at dalvik.system.NativeStart.main(Native Method)
04-21 08:15:27.153: E/MediaRecorder(375): stop called in an invalid state: 0
04-21 08:15:27.153: D/AndroidRuntime(375): Shutting down VM
04-21 08:15:27.153: W/dalvikvm(375): threadid=1: thread exiting with uncaught exception (group=0x40015560)
04-21 08:15:27.164: E/AndroidRuntime(375): FATAL EXCEPTION: main
04-21 08:15:27.164: E/AndroidRuntime(375): java.lang.IllegalStateException
04-21 08:15:27.164: E/AndroidRuntime(375): 	at android.media.MediaRecorder.stop(Native Method)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at com.sample.recordaudio.AudioRecorder.stopRecord(AudioRecorder.java:88)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at com.sample.recordaudio.AudioRecorder.access$1(AudioRecorder.java:86)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at com.sample.recordaudio.AudioRecorder$2.onClick(AudioRecorder.java:38)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at android.view.View.performClick(View.java:2485)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at android.view.View$PerformClick.run(View.java:9080)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at android.os.Handler.handleCallback(Handler.java:587)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at android.os.Handler.dispatchMessage(Handler.java:92)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at android.os.Looper.loop(Looper.java:123)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at android.app.ActivityThread.main(ActivityThread.java:3683)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at java.lang.reflect.Method.invokeNative(Native Method)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at java.lang.reflect.Method.invoke(Method.java:507)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
04-21 08:15:27.164: E/AndroidRuntime(375): 	at dalvik.system.NativeStart.main(Native Method)

Ответить