CN114359504B - 一种三维模型的显示方法及采集设备 - Google Patents
一种三维模型的显示方法及采集设备 Download PDFInfo
- Publication number
- CN114359504B CN114359504B CN202111526075.XA CN202111526075A CN114359504B CN 114359504 B CN114359504 B CN 114359504B CN 202111526075 A CN202111526075 A CN 202111526075A CN 114359504 B CN114359504 B CN 114359504B
- Authority
- CN
- China
- Prior art keywords
- sub
- model
- target
- data
- vertex
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000000034 method Methods 0.000 title claims abstract description 37
- 238000009877 rendering Methods 0.000 claims description 60
- 238000004891 communication Methods 0.000 claims description 21
- 238000004590 computer program Methods 0.000 claims description 8
- 230000011218 segmentation Effects 0.000 description 16
- 230000005540 biological transmission Effects 0.000 description 6
- 238000010586 diagram Methods 0.000 description 5
- 239000007787 solid Substances 0.000 description 4
- 230000000694 effects Effects 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000003068 static effect Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 2
- 238000012545 processing Methods 0.000 description 2
- 230000000007 visual effect Effects 0.000 description 2
- 230000006835 compression Effects 0.000 description 1
- 238000007906 compression Methods 0.000 description 1
- 238000011161 development Methods 0.000 description 1
- 230000018109 developmental process Effects 0.000 description 1
- 238000007654 immersion Methods 0.000 description 1
- 238000013507 mapping Methods 0.000 description 1
- 238000011160 research Methods 0.000 description 1
- 238000005070 sampling Methods 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
Landscapes
- Processing Or Creating Images (AREA)
Abstract
本申请涉及虚拟现实技术领域,提供一种三维模型的显示方法及采集设备,可以解决相同精度和不同精度子模型间的拼接缝隙。针对相同精度子模型间的拼接缝隙,通过各个顶点生成的三角形面片的边与相应长方体共有面的交点,更新同精度相邻子模型各自包含的顶点,由于两个共面长方体对应的交点的位置相同,因此,同精度相邻的子模型在拼接处可以完重合,从而减少同精度子模型间的拼接缝隙;针对不同精度子模型间的拼接缝隙,通过在相邻子模型的不封闭的切面内生成的至少一个新的三角形面片,使得不同精度的相邻子模型均位于不同长方体的封闭空间内,从而减少不同精度子模型间的拼接缝隙。通过本申请提供的方法,可以提高了三维模型的显示质量。
Description
技术领域
本申请涉及虚拟现实(Virtual Reality,VR)技术领域,尤其涉及一种三维模型的显示方法及采集设备。
背景技术
在实时远程三维通信系统中,由于要实时传输多路三维模型数据(包括几何数据和纹理数据),且每帧的三维模型数据不同,总的数据量巨大,增加了网络带宽的压力,从而导致显示终端在三维模型的动作帧率不足时,造成三维模型动作的卡顿。
为了解决模型动作卡顿的问题,相关技术生成了不同精度的三维模型,并进行了模型的分割,将各个低精度子模型的重建数据完整发送,以及将各个高精度子模型的数据独立传输,从而在现有网络带宽的条件下,尽可能多地传输高精度重建数据,保证模型精度的同时减少卡顿现象。
然而,采用上述方案时,显示终端需要将各个子模型进行拼接显示,相邻子模型之间会存在拼接缝隙,尤其精细程度不同的相邻子模型的缝隙更加明显,影响了模型的显示质量。
发明内容
本申请实施例提供了一种三维模型的显示方法及采集设备,用以解决三维模型拼接处的缝隙,提高三维重建的显示质量。
第一方面,本申请实施例提供一种三维模型的显示方法,包括:
对三维模型的初始重建数据进行下采样,得到目标重建数据;所述三维模型是根据RGBD相机采集的目标对象的深度图像和彩色图像得到的;
将所述三维模型对应的包围盒等分为各个长方体,分别确定每个长方体对应的第一顶点集合和第二顶点集合,所述第一顶点集合中的各个第一顶点为所述初始重建数据中的顶点,所述第二顶点集合中的各个第二顶点为所述目标重建数据中的顶点;
遍历所述初始重建数据中各个第一顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第一交点,并针对每一个第一交点,将所述第一交点分别存入所述第一交点所在共有面的两个长方体对应的第一顶点集合中;
遍历所述目标重建数据中各个第二顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第二交点,并针对每一个第二交点,将所述第二交点分别存入所述第二交点所在共有面的两个长方体对应的第二顶点集合中;
针对每一个长方体,根据所述长方体对应的第一顶点集合生成一个第一子模型,以及根据所述长方体对应的第二顶点集合生成一个第二子模型;
将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,以使所述渲染设备根据各个初始重建数据,以及与所述各个目标子模型不同标识的第二子模型的目标重建数据,渲染所述三维模型并显示;其中,所述目标子模型为所述渲染设备的视景体内的第二子模型,所述标识是所述渲染设备根据所述各个第二子模型的包围盒与所述视景体的空间关系确定的。
第二方面,本申请实施例提供一种采集设备,包括处理器、存储器和通信接口,所述存储器、所述通信接口与所述处理器通过总线连接;
所述存储器存储有计算机程序,所述处理器根据所述计算机程序执行以下操作:
对三维模型的初始重建数据进行下采样,得到目标重建数据;所述三维模型是根据RGBD相机采集的目标对象的深度图像和彩色图像得到的;
将所述三维模型对应的包围盒等分为各个长方体,分别确定每个长方体对应的第一顶点集合和第二顶点集合,所述第一顶点集合中的各个第一顶点为所述初始重建数据中的顶点,所述第二顶点集合中的各个第二顶点为所述目标重建数据中的顶点;
遍历所述初始重建数据中各个第一顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第一交点,并针对每一个第一交点,将所述第一交点分别存入所述第一交点所在共有面的两个长方体对应的第一顶点集合中;
遍历所述目标重建数据中各个第二顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第二交点,并针对每一个第二交点,将所述第二交点分别存入所述第二交点所在共有面的两个长方体对应的第二顶点集合中;
针对每一个长方体,根据所述长方体对应的第一顶点集合生成一个第一子模型,以及根据所述长方体对应的第二顶点集合生成一个第二子模型;
通过所述通信接口,将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,以使所述渲染设备根据各个初始重建数据,以及与所述各个目标子模型不同标识的第二子模型的目标重建数据,渲染所述三维模型并显示;其中,所述目标子模型为所述渲染设备的视景体内的第二子模型,所述标识是所述渲染设备根据所述各个第二子模型的包围盒与所述视景体的空间关系确定的。
第三方面,本申请提供一种计算机可读存储介质,计算机可读存储介质存储有计算机可执行指令,计算机可执行指令用于使计算机执行本申请实施例提供的三维模型的显示方法。
本申请的上述实施例中,通过对初始重建数据进行下采样,得到低于初始重建数据精度的目标重建数据,基于三维模型的包围盒等分后的各个长方体,分别对两种不同精度的重建数据进行分割,得到每个长方体对应的不同精度的第一顶点集合和第二顶点集合;进一步地,分别遍历不同精度的重建数据中各个顶点生成的三角形面片的边,得到各个边与相应长方体共有面的交点,并将获得的各个交点分别存入两个共面长方体对应的第一顶点集合和第二顶点集合中,针对每个长方体对应的第一顶点集合和第二顶点集合,生成第一子模和第二子模型。由于两个共面长方体对应的第一顶点集合中第一交点的位置相同,因此,两个相邻的第一子模型在拼接处可以完重合,同理,由于两个共面长方体对应的第二顶点集合中第二交点的位置相同,两个相邻的第二子模型在拼接处可以完重合,从而解决了相同精度的子模型间的拼接缝隙。当渲染设备根据采集设备发送的各个第二子模型的目标重建数据以及各个目标子模型的初始重建数据渲染三维模型时,精度相同的子模型间不会存在拼接缝隙,使得拼接后的三维模型更加真实,提高三维重建的显示质量。
附图说明
为了更清楚地说明本申请实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本申请的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。
图1示例性示出了本申请实施例提供的三维模型的分割示意图;
图2示例性示出了本申请实施例提供的三维模型的拼接效果示意图;
图3示例性示出了本申请实施例提供的三维模型的显示方法流程图;
图4示例性示出了本申请实施例提供的三维模型与长方体的空间示意图;
图5示例性示出了本申请实施例提供的相同精度相邻子模型间缝隙的意图;
图6示例性示出了本申请实施例提供的解决相同精度的独立子模型示意图;
图7示例性示出了本申请实施例提供的不同精度子模型间的拼接缝隙原理图;
图8示例性示出了本申请实施例提供的另一三维模型的显示方法流程图;
图9示例性示出了本申请实施例提供的不同精度相邻子模型的切面示意图;
图10示例性示出了本申请实施例提供的解决不同精度相邻子模型间缝隙的意图;
图11示例性示出了本申请实施例提供的切面内生成三角形面片的示意图;
图12示例性示出了本申请实施例提供的切面内生成三角形面片的另一示意图;
图13示例性示出了本申请实施例提供的采集设备的结构示意图。
具体实施方式
近年来,随着VR技术的发展,三维重建逐渐成为三维显示领域中的热门研究内容。三维重建是指根据单视图或者多视图的图像重建三维信息的过程。
三维重建可以分为静态三维重建和动态三维重建。对于一些静态场景、物体,通过静态三维重建算法重建场景和物体的三维模型,然后渲染在三维场景中进行显示。对于一些动态的物体(比如:人),由于是动态变化的,往往需要建立一系列的三维模型,将这些三维模型按顺序进行渲染显示以描述物体的运动状态。
实时远程三维通信系统作为动态三维重建一个重要的应用场景,由采集设备基于采集的图像数据重建三维模型后,将三维重建数据通过云端传输给渲染设备进行渲染显示。其中,采集设备和渲染设备是相对用户而言的。例如,用户A对应一个显示设备1,用户B对应一个显示设备2,显示设备1对于用户A来说是采集设备,对于用户B来说则是渲染设备,同理,显示设备2对于用户B来说是采集设备,对于用户A来说则是渲染设备。
例如,在实时远程三维通信系统的虚拟社交场景中,不同用户端通过三维重建将各自的动态三维模型传输给其它用户端,其它用户端接收到这些数据后在本端进行渲染显示。相对于传统的语音或者视频通讯方式,该方式可以让处于异地的用户达到身临其境的社交体验。
在实时远程三维通信系统中,由于三维重建数据是动态生成的,且每帧数据都不同,这样,一个设备同时接收多路三维重建数据时,数据量巨大,往往需要几百兆的网络带宽,家用网络甚至是专线网络都难以满足实时性传输的要求。若通过降低重建模型的精度来减少数据量,则无法达到较好的显示效果。
在保证模型精度的同时减小网络带宽压力,可采用将三维模型进行分块并传输不同精度子模型数据的方法进行显示。该方法中,采集设备对原始三维模型的数据(包括几何数据和纹理数据)进行下采样以减少顶点数据、降低纹理分辨率,生成一份低精度的三维模型数据,并完整的传输给渲染设备以保证数据的完整性和模型动作帧率;然后,采集设备计算出三维模型的包围盒并等分为若干长方体,按照各个长方体,将原始的高精度三维模型和下采样的低精度三维模型切割为若干子模型,如图1所示,确定三维模型(包括高精度三维模型和低精度三维模型)包含的所有顶点(在图1中用黑色原点表示)所属的长方体之后,对同一长方体内的顶点独立建立拓扑结构,生成一个独立的子模型;进一步地,根据各个子模型的优先级,陆续地将高精度子模型的数据传输给渲染设备。渲染设备在没有完成高精度子模型数据的下载时,使用同一标识的低精度子模型数据进行渲染,从而得到不同精度子模型拼接的三维模型并显示,如图2所示。由于低精度三维模型的数据量较小,且高精度数据分块传输,这样,既降低了网络带宽的压力,也保证了模型渲染的完整性。
然而,由于上述方法需要将不同精度的子模型进行拼接显示,相邻子模型之间会存在拼接缝隙,尤其精细程度不同的相邻子模型的缝隙更加明显,影响了模型的显示质量。
鉴于此,本申请实施例提供了一种三维模型的显示方法及采集设备,通过对初始重建数据进行下采样,得到低于初始重建数据精度的目标重建数据,针对不同精度的重建数据,分别进行子模型的分割,分割过程中,基于三维模型的包围盒等分后的各个长方体,获取两个相邻长方体共有面内的交点,并将交点分别存储至两个共面长方体对应的不同精度的顶点集合中,由于两个共面长方体对应的顶点集合中交点的位置相同,这样,基于顶点集合生成的相同精度的两个子模型在拼接处可以完全重合,解决了相同精度子模型间的拼接缝隙,从而提高了三维模型的显示质量。
同时,对于不同精度子模型之间的缝隙,本申请实施例通过不同精度子模型的切面内的交点,生成新的三角形面片以覆盖不同精度子模型之间的拼接缝隙。
下面以一帧三维模型的数据为例,图3示例性示出了本申请实施例提供的三维模型的显示方法流程图,该流程由采集设备执行,主要包括以下几步:
S301:对三维模型的初始重建数据进行下采样,得到目标重建数据。
在实时远程三维通信系统中,采集设备获取RGBD相机采集的目标对象的深度图像和彩色图像,由主机将深度图像转换为点云数据集,重建目标对象的几何模型,并根据深度图像与彩色图像之间的映射关系,从彩色图像提取纹理数据对几何模型进行贴图,得到目标对象的三维模型。
由于三维模型是基于采集的真实数据重建的,因此,三维模型的初始重建数据(包括几何数据和纹理数据)中,顶点的数量、纹理的分辨率等都是真实的,保证了三维模型的重建精度,可以将初始重建数据作为高精度重建数据。而高精度的重建数据对网络带宽的要求较高,在没有有效的压缩编码的方法时,现有网络难以做到实时传输,因此,为了满足远程三维通信实时性的要求,需要对初始重建数据进行下采样。
在一种可选的实施方式中,执行S301时,根据预设的采样系数,降低初始重建数据中三维模型的顶点数量,以及减小初始重建数据中纹理数据的分辨率,得到下采样后的目标重建数据,从而减少了网络传输的数据量,提高了传输速度,保证了模型动作的连贯性;并且,由于目标重建数据仅是对初始重建数据下采样后得到的,仅是降低了重建数据的精度,数据仍是完整性,保证了模型的完整性。
S302:将三维模型对应的包围盒等分为各个长方体,分别确定每个长方体对应的第一顶点集合和第二顶点集合。
在计算机图形学与计算几何领域,三维模型的包围盒就是将模型完全包容起来的一个封闭空间。将复杂模型封装在简单的包围盒中,用简单的包围盒形状来近似代替复杂几何体的形状,可以提高几何运算的效率。
如图1所示,外层为三维模型对应的长方体包围盒,对生成的包围盒在X、Y、Z三个方向进行等分,得到若干个大小相同的长方体,每个长方体对应一个唯一的编号。本申请实施例对划分的长方体的数量不做限制性要求,可根据实际情况进行设置。
在本申请的实施例中,将三维模型对应的包围盒等分后,在执行S302时,获取初始重建数据对应的几何模型中的各个第一顶点,根据各个第一顶点的空间坐标,确定各个第一顶点所在的长方体,并根据各个第一顶点所在的长方体,对初始重建数据进行空间几何分割,将同一长方体内的多个第一顶点记为第一顶点集合;以及,获取目标重建数据对应的几何模型中的各个第二顶点,根据各个第二顶点的空间坐标,确定各个第二顶点所在的长方体,并根据各个第二顶点所在的长方体,对目标重建数据进行空间几何分割,将同一长方体内的多个第二顶点记为第二顶点集合。
通过上述空间几何分割过程,每个长方体分别对应一个第一顶点集合和一个第二顶点集合,也就是说,模型顶点的空间几何分割过程,就是按照长方体空间对两个模型的所有顶点进行分类划分。
如图4所示,为一个简单、完整的三维模型,该模型横跨两个用于分割的长方体,且这两个长方体相邻且共面。按照模型顶点的空间几何分割过程可知,通过两个长方体,可以将完整的三维模型分割为两个子模型。具体的,针对同一长方体内的各个第一顶点,重新建立第一顶点间的拓扑关系,得到一个高精度的子模型,以及针对同一长方体内的各个第二顶点,重新建立第二顶点间的拓扑关系,得到一个低精度的子模型。
以图4所示的三维模型为例,三维模型的分割示意图如图5所示,两个相邻的长方体的共有面将三维模型分割为两个独立的子模型。由图5可知,若直接根据分割后的第一顶点集合生成子模型,根据分割后的第二顶点集合生成子模型,这样,分割后两个相同精度的子模型的三角形面片不再连续,在两个子模型中间产生了一条拼接缝隙。
需要说明的是,初始重建数据和目标重建数据的分割过程是分开处理的,互不相干,可充分利用CPU的并行处理能力,处理速度较快。
在VR技术领域中,三维模型通常由三角面片表示,一个三角形面片由模型的三个顶点生成,一个三角形面片包含3条边。在本申请的实施例中,初始重建数据中第一顶点的数量要多于目标重建数据中第二顶点数量,因此,初始重建数据中各个第一顶点生成的三角形面片数量也多于目标重建数据中各个第二顶点生成的三角形面片数量。
S303:遍历初始重建数据中各个第一顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第一交点,并针对每一个第一交点,将该第一交点分别存入该第一交点所在共有面的两个长方体对应的第一顶点集合中。
在执行S303时,初始重建数据中的各个第一顶点生成多个三角形面片,遍历由第一顶点生成的每个三角形面片的边,当遍历的边与相邻的两个长方体的共有面相交时,确定该边与共有面的交点(记为第一交点),并将第一交点的坐标分别存储至共有面的两个长方体对应的第一顶点集合中。
S304:遍历目标重建数据中各个第二顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第二交点,并针对每一个第二交点,将该第二交点分别存入该第二交点所在共有面的两个长方体对应的第二顶点集合中。
在执行S304时,目标重建数据中的各个第二顶点生成多个三角形面片,遍历由第二顶点生成的每个三角形面片的边,当遍历的边与相邻的两个长方体的共有面相交时,确定该边与共有面的交点(记为第一交点),并将第二交点的坐标分别存储至共有面的两个长方体对应的第二顶点集合中。
S305:针对每一个长方体,根据长方体对应的第一顶点集合生成一个第一子模型,以及根据所述长方体对应的第二顶点集合生成一个第二子模型。
在本申请的实施例中,针对每一个长方体,将至少一个第一交点的坐标存储至该长方体对应的第一顶点集合后,重现建立第一顶点集合内各个点之间的第一拓扑关系,并利用该第一拓扑关系,对初始重建数据进行纹理分割,得到该长方体对应的一个第一子模型。同理,针对每一个长方体,将至少一个第二交点的坐标存储至该长方体对应的第二顶点集合后,重现建立第二顶点集合内各个点之间的第二拓扑关系,并利用该第二拓扑关系,对目标重建数据进行纹理分割,得到该长方体对应的一个第二子模型。
由于初始重建数据和目标重建数据的分割过程一致,只不过分割后得到的子模型的精度不一致,因此,以初始重建数据为例,分割后两个独立的第一子模型如图6所示。
在本申请的实施例中,通过第一交点和第二交点更新相应的第一顶点集合和第二顶点集合后,由于共面且相邻的两个长方体各自对应的第一顶点集合中,包含至少一个位置相同的第一交点,因此,分割后的两个高精度的相邻的第一子模型在拼接处可以完重合,从而解决了高精度子模型间的拼接缝隙。同理,由于共面且相邻的两个长方体对应的第二顶点集合中,包含至少一个位置相同的第二交点,因此,分割后的两个低精度的相邻的第二子模型在拼接处可以完重合,从而解决了低精度子模型间的拼接缝隙。
S306:将各个第二子模型的目标重建数据,以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,以使渲染设备根据各个初始重建数据,以及与各个目标子模型不同标识的第二子模型的目标重建数据,渲染所述三维模型并显示。
在实时远程三维通信系统中,渲染设备向云服务器发送数据获取请求,由云服务器转发给采集设备,以使采集设备根据数据获取请求上传重建数据。由于第一子模型和第二子模型的空间大小相同、数量一致,仅在于精度不同,因此,它们的包围盒大小相同、数量一致。
在一种可选的实施方式中,采集设备将各个第二子模型的目标重建数据通过云服务器发送给渲染设备,渲染设备生成各个第二子模型的包围盒,并根据各个包围盒与渲染设备的视景体的空间关系,确定视景体内包含的各个目标子模型的标识,并对各个目标子模型的标识进行优先级的排序,将排序后的各个目标子模型的标识携带在数据获取请求中发送给采集设备。采集设备按照数据获取请求,按照排序后的各个目标子模型的标识,将同标识的第一子模型的初始重建数据依序、独立地发送给渲染设备。渲染设备根据各个目标子模型的初始重建数据,以及与各个目标子模型不同标识的第二子模型的目标重建数据,渲染不同精度的子模型拼接后的三维模型并显示。一方面,由于各个第二子模型的目标重建数据的精度较低,数据量较小,传输速度较快,且各个目标重建数据包含三维模型的完整数据,在渲染设备动作帧率不足时,保证了模型的完整性;另一方面,由于各个第一子模型的初始重建数据精度较高,数据量较大,为了降低数据的传输时延,并不是将各个第一子模型的初始重建数据全部的发送给渲染设备,而是将视野内的各个目标子模型的初始重建数据依序、独立地发送给渲染设备,在现有网络带宽的条件下,可以传输更多目标子模型的初始重建数据,保证了视野内子模型的高精度,提高了模型的显示质量。
需要说明的是,当第一子模型的初始重建数据(包括视野外的子模型)一一发送完成后,相同标识的第二子模型的目标重建数据全部被替换,最终显示的是全部由第一子模型拼接后的高精度的三维模型。
需要说明的是,子模型的优先级顺序,可由采集设备根据三维模型的骨架内各个骨骼节点的预设优先级确定后发送给渲染设备的,还可以由渲染设备根据子模型在视景体内的位置设置的。
在本申请的实施例中,各个目标子模型与不同标识的第二子模型的数据组成一份完整的重建数据,其中,目标子模型的初始重建数据的精度,高于第二子模型的目标重建数据的精度,这样,渲染后的三维模型是由不同精度的子模型拼接成的一个完整三维模型,如图2所示。也就是说,两个相邻子模型的精度可能不同,这会导致拼接处的顶点数目不同,也即两个子模型拼接处顶点无法重合。由于两个子模型相互独立,所以就会产生一条缝隙,如图7所示,白色三角形代表两个相邻的不同精度的子模型间的拼接缝隙。
本申请实施例通过对不同精度的相邻子模型间的缝隙生成三角形面片,来解决不同精度的相邻子模型间的拼接缝隙,具体参见图8:
S3051:确定各个目标子模型在空间上相邻的第二子模型。
在一种可选的实施方式中,采集设备接收到渲染设备发送的数据获取请求后,根据数据获取请求携带的各个目标子模型的标识,确定与各个目标子模型在空间上相邻的第二子模型。
例如,以图1为例,假设数据获取请求中携带的目标子模型的标识为10,根据三维模型的包围盒划分后的各个长方体的编号可知,与目标子模型10在空间上相邻的第二子模型的标识为11。
S3052:获取相邻的目标子模型和第二子模型的切面内的各个交点,各个交点包括第一交点和第二交点。
在本申请的实施例中,按照图3所示的流程,可以解决精度相同的两个相邻子模型间的拼接缝隙,但此时各个子模型的切面为非封闭状态,如图9所示。
通过执行S303,可以获得两个相邻的高精度的第一子模型的切面内的所有第一交点,通过执行S304,可以获得两个相邻的低精度的第二子模型的切面内的所有第二交点。在S3052中,通过查询与目标子模型的标识相同的第一子模型对应的第一顶点集合,以及与目标子模型相邻的第二子模型对应的第二顶点集合,可以得到目标子模型和第二子模型的切面内包含的各个第一交点和各个第二交点。
S3053:根据切面内的各个交点,生成至少一个新的三角形面片,并将至少一个新的三角形面片的数据发送给渲染设备。
在本申请的实施例中,对于相邻的目标子模型与第二子模型之间的拼接缝隙,可以用切面内的各个交点生成的至少一个新的三角形面片覆盖,如图10所示,黑色三角形表示由切面内的各个交点生成的新的三角形面片。
可选的,切面内至少一个新的三角形面片的生成方式包括:选取切面内的一个交点为参考点,将参考点与切面内非相邻的交点逐个连接,生成至少一个新的三角形面片,如图11所示。切面内生成的至少一个新的三角形面片的数量等于切面的边数减2,且切面内生成的至少一个新的三角形面片之间不相交。
在S3053中,生成至少一个新的三角形面片后,针对每一个三角形面片,确定该三角形面片的数据(包括使用交点的坐标和面片的纹理等数据),并发送给渲染设备。
本申请实施例对三角形面片纹理数据的确定方式不做限制性要求,例如,将距离三角形面片的中心点最近的顶点的纹理数据作为该三角形面片的纹理数据。
需要说明的是,本申请实施例对不封闭切面内生成至少一个三角形面片的方式不做限制性要求。例如,针对不封闭的切面,还可以用图12所示的方式生成至少一个三角形面片。
对比图7和图10可知,在不同精度的相邻子模型间的缝隙处,由不封闭的切面内的各个交点生成的三角形面片可以将该裂缝遮盖起来了。
在一些实施例中,生成至少一个新的三角形面片之后,除了将新的三角形面片的数据和各个子模型的数据独立的发送给渲染设备外,还可以将至少一个新的三角形面片和相应的子模型组织为封闭的子模型后,将数据一起发送。具体实施时,首先,将各个目标子模型对应的第一顶点集合和相应的新的三角形面片,生成各个封闭的目标子模型,以及,将各个第二子模型的对应的第二顶点集合和相应的新的三角形面片,生成各个封闭的第二子模型;然后,将各个封闭的第二子模型的第一数据和各个目标子模型的第二数据发送给渲染设备,其中,第一数据包括封闭的第二子模型的目标重建数据以及相应的新的三角形面片的数据,第二数据包括封闭的目标子模型的初始重建数据以及相应的新的三角形面片的数据。
在本申请的实施例中,在不封闭的切面内生成的至少一个新的三角形面片,使得不同精度的相邻子模型均位于不同长方体的封闭空间内,渲染设备在渲染显示三维模型时,不同精度的子模型间的拼接缝隙被覆盖,从而提高了三维模型的显示质量。
需要说明的是,本申请实施例中图3和图8所示的方案可以组合使用,从而在渲染设备显示三维模型时,无论是精度相同的相邻子模型,还是精度不同的相邻子模型,都不会有拼接缝隙,从而提高了三维模型的真实性,进行提高了在实时远程三维通信系统中的沉浸感。
基于相同的技术构思,本申请实施例提供一种采集设备,该采集设备可执行本申请实施例提供的三维模型的显示方法中采集设备侧的流程,并能达到同样的技术效果,在此不再重复。
参见图13该采集设备包括处理器1301、存储器1302和通信接口1303,通信接口1303、存储器1302与处理器1301通过总线1304连接;存储器1302存储有计算机程序,处理器1301根据计算机程序执行以下操作:
对三维模型的初始重建数据进行下采样,得到目标重建数据;三维模型是根据RGBD相机采集的目标对象的深度图像和彩色图像得到的;
将三维模型对应的包围盒等分为各个长方体,分别确定每个长方体对应的第一顶点集合和第二顶点集合,第一顶点集合中的各个第一顶点为初始重建数据中的顶点,第二顶点集合中的各个第二顶点为目标重建数据中的顶点;
遍历初始重建数据中各个第一顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第一交点,并针对每一个第一交点,将第一交点分别存入第一交点所在共有面的两个长方体对应的第一顶点集合中;
遍历目标重建数据中各个第二顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第二交点,并针对每一个第二交点,将第二交点分别存入第二交点所在共有面的两个长方体对应的第二顶点集合中;
针对每一个长方体,根据长方体对应的第一顶点集合生成一个第一子模型,以及根据长方体对应的第二顶点集合生成一个第二子模型;
通过通信接口1303,将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,以使渲染设备根据各个初始重建数据,以及与各个目标子模型不同标识的第二子模型的目标重建数据,渲染三维模型并显示;其中,目标子模型为渲染设备的视景体内的第二子模型,标识是渲染设备根据各个第二子模型的包围盒与视景体的空间关系确定的。
可选的,处理器1301还执行:
确定各个目标子模型在空间上相邻的第二子模型;
获取相邻的目标子模型和第二子模型的切面内的各个交点,各个交点包括第一交点和第二交点;
根据切面内的各个交点,生成至少一个新的三角形面片,并通过通信接口1303,将至少一个新的三角形面片的数据发送给渲染设备,新的三角形面片用于覆盖相邻的目标子模型与第二子模型之间的拼接缝隙。
可选的,生成至少一个新的三角形面片之后,处理器1301还执行:
将各个目标子模型对应的第一顶点集合和相应的新的三角形面片,生成各个封闭的目标子模型,以及,将各个第二子模型的对应的第二顶点集合和相应的新的三角形面片,生成各个封闭的第二子模型;
处理器通过通信接口1303,将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,具体操作为:
通过通信接口1303,将各个封闭的第二子模型的第一数据和各个封闭的目标子模型的第二数据发送给渲染设备,其中,第一数据包括封闭的第二子模型的目标重建数据以及相应的新的三角形面片的数据,第二数据包括与各个封闭的目标子模型同标识的第一子模型的初始重建数据以及相应的新的三角形面片的数据。
可选的,处理器1301根据切面内的各个交点,生成至少一个新的三角形面片,具体操作为:
选取切面内的一个交点为参考点,将参考点与切面内非相邻的交点逐个连接,生成至少一个新的三角形面片。
可选的,切面内生成的至少一个新的三角形面片的数量等于切面的边数减2。
可选的,切面内生成的至少一个新的三角形面片之间不相交。
需要说明的是,图13仅给出了采集设备执行图3和图8所示流程的必要硬件,除此之外,采集设备还包括显示器1305等常规硬件。
本申请实施例还提供一种计算机可读存储介质,用于存储一些指令,这些指令被执行时,可以完成前述实施例的方法。
本申请实施例还提供一种计算机程序产品,用于存储计算机程序,该计算机程序用于执行前述实施例的方法。
最后应说明的是:以上各实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述各实施例对本申请进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本申请各实施例技术方案的范围。
为了方便解释,已经结合具体的实施方式进行了上述说明。但是,上述示例性的讨论不是意图穷尽或者将实施方式限定到上述公开的具体形式。根据上述的教导,可以得到多种修改和变形。上述实施方式的选择和描述是为了更好的解释原理以及实际的应用,从而使得本领域技术人员更好的使用所述实施方式以及适于具体使用考虑的各种不同的变形的实施方式。
Claims (10)
1.一种三维模型的显示方法,其特征在于,应用于采集设备,包括:
对三维模型的初始重建数据进行下采样,得到目标重建数据;所述三维模型是根据RGBD相机采集的目标对象的深度图像和彩色图像得到的;
将所述三维模型对应的包围盒等分为各个长方体,分别确定每个长方体对应的第一顶点集合和第二顶点集合,所述第一顶点集合中的各个第一顶点为所述初始重建数据中的顶点,所述第二顶点集合中的各个第二顶点为所述目标重建数据中的顶点;
遍历所述初始重建数据中各个第一顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第一交点,并针对每一个第一交点,将所述第一交点分别存入所述第一交点所在共有面的两个长方体对应的第一顶点集合中;
遍历所述目标重建数据中各个第二顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第二交点,并针对每一个第二交点,将所述第二交点分别存入所述第二交点所在共有面的两个长方体对应的第二顶点集合中;
针对每一个长方体,根据所述长方体对应的第一顶点集合生成一个第一子模型,以及根据所述长方体对应的第二顶点集合生成一个第二子模型;
将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,以使所述渲染设备根据各个初始重建数据,以及与所述各个目标子模型不同标识的第二子模型的目标重建数据,渲染所述三维模型并显示;其中,所述目标子模型为所述渲染设备的视景体内的第二子模型,所述标识是所述渲染设备根据所述各个第二子模型的包围盒与所述视景体的空间关系确定的。
2.如权利要求1所述的方法,其特征在于,所述方法还包括:
确定所述各个目标子模型在空间上相邻的第二子模型;
获取相邻的目标子模型和第二子模型的切面内的各个交点,所述各个交点包括第一交点和第二交点;
根据所述切面内的各个交点,生成至少一个新的三角形面片,并将所述至少一个新的三角形面片的数据发送给所述渲染设备,所述新的三角形面片用于覆盖相邻的目标子模型与第二子模型之间的拼接缝隙。
3.如权利要求2所述的方法,其特征在于,生成至少一个新的三角形面片之后,所述方法还包括:
将所述各个目标子模型对应的第一顶点集合和相应的新的三角形面片,生成各个封闭的目标子模型,以及,将所述各个第二子模型的对应的第二顶点集合和相应的新的三角形面片,生成各个封闭的第二子模型;
所述将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,包括:
将各个封闭的第二子模型的第一数据和各个封闭的目标子模型的第二数据发送给渲染设备,所述第一数据包括封闭的第二子模型的目标重建数据以及相应的新的三角形面片的数据,所述第二数据包括与各个封闭的目标子模型同标识的第一子模型的初始重建数据以及相应的新的三角形面片的数据。
4.如权利要求2或3所述的方法,其特征在于,所述根据所述切面内的各个交点,生成至少一个新的三角形面片,包括:
选取所述切面内的一个交点为参考点,将所述参考点与所述切面内非相邻的交点逐个连接,生成至少一个新的三角形面片。
5.如权利要求2或3所述的方法,其特征在于,所述切面内生成的至少一个新的三角形面片的数量等于所述切面的边数减2。
6.如权利要求2或3所述的方法,其特征在于,所述切面内生成的至少一个新的三角形面片之间不相交。
7.一种采集设备,其特征在于,包括处理器、存储器和通信接口,所述存储器、所述通信接口与所述处理器通过总线连接;
所述存储器存储有计算机程序,所述处理器根据所述计算机程序执行以下操作:
对三维模型的初始重建数据进行下采样,得到目标重建数据;所述三维模型是根据RGBD相机采集的目标对象的深度图像和彩色图像得到的;
将所述三维模型对应的包围盒等分为各个长方体,分别确定每个长方体对应的第一顶点集合和第二顶点集合,所述第一顶点集合中的各个第一顶点为所述初始重建数据中的顶点,所述第二顶点集合中的各个第二顶点为所述目标重建数据中的顶点;
遍历所述初始重建数据中各个第一顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第一交点,并针对每一个第一交点,将所述第一交点分别存入所述第一交点所在共有面的两个长方体对应的第一顶点集合中;
遍历所述目标重建数据中各个第二顶点生成的三角形面片的边,确定各个边与相应长方体共有面的第二交点,并针对每一个第二交点,将所述第二交点分别存入所述第二交点所在共有面的两个长方体对应的第二顶点集合中;
针对每一个长方体,根据所述长方体对应的第一顶点集合生成一个第一子模型,以及根据所述长方体对应的第二顶点集合生成一个第二子模型;
通过所述通信接口,将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模型的初始重建数据发送给渲染设备,以使所述渲染设备根据各个初始重建数据,以及与所述各个目标子模型不同标识的第二子模型的目标重建数据,渲染所述三维模型并显示;所述目标子模型为所述渲染设备的视景体内的第二子模型,所述标识是所述渲染设备根据所述各个第二子模型的包围盒与所述视景体的空间关系确定的。
8.如权利要求7所述的采集设备,其特征在于,所述处理器还执行:
确定所述各个目标子模型在空间上相邻的第二子模型;
获取相邻的目标子模型和第二子模型的切面内的各个交点,所述各个交点包括第一交点和第二交点;
根据所述切面内的各个交点,生成至少一个新的三角形面片,并将所述至少一个新的三角形面片的数据发送给所述渲染设备,所述新的三角形面片用于覆盖相邻的目标子模型与第二子模型之间的拼接缝隙。
9.如权利要求8所述的采集设备,其特征在于,所述生成至少一个新的三角形面片之后,所述处理器还执行:
将所述各个目标子模型对应的第一顶点集合和相应的新的三角形面片,生成各个封闭的目标子模型,以及,将所述各个第二子模型的对应的第二顶点集合和相应的新的三角形面片,生成各个封闭的第二子模型;
所述处理器将各个第二子模型的目标重建数据以及与各个目标子模型同标识的第一子模的初始重建数据发送给渲染设备,具体操作为:
将各个封闭的第二子模型的第一数据和各个封闭的目标子模型的第二数据发送给渲染设备,所述第一数据包括封闭的第二子模型的目标重建数据以及相应的新的三角形面片的数据,所述第二数据包括与各个封闭的目标子模型同标识的第一子模型的初始重建数据以及相应的新的三角形面片的数据。
10.如权利要求8或9所述的采集设备,其特征在于,所述处理器根据所述切面内的各个交点,生成至少一个新的三角形面片,具体操作为:
选取所述切面内的一个交点为参考点,将所述参考点与所述切面内非相邻的交点逐个连接,生成至少一个新的三角形面片。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111526075.XA CN114359504B (zh) | 2021-12-14 | 2021-12-14 | 一种三维模型的显示方法及采集设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202111526075.XA CN114359504B (zh) | 2021-12-14 | 2021-12-14 | 一种三维模型的显示方法及采集设备 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN114359504A CN114359504A (zh) | 2022-04-15 |
CN114359504B true CN114359504B (zh) | 2024-05-03 |
Family
ID=81099938
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202111526075.XA Active CN114359504B (zh) | 2021-12-14 | 2021-12-14 | 一种三维模型的显示方法及采集设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN114359504B (zh) |
Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5886702A (en) * | 1996-10-16 | 1999-03-23 | Real-Time Geometry Corporation | System and method for computer modeling of 3D objects or surfaces by mesh constructions having optimal quality characteristics and dynamic resolution capabilities |
CN104574515A (zh) * | 2013-10-09 | 2015-04-29 | 华为技术有限公司 | 一种三维物体重建的方法、装置和终端 |
CN110458932A (zh) * | 2018-05-07 | 2019-11-15 | 阿里巴巴集团控股有限公司 | 图像处理方法、装置、系统、存储介质和图像扫描设备 |
CN110458950A (zh) * | 2019-08-14 | 2019-11-15 | 首都医科大学附属北京天坛医院 | 一种三维模型重建方法、移动终端、存储介质及电子设备 |
CN113706713A (zh) * | 2021-09-02 | 2021-11-26 | 刘旭 | 一种实景三维模型裁剪方法、装置及计算机设备 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11450030B2 (en) * | 2019-09-24 | 2022-09-20 | Apple Inc. | Three-dimensional mesh compression using a video encoder |
-
2021
- 2021-12-14 CN CN202111526075.XA patent/CN114359504B/zh active Active
Patent Citations (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5886702A (en) * | 1996-10-16 | 1999-03-23 | Real-Time Geometry Corporation | System and method for computer modeling of 3D objects or surfaces by mesh constructions having optimal quality characteristics and dynamic resolution capabilities |
CN104574515A (zh) * | 2013-10-09 | 2015-04-29 | 华为技术有限公司 | 一种三维物体重建的方法、装置和终端 |
CN110458932A (zh) * | 2018-05-07 | 2019-11-15 | 阿里巴巴集团控股有限公司 | 图像处理方法、装置、系统、存储介质和图像扫描设备 |
CN110458950A (zh) * | 2019-08-14 | 2019-11-15 | 首都医科大学附属北京天坛医院 | 一种三维模型重建方法、移动终端、存储介质及电子设备 |
CN113706713A (zh) * | 2021-09-02 | 2021-11-26 | 刘旭 | 一种实景三维模型裁剪方法、装置及计算机设备 |
Non-Patent Citations (1)
Title |
---|
新颖的网格模型压缩算法――网格切片;何辰;王磊;王春萌;;计算机应用;20160210(02);262-266 * |
Also Published As
Publication number | Publication date |
---|---|
CN114359504A (zh) | 2022-04-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9704282B1 (en) | Texture blending between view-dependent texture and base texture in a geographic information system | |
CN106919733B (zh) | 用于设计建模对象的3d组装的方法、装置、介质和系统 | |
KR20110090958A (ko) | 이미지 속성들에 대한 오클루젼 데이터의 생성 | |
US11830148B2 (en) | Reconstruction of essential visual cues in mixed reality applications | |
CN109920043B (zh) | 虚拟3d对象的立体渲染 | |
TWI225224B (en) | Apparatus, system, and method for draping annotations on to a geometric surface | |
GB2406252A (en) | Generation of texture maps for use in 3D computer graphics | |
CN114863014B (zh) | 一种三维模型的融合显示方法及设备 | |
AU2020449562B2 (en) | Geometry-aware augmented reality effects with a real-time depth map | |
CN113592994B (zh) | 用于纹理贴图的方法、装置和存储介质 | |
Takai et al. | Harmonised texture mapping | |
CN114359504B (zh) | 一种三维模型的显示方法及采集设备 | |
WO2020184174A1 (ja) | 画像処理装置および画像処理方法 | |
CN115965735B (zh) | 纹理贴图的生成方法和装置 | |
CN109816765B (zh) | 面向动态场景的纹理实时确定方法、装置、设备和介质 | |
JP2019149112A (ja) | 合成装置、方法及びプログラム | |
CN114373057A (zh) | 一种头发与头部模型的匹配方法及设备 | |
Borshukov | New algorithms for modeling and rendering architecture from photographs | |
KR20060114708A (ko) | 3차원 모델을 스케일링하는 스케일링 유닛 및 방법 | |
Sasaki et al. | Efficient virtual view rendering by merging pre-rendered RGB-D data from multiple cameras | |
Hosseinpour et al. | View synthesis for FTV systems based on a minimum spatial distance and correspondence field | |
CN116188670A (zh) | 一种三维模型的显示方法及设备 | |
US10453247B1 (en) | Vertex shift for rendering 360 stereoscopic content | |
JPH02103687A (ja) | 3次元図形処理方法及びその装置 | |
CN115619916A (zh) | 一种渲染方法、装置和设备 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
GR01 | Patent grant | ||
GR01 | Patent grant |