




已阅读5页,还剩3页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基于单目视觉测量的人体建模与显示盛光有1,姜寿山1,张欣2 (1.西安工程大学 电子信息学院,陕西 西安 710048;2.西安工程大学 服装与艺术设计学院,陕西 西安 710048 )摘要:以一种基于单目视觉测量原理的三维人体扫描装置获得的人体数据为来源,运用三角面片法构建人体表面,并把人体模型保存为一种标准的模型格式文件OBJ文件,获取了三维人体模型。然后在Visual C+的编程环境中采用OpenGL(Open Graphics Library)作为三维图形接口,编程实现了三维人体模型,获得了可视化的人体模型。关键词:三维人体模型;虚拟试衣;OpenGL;人体显示随着人们对服装的舒适性,合体性和款式的个性化的要求越来越高。传统的二维服装CAD软件暴露出了种种不足之处,如号型难以适应不同形态的人体,不能在衣片设计阶段就看到成衣后的效果,需要反复修改等。根据个人体型进行单量单裁的量身定制方式(Made To Measure,简称MTM)应运而生,由于能满足个性特殊需求,这种方式深受人们欢迎。法国力克公司推出了一种服装量身定制系统1,按照客户具体要求量身定制,做到量体裁衣,使服装真正做到合体舒适. 德国TechMath公司的FitNet软件系统针对该顾客的体型,从人体数据库中直接搜索出相近的体型及配套服装样板,并提供了进一步根据顾客体型和穿着习惯修改样板的功能2。还有英国的Baird Menswear西服公司,其销售到国内和国际市场的西服中有80是通过量身定制系统完成的,并且服装系列涵盖了不同款式、颜色和规格的组合3。而国内的三维服装CAD技术远远落后于西方发达国家,近几年来国内的一些院校和公司也都在研究这方面的技术。其中获得可视的三维人体模型的是三维虚拟试衣系统和三维服装CAD系统中的关键技术。本文以一种人体扫描仪所获取的三维人体数据为数据为基础,采用三角面片法构建了人体表面模型,并编程实现了人体模型的真实感显示。1 三维人体模型构建1.1 数据获取目前,获取用于三维人体模型重建的数据,主要用两种途径。一种是从Poser, Maya 和 3DSMax等软件系统导出人体模型数据,另外一种是采用非接触测量方法,通常是采用非接触式人体扫描仪获取人体表面的三维数据。本为获取数据的方法属于第二种。本文中人体建模用到的数据来源于一种基于单目视觉的双扫描头人体扫描仪所测得的4。由于获得的原始数据点云数量很大,并且排列不太规则,因此对原始点云进行了一定的处理,有效地减少了数据点云的数量和增加了点云数据的规律性。关于数据处理的细节不是本文的所讨论的重点,在此不讨论。处理之后的点云如图1所示。、图1 经过处理的人体点云1.2 人体模型构建方法的选取人体模型主要分为划分为线框模型、表面模型、实体模型、基于物理的模型等5 。使用线框模型的方法对人体建模时,它是将人体轮廓用线框图形和关节表示,由于包含的信息有限,因此该建模方法无法实现三维人体模型的真实感显示;表面模型是用组成物体的表面来表示物体。使用这种方法对人体建模时,曲面模型能提供三维人体的表面信息,并进行隐藏线消除和真实感三维人体模型显示;用实体模型的方法对人体建模时,由于它增加了三维人体的实心部分表达,使其信息更加完备,但是计算量大,稳定性差。基于物理的模型在建模过程中引入了人体自身的物理信息,所以基于物理的模型具有更加真实的表达效果,能对人体的动态过程进行有效地描述,但和前面几种相比,在计算上要复杂得多。综合了几种模型的优缺点,本文采用表面模型表达人体。使用三角面片、BEZIER 曲面、NURBS 曲面等都可以构成物体的表面,其中用得比较多的是 NURBS 曲面 ,但考虑到NURBS技术的复杂性,本文采用小三角面片表示人体曲面。这种方法具有表达简单、计算方便等优点。1.3 人体模型的构建前面已经介绍本文将采用一系列三角面片来表示人体表面,通过三维数据点集去构建这些三角面片的过程就叫做三角剖分,也称为三角网格化6。目前,关于三维散乱点集的三角剖分理论和算法尚不能尽如人意。然而由于本文中的点云已经处理为图1的形式,此时的人体表面是用一层层的轮廓线描述的。因此只要设法将人体相邻两截面用三角面片连接起来,就完成了三角网格化的过程。构造连接相邻两截面轮廓线的三角面片的过程也叫做轮廓连接。连接的方法有许多,目前常用方法主要有最短对角线法,最大体积法,相邻轮廓线同步前进法。由于相邻轮廓线同步前进法,只需要沿着轮廓线进行同步前进,灵活性较好并且计算不复杂,也很少出现狭长三角形等较差表面,因此本文选用这种方法来构建人体模型。这一方法的主要思想是,在用三角面片连接相邻两条轮廓线上的点列时,使得连接操作在两条轮廓线上尽可能同步进行。如图2所示,假设上下轮廓分别为P、Q,Pi、Qj(0im,0jn)分别为上下轮廓的各点,定义i、j分别为上下轮廓线线段长度除以该线段所在轮廓线的周长所得的值,同时假设i 表示上轮廓线中已经存在的轮廓线线段长度之和的标称值,j表示下轮廓线中已经存在的轮廓线线段长度之和的标称值。假设此时应判断选择三角形PiPi+1Qj或三角形PiQjQj+1,则当|i+i-j|j+j-i|时,沿上轮廓线前进,选择三角形PiPi+1Qj,否则沿下轮廓线前进。 图2 相邻轮廓线同步前进法构建三角面片示意图人体扫描仪所测得的人体数据分为六个部分,即左右腿,左右臂,躯干以及头部。按照上述方法,分别重构了这六个部分。为了获得完整的人体,还必须对这分割后的六个部分进行曲面拼接。包括左右腿和躯干的拼接,左右臂以及躯干和头部的拼接。首先需要考虑的就是相邻截面轮廓线的对应问题。以左右臂以及躯干和肩头部的拼接为例,需要首先将肩头部的第一层截面(用Ch表示)分成三部分,分别对应左右臂以及躯干部分的最后一层截面(分别用Cl、Cr、Cm表示)。对应的方法为比较Ch上各点x坐标与左右腋窝点的x坐标,若某点x坐标小于右腋窝点的x坐标,则将该点对应于Cr,若某点x坐标大于左腋窝点的x坐标,则将该点对应于Cl,剩余点对应于Cm.。在将两截面轮廓线对应后,再次按照轮廓线同步前进法分别连接各个分离的部分,则完成了人体模型的构建。构成的三角向形网格如图3所示。 图3 构建的三角形网格1.4 人体模型的存储在建立人体模型之后,需要将其以一定格式的文件进行存储,以利于应用程序对图形进行处理以及系统以后的扩展。OBJ 文件是 Wavefront公司开发的一种文件格式,该文件以纯文本形式存储了模型的顶点、法线、纹理坐标和材质等信息,而且结构非常简单,同时它也是一种标准的3D模型文件格式,很适合用于3D软件模型之间的互导,通用性较好,再者也可以方便系统将来在诸如反求工程等领域的扩展及系统的进一步开发。因此本文选用OBJ文件格式存储人体数据信息。如果三维人体显示时不经光照的浓淡处理,看到的人体模型就像平面图,没有立体效果。为了有立体效果,必须进行光照处理,这是因为物体在光的照射下其对光的一面和背光的一面呈现的效果不同,只有把这种效果反映出来,二维显示器上的三维模型才有逼真的立体感。通常我们进行人体模型绘制过程中,在进行光照处理时,必须计算面或点的法线向量才能看到效果。在本课题中以三角片来逼近模仿人体表面,就表现为计算每个三角面片法向量,采用这种方法计算量少。但是这种情况下,当数据点很少,很难模仿人体的光滑皮肤。因此为了得到一个更加真实的人体模型,使人体模型更生动、真实,还需要计算各个点的法向量。下面我们分别介绍一下三角片法向量和顶点法向量的的计算方法,如图4所示:O,P,Q,R,S,U,V,W是三角片顶点,P是一个中心顶点,它周围有7个三角片,三角片的法线向量分别是n1,n2,n3,n4,n5,n6,n7;其它点是边界点。图4 求法向量示意图对于任意三角片,根据平面法线向量定义,三角片的法线向量等于三角片两条向量边的叉乘积,例如三角形OQP,它的面法向量可以这样计算。 (1)对于中心点P法线向量np可以用平均法线向量计算: (2) 对与边界点Q的法线向量nQ可以用下面公式计算: (3)其中表示经过它的三角片的面积,表示该三角片法线向量。在OpenGL中,所使用的法线要求是规范化的向量,所以求得法线还必须规范化。这样,通过采用上面的方法计算,各个顶点的法向量是逐渐变化的,经过光照计算,视觉上的效果会很不同。如图5从左到右分别是人体腿部一部分没加光照、加光照但只计算面法向量、加光照并计算点法向量的对比效果。 (a) (b) (c)图5 大腿的光照效果对比图按照OBJ格式的要求,分别将人体表面各点,各点的法线向量以及三角面片写入OBJ文件。写入OBJ文件时,各三角形顶点索引号的写入顺序,使其满足右手准则,也就是使构成的三角形法线向外。生成的OBJ文件形式如图6所示。 (a)构成三角形的各顶点 (b) 各个顶点对应的法线(c) 三角形面片图6 生成的OBJ文件片段2 人体模型可视化虚拟环境的搭建OpenGL(Open Graphics Library),是从SGI公司的GL(graphics library)基础上发展起来的一套独立于硬件、独立于窗口系统的三维图形库。目前,OpenGL在图形设计领域已经成为工业标准,被广泛地应用于图形与动画绘制、虚拟现实技术和计算机可视化等三维图形设计领域7,而VC+也提供了与OpenGL的接口从而结合二者的特点,能很好地进行交互式三维应用程序的开发。所以本文采用OpenGL作为三维图形接口,以Visual C+6.0作为开发环境, 来显示人体模型。实现VC+6. 0和OpenGL之间图形接口的机制是像素格式设置以及关联DC与RC。在创建一个绘图描述表RC之前,首先要设置像素格式,完成像素格式的设置后,需要为OpenGL建立RC,只有建立RC后, OpenGL才能调用绘图原语在窗口中绘出图形。RC是以线程为单位的,每个线程必须使用一个RC作为当前RC才能执行OpenGL绘图原语. 在VC+6. 0中的MFC中实现OpenGL编程的大致步骤如下:(1) 建立项目文件利用MFC AppW izard(exe)创建一个单文档的新项目。(2) OpenGL的基础库设置在菜单中选择ProjectSettings,最后选择LINK选项,然后在“bject/LibraryModules” 下增加OpenGL所需的库程序,具体库程序是OpenGL32.lib、glu32.lib、laux. lib.每个程序开始要包含OpenGL所使用的库的头文件:#include “glgl. h”, #include “glglu. h” , #include “glglaux.h”。(3) 设置OpenGL支持的Windows窗口风格 OpenGL需要窗口具有WS_ CLI PCHILDREN和WS_CLI PSIBLI NG S风格。前者是创建父窗口使用的Windows风格,后者是创建子窗口使用的Windows风格。主窗口的创建函数PreCreateWindow(CREATESTRUCT & cs)中添加下面的代码:cs. style = WS _ CLIPSIBLINGS| WS _CLIPCHILDREN。 (4) 设置像素格式和关联DC和RC每个Windows应用程序都必须处理设备描述表。在创建设备描述表之前,要设置设备的像素格式,设置图形界面的属性,包括图形界面的颜色模式,颜色值的位数,使用单缓存还是双缓存,深度缓存的位数等,以及其它一些图形信息。利用OpenGL绘制的窗口也必须设置像素格式。因为,缺省设置的像素格式是Windows的GDI(图形用户接口)。对一个窗口只能设置一次像素格式,像素格式的设置,放在响应WM_CREATE消息的OnCreate()函数中实现。设置像素格式,首先应填充PIXELFORMAT-DESCRIPTOR结构,包括26个属性信息,然后调用处理像素格式的Win32函数关联DC和RC。设置像素格式与关联DC和RC的细节可以参考一下OpenGL编程方面的书籍。 (5) 重载OnSize()函数重载和OnDestroy()函数在OnSize()中,主要完成对窗口大小变化的响应。当窗口的大小改变改变时,必须重新设置图形显示模式,使其适合应用程序窗口大小,否则会导致图像变形;在程序退出时应该清空当前使用的着色上下文,并删除所创建的着色上下文。(6) 在Ondraw()函数中完成绘图工作以上完成了OpenGL在Visual C+环境下编程的有关设置。调用OpenGL有关绘图原语就可以进行编程了。绘图代码一般在Ondraw() 函数中完成。至此,显示人体的虚拟环境就搭建好了。3 三维人体显示在VC+的文档/视结构中,应用程序的数据是作为成员变量保存在文档类对象中的,视图类对象通过指针来访问文档类的成员变量。文档类的一个主要任务就是管理文档的数据磁盘存取,在文档类中实现磁盘存取的关键函数是CDocument: Serialize ()函数。本文就是重载CDocument: Serialize ()函数,在File菜单的0pen命令的消息响应函数中调用CWinApp: 0nFile0pen ()函数实现OBJ文档读入的。然后按照前面所讲的,利用MFC AppW izard(exe)创建一个单文档的新项目SingleModel. 然后建立OpenGL与VC+应用接口以及设置OpenGL的绘图环境。然后在Ondraw()中编写绘图代码。本文所显示的人体表面是有一定数量的三角面片构成的。所以绘图的主要工作是调用OpenGL函数绘出这些三角形面片。程序的核心部分是就是指定三角形的定点和法线。为了增强所显示人体的真实感,启用了OpenGL中的光照功能。在OpenGL中使用光照的步骤如下:(1) 定义每个物体的每个顶点的法线向量。这些法线决定了物体相对于光源的方向;(2) 创建一个或多个光源,并设置它们的位置;(3) 创建和选择光照模型, 它定义了全局环境光的层次以及观察点的有效位置(便于进行光照计算)。(4)定义场景中的物体的材料属性8。另外为了能从各个方面观察所显示的人体,本文实现了所显示的人体可以绕X,Y,Z轴旋转,并能实现缩放功能。在OpenGL中调用glTranslate(),glRotate(),glScale()等函数很容易实现物体的平移,旋转,缩放。综合以上各点,成功实现了OBJ三角网格文件的读取及0penGL下的显示。不同角度下的人体显示效果如图9所示: (a) (b) (c) (d) 图9 不同角度下的人体显示4结束语本文给出了一种三位人体模型的重建方法,采用三角面片法构建了三维人体表面模型,并把建立的人体模型保存一种标准的3D模型文件OBJ文件。介绍了在Visual C+环境下的OpenGL编程的接口,利用搭建起来的虚拟环境,成功实现了三维虚拟人体的真实感显示,得到了可视化的三维人体模型。本文获得三维人体模型为后续虚拟着装效果展示系统的研发提供了前提,也可用于游戏开发,虚拟现实等领域,有一定的实用价值。参考文献:1 常丽霞, 张欣. 非接触三维人体测量技术在服装工业中的应用J. 国际纺织导报,2004(4): 76-79.2 张中启, 张欣, 刘书云. 基于量身定制的女式裘皮服装关键技术探讨J. 天津工业大学学报, 2008,27(1):42-45.3 徐继红. MTM与服装定制最优裁剪方案的研究J. 扬州职业大学学报, 2003, 12(4) : 28.4 舒方法.基于单目视觉的便携式量体定制系统研究D.西安:西安工程大学,2008.5 崔树芹.三维虚拟试衣系统中参数化人体建模技术的研究D.华中科技大学,硕士,2006.6 袁夏.三维激光扫描点云数据处理及应用技术D.南京理工大学,硕士,2006.7 王兰美,赵继成,秦华东. OpenGL及其在VC+开发环境下的编程实现 J. 山东理工大学学报(自然科学版),2006,20(4):37-38.8 Dave Shreiner, Mason Woo, Jackie Neider ,Tom Davis 著,徐波 等译. OpenGL编程指南(第5版)M. 北京:
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年耳鼻喉科患者术前护理模拟测试答案及解析
- 西藏2025年上半年企业法律顾问考试《综合法律》试题
- 湖南省益阳市2026届高三上学期9月联考测试 英语试卷
- 民政局网络安全培训课件
- 工厂厂级安全培训课件
- 海南省文昌市2024-2025学年七年级上学期期中考试地理试卷(含答案)
- 2022北京城市总体规划实施体检报告公众读本
- 交警大队面试题库及答案
- 监狱局面试题库及答案解析
- 森林防火安全培训新闻课件
- 汽车充电机及DCDC测试内容
- XX专业技术人员岗位竞聘申请表
- 07K506 多联式空调机系统设计与施工安装
- CB33 验收申请报告
- 黄芪注射液联合当归注射液对急性失血性休克围手术期血乳酸水平和氧代谢的影响
- 2023年上海市选调生考试《申论》题库【真题精选+章节题库+模拟试题】
- 大气物理学课件
- 港口航道疏浚工程案例
- DLT-969-2023年变电站运行导则
- 现代铁路铁道信号远程控制系统(第2版)PPT完整全套教学课件
- 通知证人出庭申请书
评论
0/150
提交评论