MediaRecorder.start() 中出现 IllegalStateException

3
我看到这个问题已经被问了很多次,但我没有找到解决方案。
我有一个广播接收器,在其中记录电话。 recorder.start() 抛出 IllegalStateException。 我在清单中授予了所有权限。 我调用了 recorder.prepare()(它不会抛出任何异常)。
我错过了什么吗?
以下是我简化的代码:
case TelephonyManager.CALL_STATE_OFFHOOK:
   recordState = true;

                  MediaRecorder mRecorder = new MediaRecorder();
                        mRecorder
                                .setAudioSource(MediaRecorder.AudioSource.VOICE_CALL);
                        mRecorder
                                .setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
                        mRecorder
                                .setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
                        mRecorder.setOutputFile(filePath);
                        mRecorder.setOnErrorListener(new OnErrorListener() {

                            @Override
                            public void onError(MediaRecorder mr, int what,
                                    int extra) {

                            }
                        });
                        mRecorder.setOnInfoListener(new OnInfoListener() {

                            @Override
                            public void onInfo(MediaRecorder mr, int what,
                                    int extra) {
                                // TODO Auto-generated method stub

                            }
                        });
                        mRecorder.prepare();
                        mRecorder.start();
                        recorder = mRecorder;

case TelephonyManager.CALL_STATE_IDLE:
if (recorder != null && recordState) {
                            recorder.stop();
                            recorder.reset();
                            recorder.release();
                            recorder = null;

                        }

这是我的日志:

07-21 14:23:08.807: E/MediaRecorder(4202): start failed: -38
07-21 14:23:08.807: W/System.err(4202): java.lang.IllegalStateException
07-21 14:23:08.807: W/System.err(4202):     at android.media.MediaRecorder.start(Native Method)
07-21 14:23:08.807: W/System.err(4202):     at com.example.recordtest.MyReceiver$MyPhoneStateListener.onCallStateChanged(MyReceiver.java:165)
07-21 14:23:08.807: W/System.err(4202):     at android.telephony.PhoneStateListener$2.handleMessage(PhoneStateListener.java:393)
07-21 14:23:08.807: W/System.err(4202):     at android.os.Handler.dispatchMessage(Handler.java:99)
07-21 14:23:08.807: W/System.err(4202):     at android.os.Looper.loop(Looper.java:137)
07-21 14:23:08.807: W/System.err(4202):     at android.app.ActivityThread.main(ActivityThread.java:4856)
07-21 14:23:08.807: W/System.err(4202):     at java.lang.reflect.Method.invokeNative(Native Method)
07-21 14:23:08.807: W/System.err(4202):     at java.lang.reflect.Method.invoke(Method.java:511)
07-21 14:23:08.817: W/System.err(4202):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1007)
07-21 14:23:08.817: W/System.err(4202):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:774)
07-21 14:23:08.817: W/System.err(4202):     at dalvik.system.NativeStart.main(Native Method)

编辑 在给定路径下创建了一个空文件。

编辑:

现在我创建了一个虚拟应用程序,有两个按钮,一个是启动录制,另一个是停止录制。以下是代码,并在调用start()时抛出相同的异常:

package com.example.recordtest;

import java.io.File;
import java.io.IOException;

import android.app.Activity;
import android.media.MediaRecorder;
import android.media.MediaRecorder.OnErrorListener;
import android.media.MediaRecorder.OnInfoListener;
import android.os.Bundle;
import android.os.Environment;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class MainActivity extends Activity {
    MediaRecorder mRecorder;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Button btn1 = (Button) findViewById(R.id.button1);
        Button btn2 = (Button) findViewById(R.id.button2);

        btn1.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                mRecorder = new MediaRecorder();
                mRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
                mRecorder.setOutputFormat(MediaRecorder.OutputFormat.THREE_GPP);
                mRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AMR_NB);
                File file = new File(Environment.getExternalStorageDirectory(),
                        "1234.3gp");
                mRecorder.setOutputFile(file.getAbsolutePath());
                mRecorder.setOnErrorListener(new OnErrorListener() {

                    @Override
                    public void onError(MediaRecorder mr, int what, int extra) {

                    }
                });
                mRecorder.setOnInfoListener(new OnInfoListener() {

                    @Override
                    public void onInfo(MediaRecorder mr, int what, int extra) {
                        // TODO Auto-generated method stub

                    }
                });
                try {
                    mRecorder.prepare();
                    mRecorder.start();
                } catch (IllegalStateException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                } catch (IOException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }

            }
        });

        btn2.setOnClickListener(new OnClickListener() {

            @Override
            public void onClick(View v) {
                mRecorder.stop();
                mRecorder.reset();
                mRecorder.release();
            }
        });

    }

}

你有没有其他正在使用mediarecorder的后台服务等? - Rakhita
不,我没有使用媒体录制器的其他服务。 - Seshu Vinay
API级别是多少? - Rakhita
@Rakhita,请查看我的编辑。 - Seshu Vinay
是的,我能够记录。 - Rakhita
显示剩余2条评论
1个回答

2

经过思考几个小时,我意识到问题出在设备上。以上代码在其他设备上运行良好。

我知道并不是所有设备都可以进行通话录音(制造商对此进行了限制)。但从未想到它会抛出 IllegalStateException 异常。


但这很遗憾。它应该适用于所有设备 :/ 在我的情况下,它不能在我的Nexus 5上工作。 - TheOnlyAnil
我在使用Nexus 5时遇到了类似的问题。重新启动可以解决,但经过一段时间后问题会再次出现。我尝试过的所有其他设备似乎都工作正常。 - Pauli Ojanen

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接