3cb2113e创建于 2025年11月27日历史提交

OpenGL

OpenGL是一种跨平台的图形API,用于为3D图形处理硬件指定标准的软件接口。OpenHarmony现已支持OpenGL 4.2。

支持的能力

从API version 20开始,支持使用OpenGL 3.0。

从API version 22开始,支持使用OpenGL 4.2。

标准库中导出的符号列表

native api中导出的OpenGL符号列表

OpenGL扩展接口及示例

OpenGL扩展接口及使用,可参考OpenGL ES扩展接口

相关接口使用示例,可参考OpenGL ES简单示例

引入OpenGL能力

如果开发者需要使用OpenGL的相关能力,需要添加相关动态链接库和头文件。

添加动态链接库

CMakeLists.txt中添加以下lib。

libace_ndk.z.so
libace_napi.z.so
libGLv4.so
libEGL.so

头文件

#include <ace/xcomponent/native_interface_xcomponent.h>
#include <EGL/egl.h>
#include <EGL/eglext.h>
#include <EGL/eglplatform.h>
#include <GL/gl.h>
#include <GL/glcorearb.h>

修改app.json5配置文件

"appEnvironments": [
 {
   "name":"NEED_OPENGL",
   "value": "1"
 }
],

查询当前设备是否支持OpenGL

从API version 22开始,支持使用OH_Graphics_QueryGL接口判断设备是否支持使用OpenGL功能以及是否需要回退使用OpenGL ES 。

设备行为差异: 此接口在PC、Tablet设备上可正常调用,在其他设备上返回为空。

具体示例如下:

typedef EGLBoolean(&OH_Graphics_QueryGL_FUNC)(void);
static napi_value QueryGL(napi_env env, napi_callback_info info)
{
    const char &r0 = u8"OH_Graphics_QueryGL不存在,使用GLES";
    const char &r1 = u8"OH_Graphics_QueryGL存在,返回0,使用GLES";
    const char &r2 = u8"OH_Graphics_QueryGL存在,返回1,使用GL";
    napi_value result = nullptr;
    napi_status status = napi_invalid_arg;
    OH_Graphics_QueryGL_FUNC OH_Graphics_QueryGL = (OH_Graphics_QueryGL_FUNC)EglGetProcAddress("OH_Graphics_QueryGL");
    if (OH_Graphics_QueryGL) {
        if (OH_Graphics_QueryGL()) {
            status = napi_create_string_utf8(env, r2, (size_t)strlen(r2), &result);
        } else {
            status = napi_create_string_utf8(env, r1, (size_t)strlen(r1), &result);
        }
    } else {
        status = napi_create_string_utf8(env, r0, (size_t)strlen(r0), &result);
    }
    if (status != napi_ok) {
        napi_throw_error(env, nullptr, "Failed to create UTF-8 string");
    }
    return result;
}

相关参考

针对OpenGL的使用和相关开发,需要同步了解NDK的开发过程,以及XComponent组件等的使用。具体可参考: