1.名词解释

GPU:Graphic Processing Unit (图形处理器)

OpenGL:Open Graphic Library 定义了一个跨编程语言、跨平台的编程接口的规格,不同厂商会有不同的实现方法,它主要用于三维图象(二维的亦可)绘制。

SurfaceFlinger:Android中负责Surface之间叠加、混合操作的动态库

Skia:Android中的2D图形库

libagl:Android中通过软件方法实现的一套OpenGL动态库

libhgl:为区别libagl,自定义的一种叫法。特指GPU厂商提供的硬件实现的OpenGL

composition:特指SurfaceFlinger对各个Surface之间的叠加、混合操作

render:特指使用OpenGL动态库进行3D渲染

copybit:Android使用2D引擎来加速图形操作(主要是Surface之间的composition操作)的一种技术,对应着一个或几个动态库。

pmem:Android特有驱动,从linux内核中reserve物理连续内存,可以为2d、3d引擎、vpu等设备分配物理连续内存。

3D2D引擎在Android中的使用方法

2.1 Android如何使用2D3D引擎

Android在启动后,会在运行时根据配置文件加载OpenGL(libagl & libhgl)的实现,如果有libhgl实现,默认使用libhgl实现,否则使用libagl实现。

 

Android OpenGL动态库使用方法

1. 判断是否含有egl.cfg文件,如果没有在加载libagl

2. 如果有egl.cfg文件,则解析egl.cfg文件,根据egl.cfg文件加载对应libhgl和libagl

3. 分别解析libagl和libhgl,获取libagl和libhgl中标准OpenGL函数的函数地址(函数指针)

4. 系统在执行过程中,会通过函数指针调用到libagl或者libhgl中去,从而实现图形的绘制。

 

OpenGL在Android中两个作用

1. 用于Surface的composition操作

会调用到OpenGL中,通过libagl或者libhgl做Surface的组合、叠加操作。

2. 用于图形图像的渲染

会对OpenGL实现进行java层次的简单封装,在java应用程序中对OpenGL的调用最终会调用到libagl或者libhgl中去。

很多第三方游戏、3D图库、某些launcher会使用OpenGL实现比较炫丽UI的特效。

 

Copybit在Android中的作用

Copybit在Android中主要用于Surface的composition操作。

 

 

Skia在Android中的作用

Skia是Android的2D图形库,用于绘制文字、几何图形、图像等。

Skia的设备后端:Raster、OpenGL、PDF

 

Skia是否支持硬件加速?(此乃官方说明,我只是翻译。)

参考http://code.google.com/p/skia/wiki/FAQ

1. Skia子类SkCanvas

由于所有的绘图操作都会通过SkCanvas子类,这些绘图可以重定向到不同的图形API。SkGLCanvas已经可以将绘图操作直接指向对OpenGL的调用。参考src/gl目录

2. 自定义存在瓶颈的调用

中的某些blit操作存在瓶颈,可以利用CPU的一些特性去重写这些操作。比如在ARMV7设备上可以使用NEON SIMD指令进行优化。参考src/opts目录

 

2.使用GPU硬件加速需要做的工作

1. Linux内核方面:

添加GPU驱动支持,以模块方式编译GPU驱动,Android启动时加载内核模块。

添加PMEM支持,预留内存供GPU使用

2. Android方面:

添加copybit HAL

我们使用copybit调用2D engine对surface composition进行硬件加速。这样可能会达到更大的性能提升效果(比起使用3D engine)。

修改gralloc

gralloc负责显存等的分配,以及对framebuffer操作。如果使用copybit,必须修改gralloc

修改libagl

如果使用copybit,必须修改libagl,对libagl做部分hack,使之能够调用到copybit。

修改surfaceflinger


          如果使用 copybit 可能需要做部分修改