转载自点击打开链接
之前在项目的时候,遇到到Media Recorder在快速启动停止等一系列操作的后,再次启动时,会failed的问题,类似的Log如下:
ERROR/MediaRecorder(9008): startfailed:-19
WARN/dalvikvm(9008): threadid=15: thread exiting with uncaught exception (group=0x40ad01f8)
ERROR/AndroidRuntime(9008): FATAL EXCEPTION: Thread-337
ERROR/AndroidRuntime(9008): java.lang.RuntimeException: start failed.
ERROR/AndroidRuntime(9008): at android.media.MediaRecorder.start(Native Method)
ERROR/AndroidRuntime(9008): at com.huawei.ca.eivs.camera.AndroidVideo.initMediaRecoder(AndroidVideo.java:429)
ERROR/AndroidRuntime(9008): at com.huawei.ca.eivs.camera.AndroidVideo.sendLiveToMdu(AndroidVideo.java:511)
ERROR/AndroidRuntime(9008): at com.huawei.ca.eivs.camera.AndroidVideo$ListenInviteThread.run(AndroidVideo.java:241)
WARN/ActivityManager(210): Force finishing activity com.huawei.ca.eivs.ui/com.huawei.ca.eivs.camera.AndroidVideo
ERROR/ActivityManager(210): exception bw.write()java.io.IOException: Transport endpoint is not connected
这个时候,退出自己的软件,打开系统相机,会提示“相机故障,无法连接到相机”,只能重启机器才能正常使用系相机。
根据反复测试抓log发现,造成MediaRecorder start失败的原因是:在程序中反复启动停止MediaRecord时,存在在无效的状态上stop MediaRecorder的情况,而且没有捕获此操作引发的异常,没有对MediaRecorder进行reset、release造成的。
具体的MediaRecorder状态迁移,请参看SDK。
解决办法:
解决这个问题的关键是保证MediaRecorder能在合适的状态执行合适的动作。
下面是我的解决方法,希望能给遇到这个问
</pre>题的人一个灵感:</p><p style="padding-top: 0px; padding-bottom: 0px; margin-top: 0px; margin-bottom: 0px; margin-left: 40px; color: rgb(52, 52, 52); font-family: Simsun; line-height: 24px;"><pre name="code" class="java"><span style="font-family: Simsun;">private void releaseMediaRecorder()</span>
{
if (mMediaRecorder != null)
{
// 内部标识是否正在录像的变量,如果不需要可以去掉
if (isRecord)
{
try
{
mMediaRecorder.setOnErrorListener(null);
mMediaRecorder.setOnInfoListener(null);
// 停止
mMediaRecorder.stop();
}
catch (RuntimeException e)
{
e.printStackTrace();
// 如果发生异常,很可能是在不合适的状态执行了stop操作
// 所以等待一会儿
try
{
Thread.sleep(100);
}
catch (InterruptedException e1)
{
Log.e(TAG, "sleep for second stop error!!");
}
}
isRecord = false;
}
// 再次尝试停止MediaRecorder
try
{
mMediaRecorder.stop();
}
catch (Exception e)
{
Log.e(TAG, "stop fail2", e);
}
// 等待,让停止彻底执行完毕
try
{
Thread.sleep(100);
}
catch (InterruptedException e1)
{
Log.e("TAG", "sleep for reset error Error", e1);
}
// 然后再进行reset、release
mMediaRecorder.reset();
mMediaRecorder.release();
mMediaRecorder = null;
}
}