[OpenGL ES 3.0编程指南]3 EGL简介

2024-08-21 16:38

本文主要是介绍[OpenGL ES 3.0编程指南]3 EGL简介,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

EGL提供如下机制:
1 与设备的原生窗口系统通信
2 查询绘图表面的可用类型和配置
3 创建绘图表面
4 在OpenGL ES 3.0和其他图形渲染API(如桌面OpenGL或窗口系统的原生绘图命令)之间同步渲染
5 管理纹理贴图等渲染资源
本章介绍打开一个窗口所需要的基本步骤

3.1 与窗口系统通信

EGL提供了OpenGL ES 3.0和运行于计算机上的原生窗口系统(如Linux系统常见的X Window系统)之间的一个结合层。
EGL提供基本的不透明类型--EGLDisplay,该类型封装了所有系统相关性。任何使用EGL的应用程序必须执行的第一个操作时创建和初始化与本地EGL显示的连接。
例3-1 初始化EGL:

EGLint majorVersion;
EGLint minorVersion;
// 打开与EGL显示服务器的连接
esContext->eglDisplay = eglGetDisplay( esContext->eglNativeDisplay );
if ( esContext->eglDisplay == EGL_NO_DISPLAY )
{return GL_FALSE;
}// Initialize EGL
if ( !eglInitialize ( esContext->eglDisplay, &majorVersion, &minorVersion ) )
{return GL_FALSE;
}

3.2 检查错误

EGLint eglGetError()

3.3 初始化EGL

初始化EGL内部数据结构,返回EGL实现的主版本号和次版本号:

// display:指定EGL显示连接
EGLBoolean eglInitialize(EGLDisplay display, EGLint *majorVersion, EGLint *minorVersion)

3.4 确定可用表面配置

查询底层窗口系统支持的所有EGL表面配置:

// display:指定EGL显示连接
// configs:指定configs列表
// maxReturnConfigs:指定configs的大小
// numConfigs:指定返回的configs大小
EGLBoolean eglGetConfigs(EGLDisplay display, EGLConfig *configs, EGLint maxReturnConfigs, EGLint *numConfigs)

3.5 查询EGLConfig属性

// display:指定EGL显示连接
// config:指定要查询的配置
// attribute:指定返回的特定属性
// value:指定返回值
EGLBoolean eglGetConfigAttrib(EGLDisplay display, EGLConfig config, EGLint attribute, EGLint *value)

EGLConfig属性:
https://www.cnblogs.com/wellcherish/p/12727906.html

3.6 让EGL选择配置

// display:指定EGL显示连接
// attribList:指定configs匹配的属性列表
// configs:指定配置列表
// maxReturnConfigs:指定配置的大小
// numConfigs:指定返回的配置大小
EGLBoolean eglChooseConfig(EGLDisplay display, const EGLint *attribList, EGLConfig *configs, EGLint maxReturnConfigs, EGLint *numConfigs)

例3-2 指定EGL属性
需要支持RGB565的渲染表面、一个深度缓冲区和OpenGL ES 3.0的EGLConfig。

EGLint attribList[] =
{EGL_RENDERABLE_TYPE,       EGL_OPENGL_ES3_BIT_KHR,EGL_RED_SIZE,       5,EGL_GREEN_SIZE,     6,EGL_BLUE_SIZE,      5,EGL_DEPTH_SIZE,     1,EGL_NONE
};

例3-3 查询EGL表面配置

const EGLint MaxConfigs = 10;
EGLConfig configs[MaxConfigs];
EGLint numConfigs;
// Choose config
if ( !eglChooseConfig ( esContext->eglDisplay, attribList, &config, MaxConfigs, &numConfigs ) )
{// Something did not work
} else {// Everything is okey; continue to create a rendering surface
}

3.7 创建屏幕上的渲染区域:EGL窗口

一旦我们有了符合渲染需求的EGLConfig,就为创建窗口做好了准备。

// display:指定EGL显示连接
// config:指定配置
// window:指定原生窗口
// attribList:指定窗口属性列表;可能为NULL
EGLSurface eglCreateWindowSurface(EGLDisplay display, EGLConfig config, EGLNativeWindowType window, const EGLint *attribList)

例3-4 创建一个EGL窗口表面

EGLint attribList [] =
{EGL_RENDER_BUFFER, EGL_BACK_BUFFER,EGL_NONE
};// Create a surface
EGLSurface window = eglCreateWindowSurface ( esContext->eglDisplay, config,esContext->eglNativeWindow, attribList );if ( window == EGL_NO_SURFACE ) {switch (eglGetError()) {case EGL_BAD_MATCH:break;case EGL_BAD_CONFIG:break;case EGL_BAD_NATIVE_WINDOW:break;case EGL_BAD_ALLOC:break;}
}

窗口不是唯一的可用渲染表面,我们来介绍另一种渲染表面类型。

3.8 创建屏幕外渲染区域:EGL Pbuffer

Pbuffer(Pixel buffer像素缓冲区),常用于生成纹理贴图。

// display:指定EGL显示连接
// config:指定配置
// attribList:指定窗口属性列表;可能为NULL
EGLSurface eglCreatePbufferSurface(EGLDisplay display, EGLConfig config, const EGLint *attribList)

例3-5 创建EGL像素缓冲区

EGLint attribList[] =
{EGL_SURFACE_TYPE,       EGL_PBUFFER_BIT,EGL_RENDERABLE_TYPE,    EGL_OPENGL_ES3_BIT_KHR,EGL_RED_SIZE,       5,EGL_GREEN_SIZE,     6,EGL_BLUE_SIZE,      5,EGL_DEPTH_SIZE,     1,EGL_NONE
};const EGLint MaxConfigs = 10;
EGLConfig configs[MaxConfigs];
EGLint numConfigs;
// Choose config
if ( !eglChooseConfig ( esContext->eglDisplay, attribList, &config, MaxConfigs, &numConfigs ) )
{// Something did not work
} else {// Everything is okey; continue to create a rendering surface
}// Proceed to create a 512*512 pbuffer
EGLSurface pbuffer;
EGLint attribList[] =
{EGL_WIDTH, 512,EGL_HEIGHT, 512,EGL_LARGEST_PBUFFER, EGL_TRUE,EGL_NONE
};pbuffer = eglCreatePbufferSurface(display, config, attribList);
if (pbuffer == EGL_NO_SURFACE) {switch (eglGetError()) {case EGL_BAD_MATCH:break;case EGL_BAD_CONFIG:break;case EGL_BAD_PARAMETER:break;case EGL_BAD_ALLOC:break;}
}

3.9 创建一个渲染上下文

渲染上下文是OpenGL ES 3.0的内部数据结构,包含操作所需的所有状态信息。

// display:指定EGL显示连接
// config:指定配置
// shareContext:允许多个EGL上下文共享特定类型的数据;使用EGL_NO_CONTEXT表示没有共享
// attribList:指定窗口属性列表;可能为NULL
EGLContext eglCreateContext(EGLDisplay display, EGLConfig config, EGLContext shareContext, const EGLint *attribList)

例3-6 创建一个EGL上下文

const EGLint attribList[] = 
{// EGL_KHR_create_context is requiredEGL_CONTEXT_CLIENT_VERSION,    3,EGL_NONE
}
EGLContext context = eglCreateContext(display, config, EGL_NO_CONTEXT, attribList)
if (context == EGL_NO_CONTEXT) {...
}

3.10 指定某个EGLContext为当前上下文

因为一个应用程序可能创建多个EGLContext用于不同的用途,所以我们需要关联特定的EGLContext和渲染表面。
关联EGLContext和EGLSurface:

// display:指定EGL显示连接
// draw:指定EGL绘图表面
// read:指定EGL读取表面
// context:指定连接到该表面的渲染上下文
EGLBoolean eglMakeCurrent(EGLDispaly display, EGLSurface draw, EGLSurface read, EGLContext context)

3.11 完整例子

例3-7 创建EGL窗口的完整例程

EGLBoolean initializeWindow (EGLNativeWindow nativeWindow)
{const EGLint configAttribs[] ={EGL_RENDER_TYPE, EGL_WINDOW_BIT,EGL_RED_SIZE,    8,EGL_GREEN_SIZE,    8,EGL_BLUE_SIZE,    8,EGL_DEPTH_SIZE,    24,EGL_NONE};const EGLint contextAttribs[] ={EGL_CONTEXT_CLIENT_VERSION,    3,EGL_NONE};EGLDisplay display = eglGetDisplay(EGL_DEFAULT_DISPLAY);if (display == EGL_NO_DISPLAY) {return EGL_FALSE;}EGLint major, minor;if (!eglInitialize(display, &major, &minor)) {return EGL_FALSE;}EGLConfig config;EGLint numconfigs;if (!eglChooseConfig(display, configAttribs, &config, 1, &numConfigs)) {return EGL_FALSE;}EGLSurface window = eglCreateWindowSurface(display, config, nativeWindow, NULL);if (window == EGL_NO_SURFACE) {return EGL_FALSE;}EGLContext context = eglCreateContext(display, config, EGL_NO_CONTEXT, contextAttribs);if (context == EGL_NO_CONTEXT) {return EGL_FALSE;}if (!eglMakeCurrent(display, window, window, context)) {return EGL_FALSE;}return EGL_TRUE;
}

上述代码和例3-8中代码类似。

例3-8 用esUtil库创建一个窗口

ESContext esContext;
const char* title = "Window Title";if (esCreateWindow(&esContext, title, 512, 512, ES_WINDOW_RGB|ES_WINDOW_DEPTH)) {// Window creation failed
}

ES_WINDOW_RGB:基于RGB的颜色缓冲区
ES_WINDOW_ALPHA:Alpha缓冲区
ES_WINDOW_DEPTH:深度缓冲区
ES_WINDOW_STENCIL:模板缓冲区
ES_WINDOW_MULTISAMPLE:多重采样缓冲区

这篇关于[OpenGL ES 3.0编程指南]3 EGL简介的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1093707

相关文章

JDK21对虚拟线程的几种用法实践指南

《JDK21对虚拟线程的几种用法实践指南》虚拟线程是Java中的一种轻量级线程,由JVM管理,特别适合于I/O密集型任务,:本文主要介绍JDK21对虚拟线程的几种用法,文中通过代码介绍的非常详细,... 目录一、参考官方文档二、什么是虚拟线程三、几种用法1、Thread.ofVirtual().start(

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

从基础到高级详解Go语言中错误处理的实践指南

《从基础到高级详解Go语言中错误处理的实践指南》Go语言采用了一种独特而明确的错误处理哲学,与其他主流编程语言形成鲜明对比,本文将为大家详细介绍Go语言中错误处理详细方法,希望对大家有所帮助... 目录1 Go 错误处理哲学与核心机制1.1 错误接口设计1.2 错误与异常的区别2 错误创建与检查2.1 基础

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

macOS彻底卸载Python的超完整指南(推荐!)

《macOS彻底卸载Python的超完整指南(推荐!)》随着python解释器的不断更新升级和项目开发需要,有时候会需要升级或者降级系统中的python的版本,系统中留存的Pytho版本如果没有卸载干... 目录MACOS 彻底卸载 python 的完整指南重要警告卸载前检查卸载方法(按安装方式)1. 卸载

Java Docx4j类库简介及使用示例详解

《JavaDocx4j类库简介及使用示例详解》Docx4j是一个强大而灵活的Java库,非常适合需要自动化生成、处理、转换MicrosoftOffice文档的服务器端或后端应用,本文给大家介绍Jav... 目录1.简介2.安装与依赖3.基础用法示例3.1 创建一个新 DOCX 并添加内容3.2 读取一个已存

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

Python动态处理文件编码的完整指南

《Python动态处理文件编码的完整指南》在Python文件处理的高级应用中,我们经常会遇到需要动态处理文件编码的场景,本文将深入探讨Python中动态处理文件编码的技术,有需要的小伙伴可以了解下... 目录引言一、理解python的文件编码体系1.1 Python的IO层次结构1.2 编码问题的常见场景二

Oracle Scheduler任务故障诊断方法实战指南

《OracleScheduler任务故障诊断方法实战指南》Oracle数据库作为企业级应用中最常用的关系型数据库管理系统之一,偶尔会遇到各种故障和问题,:本文主要介绍OracleSchedul... 目录前言一、故障场景:当定时任务突然“消失”二、基础环境诊断:搭建“全局视角”1. 数据库实例与PDB状态2

Git进行版本控制的实战指南

《Git进行版本控制的实战指南》Git是一种分布式版本控制系统,广泛应用于软件开发中,它可以记录和管理项目的历史修改,并支持多人协作开发,通过Git,开发者可以轻松地跟踪代码变更、合并分支、回退版本等... 目录一、Git核心概念解析二、环境搭建与配置1. 安装Git(Windows示例)2. 基础配置(必