预览加载中,请您耐心等待几秒...
1/10
2/10
3/10
4/10
5/10
6/10
7/10
8/10
9/10
10/10

亲,该文档总共12页,到这已经超出免费预览范围,如果喜欢就直接下载吧~

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

(19)中华人民共和国国家知识产权局(12)发明专利申请(10)申请公布号CN105701855A(43)申请公布日2016.06.22(21)申请号201610016510.7(22)申请日2016.01.11(71)申请人南京师范大学地址210097江苏省南京市鼓楼区宁海路122号(72)发明人乐松山温永宁陈旻闾国年(74)专利代理机构南京知识律师事务所32207代理人李媛媛(51)Int.Cl.G06T15/00(2011.01)G06T1/20(2006.01)权利要求书2页说明书6页附图3页(54)发明名称基于符号结构的线型地图符号反走样绘制方法(57)摘要本发明涉及GIS领域和数字地图制图领域的一种符号化渲染技术,给出了一种基于符号结构信息的线型矢量要素反走样绘制方法,利用GPU可编程流水线和Shader语言实现了基于该方法的线状矢量要素高质量绘制。该方法包括以下步骤:首先根据线宽构造三角化后的线Mesh,将沿线走向的U参数和垂直于线走向的V参数传递给Mesh中的每个顶点;接着根据需要填充的地图符号单元生成颜色结构表,确定反走样阈值,并将此颜色结构表、反走样阈值和U-V参数传递到Shader程序中;利用Shader语言,根据每个顶点的U-V值,判读当前像素是否在反走样阈值内,在阈值内则先进行U方向的反走样颜色混合计算,再进行V方向的反走样颜色混合计算;最后得到需要填充的颜色,对线要素进行逐像素绘制。CN105701855ACN105701855A权利要求书1/2页1.基于符号结构的线型地图符号反走样绘制方法,其特征是,该方法包括下列步骤:步骤1初始化需要绘制的线状要素的点集序列,根据线宽生成需要绘制的三角形几何三角网:确定需要绘制的矢量线要素的线宽参数,遍历线要素中的每一个顶点,按照半个最大线宽向两边扩展,同时生成相应的三角形集合,并为每个三角形的每个顶点赋予沿线走向的长度值U值和垂直于线走向的长度值V值,即U-V值;最终得到最后一个顶点的U值作为整条线最大的U值MaxU;步骤2确定需要沿线重复填充的符号单元的颜色结构表:将需要填充的符号单元按照纵向-横向的结构进行分解,用列优先的二维数组和相应的符号单元属性来结构化映射一个符号单元;步骤3在着色器中根据符号颜色结构表确定当前像素的位置信息:在着色器中基于传递到着色器里面的顶点U-V值,动态确定每个像素的U-V值,即像素在水平方向上到线起点的距离u'值和像素在垂直方向上到线的上边界的距离v'值,由此确定每一个像素在符号颜色结构表中属于哪一个单元;根据所属单元的行列值,得到一个像素在沿线走向上占单元的比例u_Percernt和在垂直于线走向上占单元的比例v_Percernt;步骤4首先判断步骤3确定的比例u_Percernt是否在反走样阈值范围内,如果在范围内则进行当前单元的左单元和右单元的颜色混合;再对比例v_Percernt判断是否在反走样阈值范围内,如果在范围内则进行当前单元的上单元和下单元的颜色混合;最后利用计算得到的颜色对线要素进行逐像素绘制。2.根据权利要求1所述的基于符号结构的线型地图符号反走样绘制方法,其特征是,所述步骤1中,将V值从0至最大线宽的范围内归一化到0至1的范围内,U值通过每个顶点距离起始点的距离除以最大线宽得到。3.根据权利要求1所述的基于符号结构的线型地图符号反走样绘制方法,其特征是,所述步骤2中,A.符号的颜色结构表:将符号单元按照其结构分解为几个列,每一列都包含其相应的行,每一行都包含其相应的四个角的颜色值,由此形成一系列的颜色单元来映射特定的符号;B.颜色结构表的单元属性:对于一个符号的颜色结构表,其每一列都包含相应的宽度属性和所包含的行数属性,每一行都包含相应的高度属性,每一列都包含一个布尔值来指明该列是否为背景列,整个颜色结构表包含总列数、总宽度和总高度属性。4.根据权利要求1所述的基于符号结构的线型地图符号反走样绘制方法,其特征是,所述步骤3中确定当前像素的位置信息,具体步骤为:在着色器中根据当前像素的u'值,利用公式U(p)=u'-SL×[u'/SL],计算其在符号颜色结构表中的位置,其中U(p)表示在颜色结构表中的U值,SL表达符号的总宽度,[u'/SL]表示对u'/SL的结果进行取整得到小于u'值的SL的整数倍;然后根据当前像素的v'值,迭代判断其在颜色结构表中所处的具体行,并结合U(p)值确定该像素在符号颜色结构表中所处的具体列;根据得到的具体行和列即可确定当前像素所处的单元;所述比例u_Percernt的计算公式为:u_Percent=U(p)/ColumnWidth,其中ColumnWidth为像素所在单元的宽度;所述比例v_Percernt的计算公式为:v_Percent=v'/RowHeight,其中RowH