Android MediaCodec: eglSwapBuffers: ошибка EGL: 0x300d
Так что проблема возникает только тогда, когда я пытаюсь записать во второй раз. То есть, когда я впервые запускаю MediaCodecs и Muxer, все работает большую часть времени. Но теперь я хочу, чтобы приложение было более стабильным.
Помогите выяснить, что не сносится и правильно настроить.
В основном при втором запуске все настроено нормально, но когда вызывается Renderer.drawFrame GLES20.glClear(GLES20.GL_COLOR_BUFFER_BIT);
Я получаю ошибку: I/Adreno﹕ Native window GetBuffer failed
И когда GLES20.glFlush();
Называется ошибка: I/Adreno﹕ Failed to acquire a surface
Который всегда предшествует eglSwapBuffers: EGL error: 0x300d
когда я пытаюсь поменять буфер. Так что что-то не убирается с первого запуска.
Код очистки:
public void releaseCapture(){
if (audioCodec != null){
audioCodec.stop();
audioCodec = null;
}
if (videoCodec != null){
videoCodec.stop();
videoCodec = null;
}
if (mediaMux != null){
mediaMux.release();
mediaMux = null;
}
if ( releaseAll ) {
releaseAll = false;
//releaseSurfaceTexture();
mEGLWrapper.destroySurface();
}
}
MyMediaCodec.stop ()
public void stop(){
if (codec == null) return;
if (!isAudioCodec) {
videoCodecInputSurface.release();
}
codecPrimed=false;
codec.stop();
codec.release();
codec = null;
codecManager.stopMuxer(isAudioCodec);
}
MyMediaMuxer.stop ()
public void stopMuxer(boolean isAudio){
if (mediaMux == null) return;
if (isAudio){
audioActive = false;
} else {
videoActive = false;
}
if (!(audioActive||videoActive)){
Log.d(TAG, "Stopping Muxer now. audio frame count = " + audioFrameCount +
"; video frame count = " + videoFrameCount);
videoHandler.postDelayed(new Runnable(){
@Override
public void run() {
if (mediaMux!=null) mediaMux.stop();
// set up for next run
releaseCapture();
}
},frame_delay);
}
}
mEGLWrapper.destroySurface ();
public void destroySurface(){
EGL14.eglDestroySurface(mEGLDisplay,mEGLSurface);
checkEglError("eglDestroySurace");
}
Журнал ошибок
05-05 17:51:43.072 27756-27913/com.harmonicprocesses.penelopefree
E/OMXMaster﹕ A component of name 'OMX.qcom.audio.decoder.aac' already exists, ignoring this one.
05-05 17:51:43.085 27756-27918/com.harmonicprocesses.penelopefree I/OMXClient﹕ Using client-side OMX mux.
05-05 17:51:43.470 27756-27756/com.harmonicprocesses.penelopefree D/penny.cam.MyMediaCodec﹕ Camera profile: Frame Rate = 30; Bit Rate = 42000000
05-05 17:51:43.470 27756-27756/com.harmonicprocesses.penelopefree D/penny.cam.MyMediaCodec﹕ ; Heighth = 2160; Width = 3840
05-05 17:51:43.472 27756-27918/com.harmonicprocesses.penelopefree E/ACodec﹕ [OMX.qcom.video.encoder.avc] storeMetaDataInBuffers (output) failed w/ err -1010
05-05 17:51:43.474 27756-27918/com.harmonicprocesses.penelopefree W/ACodec﹕ do not know color format 0x7fa30c04 = 2141391876
05-05 17:51:43.475 27756-27918/com.harmonicprocesses.penelopefree W/ACodec﹕ do not know color format 0x7f000789 = 2130708361
05-05 17:51:43.478 27756-27918/com.harmonicprocesses.penelopefree I/ACodec﹕ setupVideoEncoder succeeded
05-05 17:51:43.478 27756-27918/com.harmonicprocesses.penelopefree W/ACodec﹕ do not know color format 0x7f000789 = 2130708361
05-05 17:52:57.317 27756-27784/com.harmonicprocesses.penelopefree I/Adreno﹕ Native window GetBuffer failed
05-05 17:55:41.518 27756-27784/com.harmonicprocesses.penelopefree I/Adreno﹕ Failed to acquire a surface
05-05 17:56:24.246 27756-27791/com.harmonicprocesses.penelopefree V/com.hpp.MyMediaMux﹕ Trying to write data before muxer started, isAudioSample = true
05-05 18:04:55.189 27756-27784/com.harmonicprocesses.penelopefree D/io.hpp.MyGLSurfaceView18﹕ eglSwapBuffers: EGL error: 0x300d
05-05 18:04:55.189 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ java.lang.Exception
05-05 18:04:55.189 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at com.hpp.openGL.MyEGLWrapper.checkEglError(MyEGLWrapper.java:443)
05-05 18:04:55.190 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at com.hpp.openGL.MyEGLWrapper.swapBuffers(MyEGLWrapper.java:314)
05-05 18:04:55.190 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at com.harmonicprocesses.penelopefree.camera.CaptureManager.drawFrame(CaptureManager.java:478)
05-05 18:04:55.190 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at com.harmonicprocesses.penelopefree.camera.CaptureManager.drawFrameOnInputSurface(CaptureManager.java:463)
05-05 18:04:55.190 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at com.harmonicprocesses.penelopefree.camera.CaptureManager.videoCaptureLoop(CaptureManager.java:335)
05-05 18:04:55.190 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at com.harmonicprocesses.penelopefree.camera.CaptureManager$5.run(CaptureManager.java:318)
05-05 18:04:55.190 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at android.opengl.GLSurfaceView$GLThread.guardedRun(GLSurfaceView.java:1462)
05-05 18:04:55.190 27756-27784/com.harmonicprocesses.penelopefree W/System.err﹕ at android.opengl.GLSurfaceView$GLThread.run(GLSurfaceView.java:1239)
1 ответ
Сладкий, я получил это вскоре после публикации. Один EGL14.eglDestroySurface(mEGLDisplay,mEGLSurface);
не устанавливает для mEGLSurface значение EGL14.EGL_NO_SURFACE
как я и предполагал. И вы не узнаете об этом, потому что я не опубликовал это, но MyEGLWrapper.makeCurrent() проверяет это:
public void makeCurrent(boolean toScreen, Surface surface) {
if (toScreen) { //as opposed to toEncoder
makeScreenSurfaceCurrent();
return;
}
if (mEGLSurface.equals(EGL14.EGL_NO_SURFACE)){
mEGLSurface = EGL14.eglCreateWindowSurface(mEGLDisplay, configs[0], surface,
surfaceAttribs, 0);
checkEglError("eglCreateWindowSurface");
}
EGL14.eglMakeCurrent(mEGLDisplay, mEGLSurface, mEGLSurface, mEGLContext);
checkEglError("eglMakeCurrent");
}
и во-вторых, для releaseAll было задано значение false, поэтому mEGLSurface даже не уничтожался...
спасибо за поиск.