报告分为两大部分,第一部分是3.22号在中心五楼会议室讨论后的一些需要深入调研的点,第二部分是android对2D的调用关系。
第一部分:
OpenGL(全写Open Graphics Library)是个定义了一个跨编程语言、跨平台的编程接口的规格,它用于生成二维、三维图像。这个接口由近三百五十个不同的函数调用组成,用来从简单的图元绘制复杂的三维景象。主要用于pc和工作站。
OpenVG是针对诸如Flash和SVG的矢量图形算法库提供底层硬件加速界面的免授权费、跨平台应用程序接口API。也是由OpenGL的拥有者khronos公司提出的。OpenVG 现仍处于发展阶段,其初始目标主要面向需要高质量矢量图形算法加速技术的便携手持设备,用以在小屏幕设备上实现动人心弦的用户界面和文本显示效果,并支持硬件加速以在极低的处理器功率级别下实现流畅的交互性能。
但是android中2D向量图形函数库并没有使用OpenVG,而是使用了Google在05年收购的一家公司提供的引擎叫skia。它可以搭配OpenGL/ES与特定的硬体特征,强化显示的效果。综上,2D图形硬件无需支持OpenVG。
OpenGL ES (OpenGL for Embedded Systems) 是一个针对嵌入式应用的,免费的,支持全功能2D、3D的跨平台API(OpenGL® ES is a royalty-free, cross-platform API for full-function 2D and 3D graphics on embedded systems - including consoles, phones, appliances and vehicles)。目前主要由3个版本,1.0,1.1,2.0.
OpenGL ES 1.0 是以 OpenGL 1.3 规范为基础的,OpenGL ES 1.1 是以 OpenGL 1.5 规范为基础的,1.1完全兼容1.0。OpenGL ES 2.0 则是参照 OpenGL 2.0 规范定义的。简单的来说,OpenGL ES是OpenGL针对嵌入式应用的简化版,也就是android使用的标准。OpenGL ES 1.1强调api的硬件加速,OpenGL ES 2.0更强调3D能力。
OpenGL ES 1.1和OpenGL ES 2.0之间的关系并不是旧版本和新版本之间的差别,而是一个针对相对低端的应用,一个针对高级应用,OpenGL官方的roadmap也是将这两个版本并行发展的。2.X并不能百分百兼容1.X。
Android现在支持1.X和2.X。
对于我们的应用来说,选择OpenGL ES 1.1已足够。理由如下:
1. 1.1就能达到甚至略超过PSP的效果了(PSP实际上是一个PS2的简化版,它也不支持vertex或pixel shader)。2.x能达到更好的效果(大约接近DX9)。毕竟无论是以掌机(或者手机等便携设备)的耗电量,成本,还是屏幕尺寸来看,1.x都更有优势。jsr184标准的硬件实现就是ES_1.x。
2. 如果追求最顶尖和图形质量和效果,定位为高端产品,那么就可以选择2.0,但成本和开发周期会很高。基本上2.x的接口是针对游戏主机而非掌机设计的,据说PS3就采用了ES_2.x。
3. android的目标应用不仅仅是手持设备,它的野心以后会触伸到游戏机甚至桌面等更为高端的领域,所以它现在支持更为高级的2.X。但是对于我们芯片的定位,如果选择支持OpenGL ES的IP。支持OpenGL ES 1.1足矣。
第二部分:
Android中2D图形引擎流程(以下说明以android2.0及以上版本):
上图是android的框架图,在LIBRARIES中有三个模块是比较重要的。分别是Surface Manager(界面管理),OpenGL|ES,SGL(SGL就是上文提到的skia graphic layer,是android中为应用提供的一套2D图形库)。
Android的图形系统采用client和server架构。
Client server
因此我们对其的理解可以分成两个部分,应用和界面:
应用:2D接口会调用skia图形引擎,而skia是软件实现的。3D接口会调用OpenGL,OpenGL的库可以通过软件实现,如果存在硬件库的话则调用硬件。软件库libagl.so,硬件库libhgl.so.
此部分的调研疑问:所有资料几乎都说skia是软件实现,没法使用硬件,但是在台湾的一篇介绍skia的博文中却提到:skia它可以搭配OpenGL/ES与特定的硬体特征,强化显示的效果。这部分存在矛盾,需进一步验证(这部分的疑惑已找到,可以参考这篇文章http://blog.csdn.net/yili_xie/archive/2009/11/12/4803565.aspx)。
界面:界面主要是通过sufaceFlinger实现的,在2.0及以上版本,sufaceFlinger直接调用OpenGL ES API。此时如果存在硬件库则系统自动调用硬件库的api实现硬件加速。
如果系统没有支持OpenGL ES的硬件,但是能够支持一些简单的2D功能。则系统会调用软件库,OPEN GLES软件库中有一个copybit的适配文件,此时我们可以在hardware中实现copybit这个文件。系统在自动调用OpenGL ES软件库的时候,,系统通过适配文件找到copybit从而将一些功能通过硬件实现(这些功能主要包括内存的拷贝,放大缩小,旋转)。
如果系统没有支持OpenGL ES的硬件,甚至连简单2D硬件都没有,sufaceFlinger通过open gl es软件库实现。
分享到:
相关推荐
在实际开发中,开发者通常会结合OpenVG与其他图形库,如OpenGL ES,以实现更复杂的效果和交互。例如,OpenVG可能用于绘制矢量图标,而OpenGL ES用于处理3D场景或复杂的动画效果。 总之,OpenVG是一个强大的2D图形...
嵌入式OpenGLES,全称为OpenGL for Embedded Systems,是OpenGL的一个子集,专为嵌入式设备如智能手机、平板电脑、智能电视等设计,用于处理2D和3D图形渲染。OpenGLES提供了标准接口,让开发者可以跨平台地编写图形...
OpenVG,全称为“Open Vector Graphics”,是一种开放标准的低级图形库,旨在提供高效、硬件加速的2D矢量图形渲染。这个标准由Khronos Group制定,目的是为嵌入式设备和移动设备提供高性能的图形处理能力,支持丰富...
EGL(Embedded Graphics Library)是OpenGL ES和OpenVG等图形API在嵌入式系统上的关键接口,主要用于管理和初始化图形上下文。在Java环境中,EGL主要用于建立Java代码与硬件图形加速器之间的桥梁,使得开发者可以...
EGL 1.4规范规定了一个EGL实现可能不支持所有客户端API(如OpenGL、OpenGL ES 和 OpenVG),这意味着某些函数如果调用了不受支持的客户端API时将触发错误。例如,如果一个EGL实现仅支持OpenGL ES而不支持OpenVG,则...
传统的图形应用开发通常依赖特定的API,如OpenGL ES 2.0或OpenVG 1.1,这些API在专用图形处理器上进行渲染加速。然而,这种模式可能会限制图像的复杂性和清晰度,无法满足日益增长的需求。因此,研究者提出了一个...
EGL实现可能不会支持所有可能的客户端API(例如OpenGL、OpenGL ES和OpenVG),当调用需要不支持的客户端API的函数时,将会生成错误。 #### 7. EGL函数使用 EGL提供了一系列函数来创建、管理和销毁各种对象(如上...
OpenVG专注于2D矢量图形,而OpenGL ES则用于3D图形处理。开发者需要理解这两者的工作原理,以及如何创建顶点缓冲对象、纹理映射和渲染管线等。 2. **硬件加速**:Symbian S60设备往往具备硬件图形加速能力,通过...
5. 图形库和API:可能涉及OpenGL ES、OpenVG等图形库的使用,以及如何通过这些API来调用硬件加速功能,提升图形渲染性能。 6. 电源管理:PXA310处理器的电源管理和功耗控制策略,对于电池供电的设备尤其重要,这...
5. **硬件加速**:如果涉及智能Framebuffer,需要了解如何利用硬件加速功能,如OpenGL ES和OpenVG。 6. **用户空间交互**:学习如何在用户空间应用程序中使用Framebuffer,如创建图形界面或嵌入式系统显示。 通过...
i.MX6系列是飞思卡尔推出的一款多核应用处理器,广泛应用于嵌入式系统、工业控制、车载娱乐等场景,其内置的GPU单元支持OpenVG、OpenGL ES 2.0等图形标准,能实现丰富的2D和3D渲染效果。 【GPU 3D 操作例子】在SDK...
此外,S5PV210还包含了一个高性能的图形处理器(GPU),支持OpenVG 1.1和OpenGL ES 2.0,可用于复杂的2D和3D图形处理。 二、GEC210开发板硬件结构 GEC210开发板的核心是S5PV210处理器,其外围硬件包括内存、闪存、...