gpt4 book ai didi

使用 OpenGL 处理 Android 相机帧

转载 作者:太空宇宙 更新时间:2023-11-03 22:12:04 26 4
gpt4 key购买 nike

我正在尝试在相机预览帧上应用人脸检测。我正在使用 OpenGL 和 OpenCV 在运行时处理这些相机帧。

@Override
public void onDrawFrame(GL10 unused) {
if (VERBOSE) {
Log.d(TAG, "onDrawFrame tex=" + mTextureId);
}

mSurfaceTexture.updateTexImage();
mSurfaceTexture.getTransformMatrix(mSTMatrix);

// TODO: need to implement
//JniCppManager.processFrame();

drawFrame(mTextureId, mSTMatrix);
}

我正在尝试实现 processFrame() 的 C++ 实现。如何从转换矩阵中获取 C++ 中的 Mat 对象?谁能给我一些解决方案的建议。

最佳答案

您的管道目前是:

  • 相机(制作框架)
  • SurfaceTexture(接收帧,转换为 GLES“外部”纹理)
  • [丢失的东西]
  • 传递给 C++ 的 RGB 字节数组

您需要为 [丢失的东西] 做的是将像素渲染到屏幕外 pbuffer 并使用 glReadPixels() 读回它们。您可以从用 Java 或 native 编写的代码中执行此操作;对于前者,您希望将它们读入“直接”ByteBuffer,以便您可以轻松地从 native 代码访问像素。 GLES 使用的 EGL 上下文保存在线程本地存储中,因此在 GLSurfaceView 渲染线程上运行的 native 代码将能够访问它。

这方面的一个例子可以在 bigflake ExtractMpegFramesTest 中找到,其主要区别在于它是从视频而非相机中抓取帧。

对于 API 19+,如果您可以处理 YV12 或 NV21 而不是 RGB 中的帧,则可以将相机提供给 ImageReader。无需复制/转换即可访问数据。

关于使用 OpenGL 处理 Android 相机帧,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33232446/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com