多核移动设备上3D模型的并发加载及渲染方法技术

技术编号:9462679 阅读:176 留言:0更新日期:2013-12-18 23:51
本发明专利技术涉及一种在多核移动设备上的3D模型并发加载及渲染方法,本发明专利技术包括以下步骤:以当前设备的CPU核心数作为线程池的容量来创建线程池。然后分别为存于外存设备上的每个3D模型文件分别创建3D模型数据加载任务。再为每个3D模型分别创建渲染任务。将所有数据加载任务提交到线程池的缓冲队列中,由线程池并发执行数据加载任务。等数据加载任务全部执行完毕之后,再将渲染任务提交到线程池的缓冲队列中,由线程池并发执行渲染任务。最后等所有渲染任务执行完毕后,销毁线程池释放系统资源。

【技术实现步骤摘要】
多核移动设备上3D模型的并发加载及渲染方法
本专利技术属于嵌入式软件领域。尤其涉及一种在多核移动设备上的3D模型并发加载及渲染方法。
技术介绍
随着嵌入式技术的不断发展,以智能手机、平板电脑为首的移动设备得到了迅猛的发展。移动设备的中央处理器从以前的单核心一直发展到现在的双核心、四核心甚至是八核心。在3D应用方面,多核移动设备不但能展示复杂的3D图形,甚至能运行大型的3D游戏。对于复杂场景的3D应用来说,需要加载及渲染多个3D模型。现有的方法是先将所有的3D模型文件以串行的方式加载至内存中,然后以串行的方式逐个渲染。然而在多核移动设备中,这种串行的3D处理方法并不能发挥多核处理器的优势来提高3D处理速度。
技术实现思路
本专利技术所需要解决的技术问题在于提供一种在多核移动设备上的3D模型并发加载及渲染方法。本专利技术解决技术问题所采取的技术方案如下:在加载及渲染3D模型前先判断当前移动设备的CPU核心数。以当前设备的CPU核心数作为线程池的容量来创建线程池。然后分别为存于外存设备上的每个3D模型文件分别创建3D模型数据加载任务。数据加载任务用来加载3D模型文件的顶点数据、法向量数据、纹理坐标数据、面数据、材质数据至内存。再为每个3D模型分别创建渲染任务。最后再将所有数据加载任务提交到线程池的缓冲队列中,由线程池并发执行数据加载任务。等数据加载任务全部完成之后,将渲染任务提交到线程池的缓冲队列中,由线程池并发执行渲染任务。最后等所有渲染任务执行完毕后,销毁线程池释放系统资源。本专利技术相对于现有技术具有以下有益效果:本专利技术根据移动设备的中央处理器核心数来创建线程池。线程池以中央处理器核心数个工作线程来并发执行异步3D模型文件数据加载任务、异步3D模型渲染任务。整个过程充分发挥了多核移动设备的处理性能。并且每个任务都以异步方式执行,消除了每个任务之间的同步开销。因此可以大大提高多核移动设备加载和渲染3D模型的速度。附图说明图1是本专利技术的流程图。具体实施方式以下结合附图对本专利技术作进一步说明。如图1所示,多核移动设备上3D模型的并发加载及渲染方法包括如下步骤:步骤一:获取当前移动设备的CPU核心数,具体是:根据移动设备所使用的操作系统,直接使用操作系统提供的API或者通过判断文件系统中存放CPU信息的文件数来获取当前移动设备的CPU核心数。操作系统包括但不限于IOS系统及Android系统。对于IOS操作系统的移动设备,可使用″sysctlbyname″函数来获取CPU的核心数;对于Android操作系统的移动设备,通过判断″/sys/devices/system/cpu/″目录下记录CPU信息的文件数来获取CPU的核心数。记录CPU信息的文件数即为CPU的核心数;步骤二:创建容量为CPU核心数的线程池,具体是:创建一个整型的线程池数变量nThread,将由第一步得到的CPU核心数赋给变量nThread;使用移动设备所使用的操作系统的应用程序开发工具包中的线程池类创建容量为nThread的线程池,操作系统包括但不限于IOS系统及Android系统;对于IOS操作系统的移动设备,使用IOS应用程序开发工具包中的″NSOperation″来创建线程池,使用″queuesetMaxConcurrentOperationCount:nThread″语句设置线程池的容量为nThread;对于Android操作系统的移动设备,可使用Android应用程序开发工具包中的″Executors″类来帮助创建线程池。具体使用″Executors.newFixedThreadPool(nThread)″来创建容量为nThread的线程池;步骤三:为每个3D模型文件分别创建异步数据加载任务,具体是:先遍历存于外存设备上的3D模型文件,获取每个模型文件的存放路径,并且置于数组中;再创建异步数据加载任务,具体任务流程是:流程一:根据存于数组中的3D模型文件的文件路径打开文件I/O;所述的3D模型文件格式包括OBJ格式和3DS格式;流程二:抽取存于外存设备上的3D模型文件的数据,包括:顶点数据、法向量数据、纹理坐标数据、面数据、材质数据;流程三:将抽取的3D模型数据单独封装成一个数据对象;总共创建的数据加载任务个数等于3D模型文件的个数;步骤四:为每个3D模型分别创建异步渲染任务,渲染任务流程具体是:流程一:使用步骤三封装的3D模型数据对象中的3D模型数据,为画笔绑定顶点数据,法向量数据,纹理坐标数据、面数据,并且设置材质特性;流程二:调用OpenGlES的gl.glDrawElements函数来渲染3D模型。总共创建的渲染任务个数等于3D模型文件的个数;步骤五:由线程池并发执行所有的异步数据加载任务,具体是:将由步骤三创建的所有异步数据加载任务提交到由步骤二所创建的线程池的缓冲队列中;启动线程池,并发地执行缓冲队列中所有异步数据加载任务。步骤六:由线程池并发执行所有的异步渲染任务,具体是:等步骤五的异步数据加载任务全部执行完毕后,将所有的渲染任务提交到由步骤二所创建的线程池的缓冲队列中;启动线程池,并发地执行缓冲队列中所有异步渲染任务;等所有异步渲染任务执行完毕后,销毁线程池释放系统资源。本文档来自技高网...
多核移动设备上3D模型的并发加载及渲染方法

【技术保护点】
多核移动设备上3D模型的并发加载及渲染方法,其特征包括以下步骤:步骤一:获取当前移动设备的CPU核心数,具体是:根据移动设备所使用的操作系统,直接使用操作系统提供的API或者通过判断文件系统中存放CPU信息的文件数来获取当前移动设备的CPU核心数。步骤二:创建容量为CPU核心数的线程池,具体是:创建整型的线程池数变量,将该变量的值设置为由步骤一获取的CPU核心数;以整型的线程池数变量作为线程池的容量参数,使用移动设备所使用的操作系统的应用程序开发工具包中的线程池类来创建容量为CPU核心数的线程池。步骤三:为每个3D模型文件分别创建异步数据加载任务,具体是:先遍历存于外存设备上的3D模型文件,获取每个模型文件的存放路径,并且置于数组中;再创建异步数据加载任务,具任务流程是:流程一:根据存于数组中的3D模型文件的文件路径打开文件I/O;流程二:抽取存于外存设备上的3D模型文件的数据,包括:顶点数据、法向量数据、纹理坐标数据、面数据、材质数据;流程三:将抽取的3D模型数据单独封装成一个数据对象。步骤四:为每个3D模型分别创建异步渲染任务,渲染任务流程具体是:流程一:使用步骤三封装的3D模型数据对象中的3D模型数据,为画笔绑定顶点数据,法向量数据,纹理坐标数据、面数据,并且设置材质特性;流程二:调用OpenGl?ES的gl.glDrawElements函数来渲染3D模型。步骤五:由线程池并发执行所有的异步数据加载任务,具体是:将由步骤三创建的所有异步数据加载任务提交到由步骤二所创建的线程池的缓冲队列中;启动线程池,并发地执行缓冲队列中所有异步数据加载任务。步骤六:由线程池并发执行所有的异步渲染任务,具体是:等步骤五的异步数据加载任务全部执行完毕后,将所有的渲染任务提交到由步骤二所创建的线程池的缓冲队列中;启动线程池,并发地执行缓冲队列中所有异步渲染任务;等所有异步渲染任务执行完毕后,销毁线程池释放系统资源。...

【技术特征摘要】
1.多核移动设备上3D模型的并发加载及渲染方法,其特征包括以下步骤:步骤一:获取当前移动设备的CPU核心数,具体是:根据移动设备所使用的操作系统,直接使用操作系统提供的API或者通过判断文件系统中存放CPU信息的文件数来获取当前移动设备的CPU核心数;步骤二:创建容量为CPU核心数的线程池,具体是:创建整型的线程池数变量,将该变量的值设置为由步骤一获取的CPU核心数;以整型的线程池数变量作为线程池的容量参数,使用移动设备所使用的操作系统的应用程序开发工具包中的线程池类来创建容量为CPU核心数的线程池;步骤三:为每个3D模型文件分别创建异步数据加载任务,具体是:先遍历存于外存设备上的3D模型文件,获取每个模型文件的存放路径,并且置于数组中;再创建异步数据加载任务,具任务流程是:流程一:根据存于数组中的3D模型文件的文件路径打开文件I/O;流程二:抽取存于外存设备上的3D模型文件的数据,包括:顶点数据、法向...

【专利技术属性】
技术研发人员:王秀敏张麒单良
申请(专利权)人:中国计量学院
类型:发明
国别省市:

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1