-
Anastasi
- Сообщения: 10
- Зарегистрирован: 09 апр 2013, 10:08
Сообщение
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
-
Контактная информация:
Сообщение
neoksi » 21 апр 2013, 08:32
Лог ошибки в студию.
-
Anastasi
- Сообщения: 10
- Зарегистрирован: 09 апр 2013, 10:08
Сообщение
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)