CN107031033B - 一种可3d打印的镂空二维码模型生成方法及*** - Google Patents
一种可3d打印的镂空二维码模型生成方法及*** Download PDFInfo
- Publication number
- CN107031033B CN107031033B CN201710326073.3A CN201710326073A CN107031033B CN 107031033 B CN107031033 B CN 107031033B CN 201710326073 A CN201710326073 A CN 201710326073A CN 107031033 B CN107031033 B CN 107031033B
- Authority
- CN
- China
- Prior art keywords
- code
- image
- area
- dimensional
- dimensional surface
- 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
Classifications
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B33—ADDITIVE MANUFACTURING TECHNOLOGY
- B33Y—ADDITIVE MANUFACTURING, i.e. MANUFACTURING OF THREE-DIMENSIONAL [3-D] OBJECTS BY ADDITIVE DEPOSITION, ADDITIVE AGGLOMERATION OR ADDITIVE LAYERING, e.g. BY 3-D PRINTING, STEREOLITHOGRAPHY OR SELECTIVE LASER SINTERING
- B33Y30/00—Apparatus for additive manufacturing; Details thereof or accessories therefor
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B33—ADDITIVE MANUFACTURING TECHNOLOGY
- B33Y—ADDITIVE MANUFACTURING, i.e. MANUFACTURING OF THREE-DIMENSIONAL [3-D] OBJECTS BY ADDITIVE DEPOSITION, ADDITIVE AGGLOMERATION OR ADDITIVE LAYERING, e.g. BY 3-D PRINTING, STEREOLITHOGRAPHY OR SELECTIVE LASER SINTERING
- B33Y50/00—Data acquisition or data processing for additive manufacturing
- B33Y50/02—Data acquisition or data processing for additive manufacturing for controlling or regulating additive manufacturing processes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06K—GRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
- G06K19/00—Record carriers for use with machines and with at least a part designed to carry digital markings
- G06K19/06—Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
- G06K19/06009—Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
- G06K19/06037—Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking multi-dimensional coding
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06K—GRAPHICAL DATA READING; PRESENTATION OF DATA; RECORD CARRIERS; HANDLING RECORD CARRIERS
- G06K19/00—Record carriers for use with machines and with at least a part designed to carry digital markings
- G06K19/06—Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code
- G06K19/06009—Record carriers for use with machines and with at least a part designed to carry digital markings characterised by the kind of the digital marking, e.g. shape, nature, code with optically detectable marking
- G06K19/06046—Constructional details
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Chemical & Material Sciences (AREA)
- Manufacturing & Machinery (AREA)
- Materials Engineering (AREA)
- Processing Or Creating Images (AREA)
- Image Generation (AREA)
Abstract
本发明公开了一种可3D打印的镂空二维码模型生成方法及***,其中该方法包括:输入二维码图像,对镂空区域进行连通性处理,得到连通图像Ic;其中,二维码图像的白色区域为镂空区域,黑色区域为非镂空区域;根据连通图像Ic中每个像素的颜色值,生成映射到单位面积的二维表面网格S;对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M。
Description
技术领域
本发明涉及面向3D打印的几何模型定制领域,尤其涉及一种可3D打印的镂空二维码模型生成方法及***。
背景技术
二维码,又称快速响应码,使用黑白矩形图案表示二进制数据,通过扫描设备可解码获得二维码中包含的信息。近年来,二维码技术日益成熟,尤其对于矩阵式二维码,由于其具有信息容量大、保密性高、容错纠错能力强、译码可靠性高、尺寸可调、制作成本较低等的优点,它已经被广泛的应用于信息检索、信息通讯、电子凭证、广告媒体等领域,并且逐渐渗透进人们的生活当中。
3D打印,又称增材制造,常见的3D打印指在计算机的控制下层叠原材料,制作三维物体的过程。随着3D打印技术的迅速发展,打印精度与打印速度逐渐提高,3D打印设备与打印材料的价格逐渐降低,3D打印也被广泛的应用于各个领域。
近年来,大量出现纸质二维码暴露出了容易破损、不耐用不环保、易于伪造安全性较低的问题,常见的动态二维码又具有对电子设备与信息安全的依赖性较高的问题。相比以上两种二维码,3D打印二维码具有独立成型、不易更改、不易损坏且使用持久等优点。鉴于3D打印技术的成熟与以上原因,目前已经出现了可3D打印的二维码三维几何模型生成技术,即通过对二维码黑色区域沿面法向量向正方向拉升或向反方向凹陷生成浮雕形式的二维码三维几何模型,因此输入模型都具有厚重的底部,对打印材料的耗费较高。除此之外,现有方法生成的二维码模型在3D打印时,对于模型的底部区域与模型的上浮二维码区域需要两种颜色对比较强的打印材料进行打印,才能保证打印结果能有效的被机器识别并成功解码。
然而,生成二维码模型的现有技术存在以下缺陷:
(1)现存技术生成的二维码模型无法作为较普遍的单一材料3D打印机的输入模型。
(2)由于二维码图像存在大量独立不连通的区域,根据二维码图像生成对应的可3D打印可扫描的镂空二维码模型的问题仍待解决。
发明内容
为了解决现有技术的不足,本发明提供了一种可3D打印的镂空二维码模型生成方法,该方法通过用户输入的二维码图像,考虑到3D打印机精度生成相对应的镂空二维码模型,用于单一材料3D打印机的输入模型,最终可打印得到可以扫描并能成功被解码的立体镂空二维码。
本发明的一种可3D打印的镂空二维码模型生成方法,包括:
输入二维码图像,对镂空区域进行连通性处理,得到连通图像Ic;其中,二维码图像的白色区域为镂空区域,黑色区域为非镂空区域;
根据连通图像Ic中每个像素的颜色值,生成映射到单位面积的二维表面网格S;
对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M。
进一步的,对镂空区域进行连通性处理之前,还包括:
对二维码图像进行阈值预处理,遍历二维码图像并标记所有不同的独立白色区域。
本发明通过对二维码图像阈值预处理,再对预阈值后的二维码图像进行独立区域的检测,能够准确得到二维码图像信息,最终提高了连通性处理的精度。
进一步的,对镂空区域进行连通性处理的具体过程包括:
遍历二维码图像的所有不同的独立白色区域,使用白色直线连接二维码图像中距离最近的两个独立的白色区域,将两个白色区域合并为同一个区域;
检测二维码图像的独立白色区域个数是否大于1,若是,则返回上一步;否则,结束连通化处理过程,得到连通图像Ic。
本发明对任意的二维码图像进行独立区域检测与连通性处理,得到白色区域连通的二维码图像,并据此生成准确地相对应的镂空二维码表面网格,最终得到连通的符合要求的镂空二维码模型。
进一步的,生成映射到单位面积的二维表面网格S的具体过程包括:
根据扫描线算法,顺序遍历连通图像Ic中的每个像素,其中,连通图像Ic的像素为n×n;
若第y+1行且第x+1列的像素颜色为白色,则记为P(x,y)=1;否则,记为P(x,y)=0,得到标记集合P,其中,1≤x≤n,n为正整数;
遍历标记集合P,若P(x,y)=1,则添加v0((x-1)/n,(y-1)/n)、v1(x/n,(y-1)/n)、v2((x-1)/n,y/n)和v3(x/n,y/n)这四个顶点,分别添加连接v0与v1、v1与v2、v2与v3、v3与v0提及v0与v2的边,若边已存在,则不添加,得到连通图像Ic映射到单位面积的二维表面网格S。
其中,标记集合P与镂空表面网格成线性映射关系。
进一步的,对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M的具体过程包括:
遍历二维表面网格S的镂空区域,查找到面积最小的镂空区域,并对其求最大内接圆,得到内接圆直径d,计算得到放大倍数m1=ω/d,其中,ω为3D打印机精度;
根据白色直线的宽度w,计算得到放大倍数m2=ω/w;若m1>m2,则将二维表面网格S放大m1倍,否则,放大m2倍;
将放大后的二维表面网格S按照面法向量,即沿着z轴正方向延伸kω距离,打印出三维镂空模型M,其中,k≥1。
其中,k为用户根据需要自定义的打印厚度倍数。
本发明的第二目的是提供一种可3D打印的镂空二维码模型生成***。
本发明的一种可3D打印的镂空二维码模型生成***,包括:
图像连通性处理模块,其用于输入二维码图像,对镂空区域进行连通性处理,得到连通图像Ic;其中,二维码图像的白色区域为镂空区域,黑色区域为非镂空区域;
二维表面网格映射模块,其用于根据连通图像Ic中每个像素的颜色值,生成映射到单位面积的二维表面网格S;
二维表面网格放大及打印模块,其用于对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M。
进一步的,该***还包括:
图像预处理模块,其用于对二维码图像进行阈值预处理,遍历二维码图像并标记所有不同的独立白色区域。
进一步的,所述图像连通性处理模块包括:
白色区域遍历模块,其用于遍历二维码图像的所有不同的独立白色区域,使用白色直线连接二维码图像中距离最近的两个独立的白色区域,将两个白色区域合并为同一个区域;
连通图像生成模块,其用于检测二维码图像的独立白色区域个数是否大于1,若是,则返回上一步;否则,结束连通化处理过程,得到连通图像Ic。
进一步的,所述二维表面网格映射模块包括:
扫描模块,其用于根据扫描线算法,顺序遍历连通图像Ic中的每个像素,其中,连通图像Ic的像素为n×n;若第y+1行且第x+1列的像素颜色为白色,则记为P(x,y)=1;否则,记为P(x,y)=0,得到标记集合P,其中,1≤x≤n,n为正整数;
标记集合遍历模块,其用于遍历标记集合P,若P(x,y)=1,则添加v0((x-1)/n,(y-1)/n)、v1(x/n,(y-1)/n)、v2((x-1)/n,y/n)和v3(x/n,y/n)这四个顶点,分别添加连接v0与v1、v1与v2、v2与v3、v3与v0提及v0与v2的边,若边已存在,则不添加,得到连通图像Ic映射到单位面积的二维表面网格S。
进一步的,所述二维表面网格放大及打印模块包括:
放大倍数计算模块,其用于遍历二维表面网格S的镂空区域,查找到面积最小的镂空区域,并对其求最大内接圆,得到内接圆直径d,计算得到放大倍数m1=ω/d,其中,ω为3D打印机精度;根据白色直线的宽度w,计算得到放大倍数m2=ω/w;若m1>m2,则将二维表面网格S放大m1倍,否则,放大m2倍;
z轴延伸及打印模块,其用于将放大后的二维表面网格S按照面法向量,即沿着z轴正方向延伸kω距离,打印出三维镂空模型M,其中,k≥1。
与现有技术相比,本发明的有益效果是:
(1)本发明将二维码图像分成镂空区域和非镂空区域,并对其进行处理,不但能满足常见的单一材料打印结果可扫描并成功解码,与浮雕式二维码相比还在降低材料耗费、减少打印时间、节省制作成本、环境保护等方面具有显著优势。
(2)本发明的该方法对任意的二维码图像进行独立区域检测与连通性处理,得到白色区域连通的二维码图像,并据此生成对应的镂空二维码表面网格,进而得到连通的镂空二维码模型。
(3)本发明的该方法根据不同3D打印机的精度可自动生成合适大小的可3D打印的三维镂空二维码模型。
(4)本发明的该方法得到的模型可直接进行3D打印,采用3D打印机即可完成,对于打印材料属性没有要求,所需打印材料和打印时间较少,成型成本较低。3D打印结果可扫描并能被成功解码,不易破损,使用周期较长,具有一定的环保价值。
附图说明
构成本申请的一部分的说明书附图用来提供对本申请的进一步理解,本申请的示意性实施例及其说明用于解释本申请,并不构成对本申请的不当限定。
图1为本发明的可3D打印的镂空二维码模型生成方法流程图;
图2为对输入的二维码图像进行第一次白色独立区域检测结果图;
图3(a)为遍历独立白色区域后,得到的距离最近两区域即区域1与区域2;
图3(b)为以宽度为2像素的白色直线连接距离最近的两区域的示意图;
图4(a)为输入的二维码图像I;
图4(b)为对输入的二维码图像I进行连通性处理后的结果图Ic;
图4(c)为输入的二维码图像I与连通性处理结果图Ic的差异图;
图5(a)为根据通性处理结果图Ic特写部分的标记集合P示意图
图5(b)为根据图5(a)所示的标记集合生成的表面网格;
图6为生成的表面网格S;
图7为生成的三维镂空模型M及其3D打印的实物模型;
图8为本发明的可3D打印的镂空二维码模型生成***的结构示意图;
图9为图像连通性处理模块的结构示意图;
图10为二维表面网格映射模块的结构示意图;
图11为二维表面网格放大及打印模块的结构示意图。
具体实施方式
应该指出,以下详细说明都是例示性的,旨在对本申请提供进一步的说明。除非另有指明,本文使用的所有技术和科学术语具有与本申请所属技术领域的普通技术人员通常理解的相同含义。
需要注意的是,这里所使用的术语仅是为了描述具体实施方式,而非意图限制根据本申请的示例性实施方式。如在这里所使用的,除非上下文另外明确指出,否则单数形式也意图包括复数形式,此外,还应当理解的是,当在本说明书中使用术语“包含”和/或“包括”时,其指明存在特征、步骤、操作、器件、组件和/或它们的组合。
图1为本发明的可3D打印的镂空二维码模型生成方法流程图。
本实施例中,采用I表示用户输入的二维码二值图像,如附图4(a)所示。
如附图4(b)所示,Ic表示连通性处理后的二维码图像,ω表示来自用户3D打印机打印精度的参数,首先生成的二维表面网格S时的横、纵坐标都归一化到[0,1]范围内,然后对二维表面网格S进行调整并挤出,得到可3D打印的三维镂空二维码模型M。
如图1所示,本发明的一种可3D打印的镂空二维码模型生成方法,包括:
步骤(1):输入二维码图像,对镂空区域进行连通性处理,得到连通图像Ic;其中,二维码图像的白色区域为镂空区域,黑色区域为非镂空区域。
其中,对镂空区域进行连通性处理之前,还包括:
对二维码图像进行阈值预处理,遍历二维码图像并标记所有不同的独立白色区域。
具体地,对输入二维码图像I的每个像素通过扫描线算法,从上到下,从左到右进行遍历,并采用以下公式进行全局阈值预处理:
其中,以图像左上角为原点,I(x,y)表示图像某一坐标位置下的像素颜色,I′(x,y)表示处理后该像素颜色,对应为第y+1行,第x+1列对应的像素颜色,1表示白色,0表示黑色,T为阈值。
对预阈值后的二维码图像进行独立区域的检测,通过种子填充法的连通区域分析方法确定不同的独立白色区域,下面给出分析方法:
a.初始化不同区域的标记值label=1;
b.对图像中像素按扫描线算法进行遍历,直到I(x,y)=1;
c.若该点没有被标记,将该点作为种子,并赋予一个label标记值,然后将4领域相邻的色值为1的像素都压入栈中;
d.将栈顶像素赋予相同标记值后弹出,将与弹出栈顶像素4领域相邻的色值为1的像素都压入栈中;
e.重复步骤d直到栈为空,更改标记值label=label+1,若图像遍历未结束,回到步骤b,否则结束分析算法,得到不同独立白色区域,如附图2所示,图2中的不同色值的灰色区域表示不同的独立白色区域。
本发明通过对二维码图像阈值预处理,再对预阈值后的二维码图像进行独立区域的检测,能够准确得到二维码图像信息,最终提高了连通性处理的精度。
其中,对镂空区域进行连通性处理的具体过程包括:
步骤(1.1):遍历二维码图像的所有不同的独立白色区域,使用白色直线连接二维码图像中距离最近的两个独立的白色区域,将两个白色区域合并为同一个区域。
具体地,两区域间的距离通过,遍历属于两个不同区域边界上的像素,根据以下公式计算它们之间的距离dI,并取最小值得到,并以距离最小的两个像素点作为终点与起点,以宽度为w的白色直线相连接,为保证处理后的二维码图像可扫描连接线宽度w小于等于0.8倍定位标记的线框宽度,如附图3(a)和图3(b)所示;
其中,图3(a)表示遍历独立白色区域后,得到的距离最近两区域即区域1与区域2,灰色像素点表示连接线的起点与终点;
图3(b)表示以宽度为2像素的白色直线连接距离最近的两区域的示意图,黑框表示连接线轮廓。
其中,dI为位于两区域边界上的像素值之间的距离,以图像左上角为原点,x1y1和x2y2分别代表位于两区域边界上的像素值对应坐标。
步骤(1.2):检测二维码图像的独立白色区域个数是否大于1,若是,则返回上一步;否则,结束连通化处理过程,得到连通图像Ic。
具体地,通过种子填充法的连通区域分析二维码图像后,若label≥1表示图像的独立白色区域个数大于1,则返回步骤(1.1),否则,结束连通化处理过程,得到白色区域连通的二维码图像Ic,如附图4(b)所示。
本发明对任意的二维码图像进行独立区域检测与连通性处理,得到白色区域连通的二维码图像,并据此生成准确地相对应的镂空二维码表面网格,最终得到连通的符合要求的镂空二维码模型。
步骤(2):根据连通图像Ic中每个像素的颜色值,生成映射到单位面积的二维表面网格S。
具体地,生成映射到单位面积的二维表面网格S的具体过程包括:
步骤(2.1):根据扫描线算法,顺序遍历连通图像Ic中的每个像素,其中,连通图像Ic的像素为n×n;
若第y+1行且第x+1列的像素颜色为白色,则记为P(x,y)=1;否则,记为P(x,y)=0,得到标记集合P,其中,1≤x≤n,n为正整数。
在具体实施过程中,根据扫描线算法,从左到右,从上到下的遍历n×n像素的图像Ic中的每个像素,若第y+1行,第x+1列的像素颜色为白色记P(x,y)=1,否则记为P(x,y)=0,得到标记集合P,图像特写部分的标记如附图5(a)所示;
步骤(2.2):遍历标记集合P,若P(x,y)=1,则添加v0((x-1)/n,(y-1)/n)、v1(x/n,(y-1)/n)、v2((x-1)/n,y/n)、v3(x/n,y/n)四个顶点,分别添加连接v0与v1,v1与v2,v2与v3,v3与v0,v0与v2的边,若边已存在则不添加,得到通过连通二维码图像Ic生成的映射到单位面积的二维表面网格S,结果网格部分特写如附图5(b)所示,得到的表面网格如附图6所示。
其中,标记集合P与镂空表面网格成线性映射关系。
步骤(3):对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M。
具体地,对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M的具体过程包括:
步骤(3.1):遍历二维表面网格S的镂空区域,查找到面积最小的镂空区域,并对其求最大内接圆,得到内接圆直径d,计算得到放大倍数m1=ω/d,其中,ω为3D打印机精度;
根据白色直线的宽度w,计算得到放大倍数m2=ω/d;若m1>m2,则将二维表面网格S放大m1倍,否则,放大m2倍;
步骤(3.2):将放大后的二维表面网格S按照面法向量,即沿着z轴正方向延伸kω距离,打印出三维镂空模型M,其中,k≥1。
其中k为用户根据需要自定义的打印厚度倍数,得到的可3D打印镂空模型M如附图7所示。
本发明将二维码图像分成镂空区域和非镂空区域,并对其进行处理,不但能满足常见的单一材料打印结果可扫描并成功解码,与浮雕式二维码相比还在降低材料耗费、减少打印时间、节省制作成本、环境保护等方面具有显著优势。
本发明的该方法对任意的二维码图像进行独立区域检测与连通性处理,得到白色区域连通的二维码图像,并据此生成对应的镂空二维码表面网格,进而得到连通的镂空二维码模型。
本发明的该方法根据不同3D打印机的精度可自动生成合适大小的可3D打印的三维镂空二维码模型。
本发明的该方法得到的模型可直接进行3D打印,采用3D打印机即可完成,对于打印材料属性没有要求,所需打印材料和打印时间较少,成型成本较低。3D打印结果可扫描并能被成功解码,不易破损,使用周期较长,具有一定的环保价值。
图8是本发明的可3D打印的镂空二维码模型生成***的结构示意图。
如图8所示,本发明的一种可3D打印的镂空二维码模型生成***,包括:
(1)图像连通性处理模块,其用于输入二维码图像,对镂空区域进行连通性处理,得到连通图像Ic;其中,二维码图像的白色区域为镂空区域,黑色区域为非镂空区域。
如图9所示,所述图像连通性处理模块包括:
(1.1)白色区域遍历模块,其用于遍历二维码图像的所有不同的独立白色区域,使用白色直线连接二维码图像中距离最近的两个独立的白色区域,将两个白色区域合并为同一个区域;
(1.2)连通图像生成模块,其用于检测二维码图像的独立白色区域个数是否大于1,若是,则返回上一步;否则,结束连通化处理过程,得到连通图像Ic。
(2)二维表面网格映射模块,其用于根据连通图像Ic中每个像素的颜色值,生成映射到单位面积的二维表面网格S。
如图10所示,所述二维表面网格映射模块包括:
(2.1)扫描模块,其用于根据扫描线算法,顺序遍历连通图像Ic中的每个像素,其中,连通图像Ic的像素为n×n;若第y+1行且第x+1列的像素颜色为白色,则记为P(x,y)=1;否则,记为P(x,y)=0,得到标记集合P,其中,1≤x≤n,n为正整数;
(2.2)标记集合遍历模块,其用于遍历标记集合P,若P(x,y)=1,则添加v0((x-1)/n,(y-1)/n)、v1(x/n,(y-1)/n)、v2((x-1)/n,y/n)和ν3(x/n,y/n)这四个顶点,分别添加连接v0与v1、v1与v2、v2与v3、v3与v0提及v0与v2的边,若边已存在,则不添加,得到连通图像Ic映射到单位面积的二维表面网格S。
(3)二维表面网格放大及打印模块,其用于对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M。
如图11所示,所述二维表面网格放大及打印模块包括:
(3.1)放大倍数计算模块,其用于遍历二维表面网格S的镂空区域,查找到面积最小的镂空区域,并对其求最大内接圆,得到内接圆直径d,计算得到放大倍数m1=ω/d,其中,ω为3D打印机精度;根据白色直线的宽度w,计算得到放大倍数m2=ω/w;若m1>m2,则将二维表面网格S放大m1倍,否则,放大m2倍;
(3.2)z轴延伸及打印模块,其用于将放大后的二维表面网格S按照面法向量,即沿着z轴正方向延伸kω距离,打印出三维镂空模型M,其中,k≥1。
其中,该***还包括:
(4)图像预处理模块,其用于对二维码图像进行阈值预处理,遍历二维码图像并标记所有不同的独立白色区域。
本发明将二维码图像分成镂空区域和非镂空区域,并对其进行处理,不但能满足常见的单一材料打印结果可扫描并成功解码,与浮雕式二维码相比还在降低材料耗费、减少打印时间、节省制作成本、环境保护等方面具有显著优势。
本发明对任意的二维码图像进行独立区域检测与连通性处理,得到白色区域连通的二维码图像,并据此生成对应的镂空二维码表面网格,进而得到连通的镂空二维码模型。
本发明根据不同3D打印机的精度可自动生成合适大小的可3D打印的三维镂空二维码模型。
本发明得到的模型可直接进行3D打印,采用3D打印机即可完成,对于打印材料属性没有要求,所需打印材料和打印时间较少,成型成本较低。3D打印结果可扫描并能被成功解码,不易破损,使用周期较长,具有一定的环保价值。
上述虽然结合附图对本发明的具体实施方式进行了描述,但并非对本发明保护范围的限制,所属领域技术人员应该明白,在本发明的技术方案的基础上,本领域技术人员不需要付出创造性劳动即可做出的各种修改或变形仍在本发明的保护范围以内。
Claims (4)
1.一种可3D打印的镂空二维码模型生成方法,其特征在于,包括:
输入二维码图像,对镂空区域进行连通性处理,得到连通图像Ic;其中,二维码图像的白色区域为镂空区域,黑色区域为非镂空区域;
所述对镂空区域进行连通性处理的具体过程包括:
遍历二维码图像的所有不同的独立白色区域,使用白色直线连接二维码图像中距离最近的两个独立的白色区域,将两个白色区域合并为同一个区域;
检测二维码图像的独立白色区域个数是否大于1,若是,则返回上一步;否则,结束连通化处理过程,得到连通图像Ic;
根据连通图像Ic中每个像素的颜色值,生成映射到单位面积的二维表面网格S;
所述生成映射到单位面积的二维表面网格S的具体过程包括:
根据扫描线算法,顺序遍历连通图像Ic中的每个像素,其中,连通图像Ic的像素为n×n;
若第y+1行且第x+1列的像素颜色为白色,则记为P(x,y)=1;否则,记为P(x,y)=0,得到标记集合P,其中,1≤x≤n,n为正整数;
遍历标记集合P,若P(x,y)=1,则添加v0((x-1)/n,(y-1)/n)、v1(x/n,(y-1)/n)、v2((x-1)/n,y/n)和v3(x/n,y/n)这四个顶点,分别添加连接v0与v1、v1与v2、v2与v3、v3与v0提及v0与v2的边,若边已存在,则不添加,得到连通图像Ic映射到单位面积的二维表面网格S;
对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M;
所述对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M的具体过程包括:
遍历二维表面网格S的镂空区域,查找到面积最小的镂空区域,并对其求最大内接圆,得到内接圆直径d,计算得到放大倍数m1=ω/d,其中,ω为3D打印机精度;
根据白色直线的宽度w,计算得到放大倍数m2=ω/w;若m1>m2,则将二维表面网格S放大m1倍,否则,放大m2倍;
将放大后的二维表面网格S按照面法向量,即沿着z轴正方向延伸kω距离,打印出三维镂空模型M,其中,k≥1。
2.如权利要求1所述的一种可3D打印的镂空二维码模型生成方法,其特征在于,对镂空区域进行连通性处理之前,还包括:
对二维码图像进行阈值预处理,遍历二维码图像并标记所有不同的独立白色区域。
3.一种可3D打印的镂空二维码模型生成***,其特征在于,包括:
图像连通性处理模块,其用于输入二维码图像,对镂空区域进行连通性处理,得到连通图像Ic;其中,二维码图像的白色区域为镂空区域,黑色区域为非镂空区域;
所述图像连通性处理模块包括:
白色区域遍历模块,其用于遍历二维码图像的所有不同的独立白色区域,使用白色直线连接二维码图像中距离最近的两个独立的白色区域,将两个白色区域合并为同一个区域;
连通图像生成模块,其用于检测二维码图像的独立白色区域个数是否大于1,若是,则返回上一步;否则,结束连通化处理过程,得到连通图像Ic;
二维表面网格映射模块,其用于根据连通图像Ic中每个像素的颜色值,生成映射到单位面积的二维表面网格S;
所述二维表面网格映射模块包括:
扫描模块,其用于根据扫描线算法,顺序遍历连通图像Ic中的每个像素,其中,连通图像Ic的像素为n×n;若第y+1行且第x+1列的像素颜色为白色,则记为P(x,y)=1;否则,记为P(x,y)=0,得到标记集合P,其中,1≤x≤n,n为正整数;
标记集合遍历模块,其用于遍历标记集合P,若P(x,y)=1,则添加v0((x-1)/n,(y-1)/n)、v1(x/n,(y-1)/n)、v2((x-1)/n,y/n)和v3(x/n,y/n)这四个顶点,分别添加连接v0与v1、v1与v2、v2与v3、v3与v0提及v0与v2的边,若边已存在,则不添加,得到连通图像Ic映射到单位面积的二维表面网格S;
二维表面网格放大及打印模块,其用于对二维表面网格S进行放大处理,打印出与3D打印机精度相匹配的三维镂空模型M;
所述二维表面网格放大及打印模块包括:
放大倍数计算模块,其用于遍历二维表面网格S的镂空区域,查找到面积最小的镂空区域,并对其求最大内接圆,得到内接圆直径d,计算得到放大倍数m1=ω/d,其中,ω为3D打印机精度;根据白色直线的宽度w,计算得到放大倍数m2=ω/w;若m1>m2,则将二维表面网格S放大m1倍,否则,放大m2倍;
z轴延伸及打印模块,其用于将放大后的二维表面网格S按照面法向量,即沿着z轴正方向延伸kω距离,打印出三维镂空模型M,其中,k≥1。
4.如权利要求3所述的一种可3D打印的镂空二维码模型生成***,其特征在于,该***还包括:
图像预处理模块,其用于对二维码图像进行阈值预处理,遍历二维码图像并标记所有不同的独立白色区域。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710326073.3A CN107031033B (zh) | 2017-05-10 | 2017-05-10 | 一种可3d打印的镂空二维码模型生成方法及*** |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201710326073.3A CN107031033B (zh) | 2017-05-10 | 2017-05-10 | 一种可3d打印的镂空二维码模型生成方法及*** |
Publications (2)
Publication Number | Publication Date |
---|---|
CN107031033A CN107031033A (zh) | 2017-08-11 |
CN107031033B true CN107031033B (zh) | 2019-03-01 |
Family
ID=59537843
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201710326073.3A Active CN107031033B (zh) | 2017-05-10 | 2017-05-10 | 一种可3d打印的镂空二维码模型生成方法及*** |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN107031033B (zh) |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109421252A (zh) * | 2017-08-19 | 2019-03-05 | 宝胜科技创新股份有限公司 | 3d打印电线电缆制备方法 |
CN108248016B (zh) * | 2018-01-06 | 2019-11-19 | 石家庄铁道大学 | 一种镂空结构的fdm打印方法 |
CN109614838B (zh) * | 2018-11-05 | 2021-11-30 | 武汉天喻信息产业股份有限公司 | 二维码生成方法、***、实现方法及支付设备 |
CN109508489B (zh) * | 2018-11-07 | 2020-11-10 | 山东大学 | 一种各向异性多孔结构的建模方法及*** |
CN109933841A (zh) * | 2019-01-18 | 2019-06-25 | 南京大学 | 一种基于3d打印的高密度存储方法 |
CN111914974B (zh) * | 2020-07-07 | 2022-02-18 | 山东大学 | 一种面向3d打印的立体二维码生成方法及*** |
CN112348946A (zh) * | 2020-11-04 | 2021-02-09 | 深圳市纵维立方科技有限公司 | 打印处理方法、装置、电子设备以及存储介质 |
CN117292372B (zh) * | 2023-09-12 | 2024-06-04 | 安徽美立刻医疗器械有限公司 | 一种适用3d打印产品的识别方法、***、电子设备及介质 |
Family Cites Families (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2006041624A (ja) * | 2004-07-22 | 2006-02-09 | Canon Inc | 印刷制御装置及び方法 |
CN103971138B (zh) * | 2014-05-28 | 2017-07-28 | 汤淼 | 立体信息载体及存读方法 |
CN203909820U (zh) * | 2014-05-30 | 2014-10-29 | 上海理工大学 | 具有防伪功能的光栅结构二维码 |
CN105678368A (zh) * | 2016-01-11 | 2016-06-15 | 熊文海 | 一种三维码 |
CN106529368B (zh) * | 2016-09-29 | 2019-06-07 | 上海正雅齿科科技股份有限公司 | 二维码识别区域定位的方法 |
-
2017
- 2017-05-10 CN CN201710326073.3A patent/CN107031033B/zh active Active
Also Published As
Publication number | Publication date |
---|---|
CN107031033A (zh) | 2017-08-11 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107031033B (zh) | 一种可3d打印的镂空二维码模型生成方法及*** | |
CN104751142B (zh) | 一种基于笔划特征的自然场景文本检测方法 | |
CN100464347C (zh) | 一种工程cad图纸的矢量化图形识别方法 | |
US8915440B2 (en) | Four dimensional (4D) color barcode for high capacity data encoding and decoding | |
CN107610200B (zh) | 一种基于特征模板的字库快速生成方法 | |
EP3457327A1 (en) | Method and apparatus for generating two-dimensional code picture having dynamic effect | |
CN106991462B (zh) | 三维码生成方法 | |
CN107330979A (zh) | 建筑户型的矢量图生成方法、装置及终端 | |
CN105069394A (zh) | 二维码加权平均灰度法解码方法及*** | |
CN106104564A (zh) | 用于数字指纹代码的解码器和编码器 | |
CN104835108A (zh) | 产生可视化二维码的方法 | |
CN110348264A (zh) | 一种qr二维码图像校正方法及*** | |
CN111899295B (zh) | 一种基于深度学习的单目场景深度预测方法 | |
CN110356151B (zh) | 一种玉石雕刻路径的自动生成方法及装置 | |
CN103955730A (zh) | 一种防伪用光刻二维码标签的制作方法 | |
US20100201114A1 (en) | Page mark-up using printed dot barcodes | |
CN113688688A (zh) | 图片中表格线条的补全方法与图片中表格的识别方法 | |
JP7076772B2 (ja) | 認証システムおよび認証方法 | |
CN108734250A (zh) | 基于Sobel算子的视觉二维码生成方法 | |
Gu et al. | Dot-coded structured light for accurate and robust 3D reconstruction | |
Lu et al. | HFENet: A lightweight hand‐crafted feature enhanced CNN for ceramic tile surface defect detection | |
CN109492450A (zh) | 一种基于版面分析的条形码定位方法 | |
Ablameyko | An introduction to interpretation of graphic images | |
CN107563314A (zh) | 一种基于平行坐标系的车道线检测方法 | |
CN106875357A (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 |