CN108986224A - 电子地图处理方法、装置和计算机设备 - Google Patents

电子地图处理方法、装置和计算机设备 Download PDF

Info

Publication number
CN108986224A
CN108986224A CN201710405645.7A CN201710405645A CN108986224A CN 108986224 A CN108986224 A CN 108986224A CN 201710405645 A CN201710405645 A CN 201710405645A CN 108986224 A CN108986224 A CN 108986224A
Authority
CN
China
Prior art keywords
virtual object
dimensional
dimensional virtual
anchor point
addition
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.)
Granted
Application number
CN201710405645.7A
Other languages
English (en)
Other versions
CN108986224B (zh
Inventor
张玖林
李斌
罗程
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Tencent Technology Shenzhen Co Ltd
Original Assignee
Tencent Technology Shenzhen Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by Tencent Technology Shenzhen Co Ltd filed Critical Tencent Technology Shenzhen Co Ltd
Priority to CN201710405645.7A priority Critical patent/CN108986224B/zh
Publication of CN108986224A publication Critical patent/CN108986224A/zh
Application granted granted Critical
Publication of CN108986224B publication Critical patent/CN108986224B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T19/00Manipulating 3D models or images for computer graphics
    • G06T19/006Mixed reality

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Graphics (AREA)
  • Computer Hardware Design (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Processing Or Creating Images (AREA)

Abstract

本发明涉及一种电子地图处理方法、装置和计算机设备,所述方法包括:确定三维电子地图中待添加三维虚拟物体的目标地图元素;获取所述目标地图元素的定位点;在所述三维电子地图中,生成从天空区指向所述定位点的射线;沿所述射线的方向,确定所述射线在所述三维电子地图中的交点;按照所述交点添加与所述目标地图元素匹配的三维虚拟物体。本发明提供的电子地图处理方法、装置和计算机设备,在整个三维虚拟物体的添加过程中,降低了添加三维虚拟物体的计算量,节省了计算所耗费的时间,提高了三维虚拟物体的添加效率。

Description

电子地图处理方法、装置和计算机设备
技术领域
本发明涉及数据处理技术,特别是涉及一种电子地图处理方法、装置和计算机设备。
背景技术
随着计算机技术的迅猛发展,各种数据的处理都依赖于计算机的处理,并为用户提供了方便。随着电子地图的兴起和广泛的应用,现在很多电子地图的绘制同样也依赖于计算机的处理。
电子地图的绘制过程中,为了使的电子地图更加真实,需要在电子地图中添加虚拟物体。传统的虚拟物体添加过程中,为了减少虚拟物体相交,需要通过严格的计算才能确定虚拟物体的添加位置,每添加一个虚拟物体都要经过大量的计算,导致需要花费较长时间去计算,降低了虚拟物体的添加效率。
发明内容
基于此,有必要针对在电子地图中添加虚拟物体的添加效率低下的问题,提供一种电子地图处理方法、装置和计算机设备。
一种电子地图处理方法,所述方法包括:
确定三维电子地图中待添加三维虚拟物体的目标地图元素;
获取所述目标地图元素的定位点;
在所述三维电子地图中,生成从天空区指向所述定位点的射线;
沿所述射线的方向,确定所述射线在所述三维电子地图中的交点;
按照所述交点添加与所述目标地图元素匹配的三维虚拟物体。
一种电子地图处理装置,所述装置包括:
元素确定模块,用于确定三维电子地图中待添加三维虚拟物体的目标地图元素;
定位点获取模块,用于获取所述目标地图元素的定位点;
射线生成模块,用于在所述三维电子地图中,生成从天空区指向所述定位点的射线;
交点确定模块,用于沿所述射线的方向,确定所述射线在所述三维电子地图中的交点;
物体添加模块,用于按照所述交点添加与所述目标地图元素匹配的三维虚拟物体。
一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述计算机可读指令被所述处理器执行时,使得所述处理器执行以下步骤:
确定三维电子地图中待添加三维虚拟物体的目标地图元素;
获取所述目标地图元素的定位点;
在所述三维电子地图中,生成从天空区指向所述定位点的射线;
沿所述射线的方向,确定所述射线在所述三维电子地图中的交点;
按照所述交点添加与所述目标地图元素匹配的三维虚拟物体。
上述电子地图处理方法、装置和计算机设备,确定三维电子地图中待添加三维虚拟物体的目标地图元素,获取目标地图元素的定位点,无需通过严格的计算才能确定三维虚拟物体的添加位置,只需通过在三维电子地图中生成从天空区指向定位点的射线,沿射线的方向确定射线在三维电子地图中的交点,根据交点添加与目标地图元素匹配的三维虚拟物体即可减少添加的三维虚拟物体出现相交的情况。在整个三维虚拟物体的添加过程中,降低了添加三维虚拟物体的计算量,节省了计算所耗费的时间,提高了三维虚拟物体的添加效率。
附图说明
图1为一个实施例中电子地图处理方法的应用环境图;
图2为一个实施例中计算机设备的内部结构示意图;
图3为一个实施例中电子地图处理方法的流程示意图;
图4为一个实施例中选取定位点的步骤的流程示意图;
图5为一个实施例中确定线状属性的目标地图元素的边缘线的示意图;
图6为一个实施例中确定多边形属性的目标地图元素的子区域的示意图;
图7为一个实施例中添加三维虚拟物体的三维电子地图的示意图;
图8为一个实施例中根据三维电子地图中的定位点确定射线交点的示意图;
图9为另一个实施例中电子地图处理方法的流程示意图;
图10为一个实施例中电子地图处理装置的结构框图;
图11为一个实施例中定位点获取模块的结构框图;
图12为一个实施例中物体添加模块的结构框图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
图1为一个实施例中电子地图处理方法的应用环境图。参照图1,该电子地图处理方法应用于电子地图处理系统。电子地图处理系统包括终端110和服务器120,其中终端110通过网络与服务器120连接。终端110可以是固定终端或移动终端,固定终端具体可以是台式电脑、显示屏和监控器中的至少一种,移动终端具体可以是平板电脑、智能手机和个人数字助理的至少一种。
图2为一个实施例中计算机设备的内部结构示意图。该计算机设备可以是图1中的终端110。如图2所示,该计算机设备包括通过系统总线连接的处理器、非易失性存储介质、内存储器、网络接口、显示屏和输入设备。其中,计算机设备的非易失性存储介质存储有操作系统和计算机可读指令,该计算机可读指令被执行时,可使得处理器执行一种电子地图处理方法。该计算机设备的处理器用于提供计算和控制能力,支撑整个计算机设备的运行。该内存储器执行中存储有计算机可读指令,该计算机可读指令被处理器执行时,可使得处理器执行一种电子地图处理方法。计算机设备的网络接口用于进行网络通信。计算机设备的显示屏可以是液晶显示屏或者电子墨水显示屏,计算机设备的输入装置可以是显示屏上覆盖的触摸屏,也可以是计算机设备外壳上设备的按键、轨迹球或触控板,还可以是外接的键盘、触控板或鼠标等。触摸层和显示屏构成触控屏。
本领域技术人员可以理解,图2中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的计算机设备的限定,具体的计算机设备可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
如图3所示,在一个实施例中,提供一种电子地图处理方法。本实施例以该方法应用于上述图1中的终端110来举例说明。该方法具体包括以下步骤:
S302,确定三维电子地图中待添加三维虚拟物体的目标地图元素。
其中,三维虚拟物体为三维电子地图中未包括的,需要另外添加的虚拟物体,比如树木、汽车和小船等。地图元素为三维电子地图中固有的元素,包括草地、湖泊、河流、道路和建筑物等。
具体地,终端110获取三维电子地图的电子地图数据,根据获取到的电子地图数据绘制三维电子地图,将绘制的三维电子地图显示在显示屏中。终端110在显示的三维电子地图中查询待添加三维虚拟物体的地图元素,以查询到的地图元素作为目标地图元素。其中,三维电子地图的电子地图数据可以存储在终端110中,还可以存储在服务器120中。
在一个实施例中,三维电子地图的电子地图数据存储在服务器120中。终端110在检测到三维电子地图的显示指令时,向服务器120发送地图数据获取请求。服务器120根据地图数据获取请求将三维电子地图的电子地图数据发送至终端110。终端110根据接收到服务器120发送的电子地图数据,根据接收到的电子地图数据绘制三维电子地图。
在一个实施例中,终端110获取当前位置信息,获取当前位置信息对应电子地图数据,根据获取到的电子地图数据绘制三维电子地图。
在一个实施例中,终端110根据电子地图数据在三维电子地图中查询符合待添加三维虚拟物体条件的地图元素,以查询到的地图元素为目标地图元素。
在一个实施例中,S302具体包括:获取待添加三维虚拟物体的地图元素类型;按照地图元素类型,从三维电子地图中选取目标地图元素。
具体地,其中待添加三维虚拟物体的地图元素类型为需要添加三维虚拟物体的地图元素所述的类型,例如待添加三维虚拟物体的地图元素类型包括道路、河流、湖泊和建筑物等。终端110识别三维电子地图中地图元素的地图元素类型,获取属于待添加三维虚拟物体的地图元素类型的地图元素,以获取到的地图元素作为目标地图元素。
S304,获取目标地图元素的定位点。
具体地,终端110在三维电子地图中查询到目标地图元素后,在三维电子地图中与目标地图元素匹配区域中确定定位点。
在一个实施例中,终端110获取目标地图元素的元素信息,根据元素信息确定定位点,获取定位点的坐标。
S306,在三维电子地图中,生成从天空区指向定位点的射线。
具体地,终端110在三维电子地图中,从天空区中选取高度高于定位点的一点作为射线的起点,生成指向定位点的射线。其中,终端110在空中可以是随机选取高度高于定位点的射线起点,也可以根据定位点的坐标选取匹配、且高度高于定位点的射线起点,还可以是从无限高处的一点向定位点引出射线。
在一个实施例中,终端110在三维电子地图中,根据定位点的坐标确定映射到天空区的坐标点,以确定的坐标点作为射线的起点,向定位点引出射线。其中引出的射线可以与地面垂直或近似垂直。
在另一个实施例中,定位点的坐标三维坐标,终端110将定为点的三维坐标中表示高度的坐标值修改为三维电子地图中的最大高度值或大于三维电子地图中的最大高度值,以修改后的三维坐标对应的点作为射线的起点,向定位点引出垂直于地面的射线。
举例说明,若定位点的坐标为(x,y,H),H用于表示定位点的高度,若定位点处于建筑物顶部,H可以是建筑物的高度,若点位点处于地面上H的取值为0。终端110获取定位点的坐标(x,y,H),获取三维电子地图中的最大高度值maxH,以坐标为(x,y,maxH)的点为射线的起点,向定位点(x,y,H)引出射线。
S308,沿射线的方向,确定射线在三维电子地图中的交点。
具体地,终端110沿射线的方向,确定射线于三维电子地图中的地图元素或三维虚拟物体的交点。
在一个实施例中,终端110可沿射线的方向,确定射线在三维电子地图中的首个交点。
S310,按照交点添加与目标地图元素匹配的三维虚拟物体。
具体地,终端110确定目标地图元素匹配的三维虚拟物体类型,获取与确定的三维虚拟物体类型对应的资源数据文件,根据获取到的资源数据文件构建三维虚拟物体,将构建的三维虚拟物体添加到确定的交点的位置。其中,终端110以确定的交点作为三维虚拟物体底部面的中点或任意一点,将三维虚拟物体放置在交点的位置。
在一个实施例中,S310具体还包括:在交点对应的地图空余空间中,添加与目标地图元素的地图元素类型匹配的三维虚拟物体。
具体地,终端110查询与目标地图元素的地图元素类型匹配的三维虚拟物体,获取三维虚拟物体所占空间的尺寸信息。终端110根据所占空间的尺寸信息在交点所在位置确定空余空间,将查询到的三维虚拟物体添加到确定的空余空间中。
本实施例中,确定三维电子地图中待添加三维虚拟物体的目标地图元素,获取目标地图元素的定位点,无需通过严格的计算才能确定三维虚拟物体的添加位置,只需通过在三维电子地图中生成从天空区指向定位点的射线,沿射线的方向确定射线在三维电子地图中的交点,根据交点添加与目标地图元素匹配的三维虚拟物体即可减少添加的三维虚拟物体出现相交的情况。在整个三维虚拟物体的添加过程中,降低了添加三维虚拟物体的计算量,节省了计算所耗费的时间,提高了三维虚拟物体的添加效率。
如图4所示,在一个实施例中,S304具体包括选取定位点的步骤,该步骤具体包括以下内容:
S402,获取目标地图元素的几何属性。
具体地,在三维电子地图中的地图元素,每个地图元素都有各自所属的几何属性。三维电子地图中的地图元素的几何属性包括点状属性、线状属性和多边形属性。
举例说明,在三维电子地图中,点状属性的地图元素包括公交车站点、自动取款机和自动售货机等;线状属性的地图元素包括道路、河流、桥梁和隧道等;多边形属性的地图元素包括建筑物、湖泊、海洋和草地等。
S404,确定获取的几何属性所对应的定位点选取方式。
具体地,终端110中存储着每种几何属性对应的定位点选取方式。终端110确定目标地图元素的几何属性,获取确定的几何属性对应的定位点选取方式。
S406,按照定位点选取方式选取目标地图元素的定位点。
具体地,终端110获取到目标地图元素的几何属性,当获取到的几何属性为点状属性时,将目标地图元素所在点作为目标地图元素的定位点,获取定位点的坐标。目标地图元素的几何属性为点状属性时,则存储的目标地图元素的位置信息为点信息。当获取到的几何属性为线状属性时,终端110确定目标地图元素的边缘线,在边缘线上选取目标地图元素的定位点。当获取到的几何属性为多边形属性时,确定目标地图元素的多边形区域,在多边形区域中选取包含于多边形区域的子区域,在选取的子区域中选取目标地图元素的定位点。
在一个实施例中,当目标地图元素的几何属性为线状属性时,获取目标地图元素的宽度;根据宽度生成大于宽度的一半的第一偏移距离;分别向目标地图元素的中线两侧偏移第一偏移距离,形成目标地图元素的两条边缘线。
其中,在三维电子地图中以目标地图元素中的中线信息和宽度表示目标地图元素,中线信息包括至少一条线段的端点坐标,其中每条线段对应的宽度可能不同。
请参照图5,图5为确定几何属性为线状属性的目标地图元素的边缘线的示意图。其中,目标地图元素的几何属性为线状属性,502a和502b为目标地图元素的两边,504为目标地图元素的中线,506a和506b为目标地图元素的边缘线。
终端110获取目标地图元素的宽度或预设距离,用D表示宽度,用L表示预设距离,则以S表示第一偏移距离,根据S=D/2+L计算得到第一偏移距离。终端110确定目标地图元素的中线,将中线以分别垂直于目标地图元素的两边502a和502b的方向向两侧移动,移动的距离为第一偏移距离S,分别得到边缘线506a和506b。其中,中线可以有至少一条线段构成,每条线段对应的宽度可以不同。终端110在分别在边缘线上按预设定位间距选取定位点。
在一个实施例中,当几何属性为多边形属性时,确定目标地图元素的多边形区域;获取第二偏移距离;将多边形区域各边分别向多边形的内侧偏移第二偏移距离,形成包含于多边形区域的子区域;在子区域中选取目标地图元素的定位点。
请参照图6,图6为确定几何属性为多边形属性的目标地图元素的子区域的示意图。图6中包括目标地图元素的多边形区域602和包含于多边形区域的子区域604,以K表示第二偏移距离。当目标地图元素的几何属性为多边形属性时,存储的目标地图元素的信息为多边形的边信息。终端110获取目标地图元素的边信息,根据边信息确定目标地图元素的多边形区域的各边,从而确定多边形区域。终端110获取第二偏移距离K,将确定的多边性区域的各边向多边形内测偏移第二偏移距离K,确定相邻两条边的交点,按顺序将交点进行连接构成的包含于多边形区域的子区域。终端110在子区域中选取定位点。其中K小于多边形区域的中点到各边距离中的最短距离。
本实施例中,根据目标地图元素的几何属性,选取合适的定位点选取方式,采用合适的定位点选取方式选取目标地图元素的定位点,避免错误选取定位点,提高了目标地图元素的定位点的选取准确率。
在一个实施例中,S310具体包括调整添加的三维虚拟物体的位置的步骤,该步骤具体包括以下内容:在交点处添加与目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体;当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置。
具体地,终端110查询与目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体。碰撞触发器用于检测三维虚拟物体是否与三维电子地图中障碍物发生重叠的情况;当碰撞触发器触发时,表示三维虚拟物体与障碍物存在重叠的情况;当碰撞触发器未触发时,表示三维虚拟物体与障碍物不存在重叠的情况。
终端110将查询到的三维虚拟物体添加在交点处之后,当碰撞触发器触发时,对添加的三维虚拟物体的位置进行调整,直至碰撞触发器停止触发时,停止调整添加的三维虚拟物体的位置。
在一个实施例中,当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置,包括:当碰撞触发器被第一障碍物触发时,向背离第一障碍物的方向调整添加的三维虚拟物体的位置;调整添加的三维虚拟物体的位置时,若碰撞触发器被第二障碍物触发,则放弃添加的三维虚拟物体;调整添加的三维虚拟物体的位置时,若碰撞触发器停止触发,则停止调整添加的三维虚拟物体的位置。
具体地,终端110在将三维虚拟物体添加在交点处后,当添加的三维虚拟物体的碰撞触发器被第一障碍物触发时,将添加的三维虚拟物体向背离第一障碍物的方向调整,在调整添加的三维虚拟物体的位置的过程中,若碰撞触发器被第二障碍物触发,丢弃添加的三维虚拟物体,放弃添加三维虚拟物体;若在调整添加的三维虚拟物体的位置的过程中,若碰撞触发器停止触发,则停止调整添加的三维虚拟物体的位置,将添加的三维虚拟物体添加在当前位置。其中,障碍物可以是三维虚拟物体或地图元素。
本实施例中,通过三维虚拟物体中的碰撞触发器,可以检测到三维虚拟物体的添加过程中是否与三维电子地图中的障碍物存在相交的情况,在检测到添加的三维虚拟物体与三维电子地图中的障碍物存在相交时,调整添加的三维虚拟物体的位置,从而避免在添加的三维虚拟物体与障碍物存在相交的情况,提高了在三维电子地图中添加三维虚拟物体的准确性。
图7为一个实施例中添加三维虚拟物体的三维电子地图的示意图。如图7所示,三维电子地图700中的地图元素包括建筑物702、道路704和湖泊706,其中的添加的三维虚拟物体为树708和小船710。
终端110在三维电子地图700中确定待添加三维虚拟物体的目标地图元素为道路704和湖泊706,识别道路704和湖泊706的几何属性。对于道路704,道路704的几何属性为线状属性,终端110在三维电子地图中确定道路704的两侧的边缘线,在边缘线上选取定位点;对于湖泊706,湖泊706的几何属性为多边形属性,终端110在多边形区域中确定子区域,在子区域中选取定位点。终端110以选取的定位点映射到天空区的点作为射线的起点,指向定位点引出垂直于地面的射线,沿射线方向在射线上选取射线在三维电子地图700中的首个交点,以选取的交点作为三维虚拟物体的添加位置。终端110查询到与道路704匹配的三维虚拟物体为树708,将树708添加到根据道路704选取的交点对应的位置。终端110查询到与湖泊706匹配的三维虚拟物体为小船710,将小船710添加到根据湖泊706选取的交点对应的位置。
图8为一个实施例中根据三维电子地图中的定位点确定射线交点的示意图。如图8所示,终端110在三维电子地图800中确定了定位点802和定位点804,在这两个定位点所处位置需要添加三维虚拟物体。定位点802在建筑物818的顶部,以h1表示建筑物818在三维电子地图800中离地面的高度,以(x1,y1,h1)表示定位点802。其中,建筑物818顶部放置有障碍物816。定位点804在三维电子地图800中的地面处,以(x2,y2,0)表示定位点804。以maxh表示三维电子地图800中的天空区的无限高度。
对于定位点802,以(x1,y1,maxh)作为射线的起点,向定位点802引出垂直于三维电子地图800中地面的射线812,沿射线812的方向,选取射线812上的首个交点808,交点808处为添加三维虚拟物体的位置。
对于定位点804,以(x2,y2,maxh)作为射线的起点,向定位点804引出垂直于三维电子地图中800中地面的射线814,沿射线814的方向,选取射线814上的首个交点。其中,因为定位点804处于地面,且定位点804处没有障碍物阻碍射线814,则选取的交点可以与定位点804重合。
如图9所示,在一个实施例中,提供一种电子地图处理方法,该方法具体包括以下步骤:
S902,确定三维电子地图中待添加三维虚拟物体的目标地图元素。
S904,获取目标地图元素的几何属性。
S906,当几何属性为线状属性时,确定目标地图元素的边缘线;在边缘线上选取目标地图元素的定位点。
S908,当几何属性为点状属性时,将目标地图元素所在点作为目标地图元素的定位点。
S910,当几何属性为多边形属性时,确定目标地图元素的多边形区域;选取包含于多边形区域的子区域;在子区域中选取目标地图元素的定位点。
S912,在三维电子地图中,生成从天空区指向定位点的射线。
S914,沿射线的方向,确定射线在三维电子地图中的交点。
S916,在交点处添加与目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体。
S918,当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置。
本实施例中,在确定三维电子地图中待添加三维虚拟物体的目标地图元素后,根据目标地图元素的几何属性,采取相应的定位点确定方式确定定位点,以提高定位点的确定准确率。通过从天空区引出指向定位点的射线,沿射线的方向确定射线在三维电子地图中的交点,按照交点添加与目标地图元素匹配的三维虚拟物体,减少了在添加三维虚拟物体时出现相交的情况。在碰撞触发器触发时,调整添加的三维虚拟物体的位置,进一步避免了添加三维虚拟物体出现相交的情况,提高了添加三维虚拟物体的添加准确率。
如图10所示,在一个实施例中,提供一种电子地图处理装置1000,该装置具体包括:元素确定模块1002、定位点获取模块1004、射线生成模块1006、交点确定模块1008和物体添加模块1010。
元素确定模1002,用于确定三维电子地图中待添加三维虚拟物体的目标地图元素。
定位点获取模块1004,用于获取目标地图元素的定位点。
射线生成模块1006,用于在三维电子地图中,生成从天空区指向定位点的射线。
交点确定模块1008,用于沿射线的方向,确定射线在三维电子地图中的交点。
物体添加模块1010,用于按照交点添加与目标地图元素匹配的三维虚拟物体。
在一个实施例中,元素确定模块1002还用于获取待添加三维虚拟物体的地图元素类型;按照地图元素类型,从三维电子地图中选取目标地图元素。
物体添加模块1010还用于在交点对应的地图空余空间中,添加与目标地图元素的地图元素类型匹配的三维虚拟物体。
本实施例中,确定三维电子地图中待添加三维虚拟物体的目标地图元素,获取目标地图元素的定位点,无需通过严格的计算才能确定三维虚拟物体的添加位置,只需通过在三维电子地图中生成从天空区指向定位点的射线,沿射线的方向确定射线在三维电子地图中的交点,根据交点添加与目标地图元素匹配的三维虚拟物体即可减少添加的三维虚拟物体出现相交的情况。在整个三维虚拟物体的添加过程中,降低了添加三维虚拟物体的计算量,节省了计算所耗费的时间,提高了三维虚拟物体的添加效率。
如图10所示,在一个实施例中,定位点获取模块1004具体包括:几何属性获取模块1004a、选取方式确定模块1004b和定位点选取模块1004c。
几何属性获取模块1004a,用于获取目标地图元素的几何属性。
选取方式确定模块1004b,用于确定获取的几何属性所对应的定位点选取方式。
定位点选取模块1004c,用于按照定位点选取方式选取目标地图元素的定位点。
在一个实施例中,定位点选取模块1004c还用于当几何属性为点状属性时,将目标地图元素所在点作为目标地图元素的定位点。
在一个实施例中,定位点选取模块1004c还用于当几何属性为线状属性时,确定目标地图元素的边缘线;在边缘线上选取目标地图元素的定位点。
在一个实施例中,定位点选取模块1004c还用于获取目标地图元素的宽度;根据宽度生成大于宽度的一半的第一偏移距离;分别向目标地图元素的中线两侧偏移第一偏移距离,形成目标地图元素的两条边缘线。
在一个实施例中,定位点选取模块1004c还用于当几何属性为多边形属性时,确定目标地图元素的多边形区域;选取包含于多边形区域的子区域;在子区域中选取目标地图元素的定位点。
在一个实施例中,定位点选取模块1004c还用于获取第二偏移距离;将多边形区域各边分别向多边形的内侧偏移第二偏移距离,形成包含于多边形区域的子区域。
本实施例中,根据目标地图元素的几何属性,选取合适的定位点选取方式,采用合适的定位点选取方式选取目标地图元素的定位点,避免错误选取定位点,提高了目标地图元素的定位点的选取准确率。
如图10所示,在一个实施例中,物体添加模块1010具体还包括:虚拟物体添加模块1010a和添加位置调整模块1010b。
虚拟物体添加模块1010a,用于在交点处添加与目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体。
添加位置调整模块1010b,用于当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置。
在一个实施例中,添加位置调整模块1010b还用于当碰撞触发器被第一障碍物触发时,向背离第一障碍物的方向调整添加的三维虚拟物体的位置;调整添加的三维虚拟物体的位置时,若碰撞触发器被第二障碍物触发,则放弃添加的三维虚拟物体;调整添加的三维虚拟物体的位置时,若碰撞触发器停止触发,则停止调整添加的三维虚拟物体的位置。
本实施例中,通过三维虚拟物体中的碰撞触发器,可以检测到三维虚拟物体的添加过程中是否与三维电子地图中的障碍物存在相交的情况,在检测到添加的三维虚拟物体与三维电子地图中的障碍物存在相交时,调整添加的三维虚拟物体的位置,从而避免在添加的三维虚拟物体与障碍物存在相交的情况,提高了在三维电子地图中添加三维虚拟物体的准确性。
在一个实施例中,提供一种计算机设备,包括存储器和处理器,存储器中存储有计算机可读指令,计算机可读指令被处理器执行时,使得处理器执行以下步骤:确定三维电子地图中待添加三维虚拟物体的目标地图元素;获取目标地图元素的定位点;在三维电子地图中,生成从天空区指向定位点的射线;沿射线的方向,确定射线在三维电子地图中的交点;按照交点添加与目标地图元素匹配的三维虚拟物体。
在一个实施例中,确定三维电子地图中待添加三维虚拟物体的目标地图元素包括:获取待添加三维虚拟物体的地图元素类型;按照地图元素类型,从三维电子地图中选取目标地图元素;按照交点添加与目标地图元素匹配的三维虚拟物体,包括:在交点对应的地图空余空间中,添加与目标地图元素的地图元素类型匹配的三维虚拟物体。
在一个实施例中,获取目标地图元素的定位点包括:获取目标地图元素的几何属性;确定获取的几何属性所对应的定位点选取方式;按照定位点选取方式选取目标地图元素的定位点。
在一个实施例中,按照定位点选取方式选取目标地图元素的定位点,包括:当几何属性为点状属性时,将目标地图元素所在点作为目标地图元素的定位点。
在一个实施例中,按照定位点选取方式选取目标地图元素的定位点,包括:当几何属性为线状属性时,确定目标地图元素的边缘线;在边缘线上选取目标地图元素的定位点。
在一个实施例中,确定目标地图元素的边缘线,包括:获取目标地图元素的宽度;根据宽度生成大于宽度的一半的第一偏移距离;分别向目标地图元素的中线两侧偏移第一偏移距离,形成目标地图元素的两条边缘线。
在一个实施例中,按照定位点选取方式选取目标地图元素的定位点,包括:当几何属性为多边形属性时,确定目标地图元素的多边形区域;选取包含于多边形区域的子区域;在子区域中选取目标地图元素的定位点。
在一个实施例中,选取包含于多边形区域的子区域,包括:获取第二偏移距离;将多边形区域各边分别向多边形的内侧偏移第二偏移距离,形成包含于多边形区域的子区域。
在一个实施例中,按照交点添加与目标地图元素匹配的三维虚拟物体,包括:在交点处添加与目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体;当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置。
在一个实施例中,当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置,包括:当碰撞触发器被第一障碍物触发时,向背离第一障碍物的方向调整添加的三维虚拟物体的位置;调整添加的三维虚拟物体的位置时,若碰撞触发器被第二障碍物触发,则放弃添加的三维虚拟物体;调整添加的三维虚拟物体的位置时,若碰撞触发器停止触发,则停止调整添加的三维虚拟物体的位置。
本实施例中,确定三维电子地图中待添加三维虚拟物体的目标地图元素,获取目标地图元素的定位点,无需通过严格的计算才能确定三维虚拟物体的添加位置,只需通过在三维电子地图中生成从天空区指向定位点的射线,沿射线的方向确定射线在三维电子地图中的交点,根据交点添加与目标地图元素匹配的三维虚拟物体即可减少添加的三维虚拟物体出现相交的情况。在整个三维虚拟物体的添加过程中,降低了添加三维虚拟物体的计算量,节省了计算所耗费的时间,提高了三维虚拟物体的添加效率。
在一个实施例中,提供一种计算机可读存储介质,其上存储有计算机可读指令,该计算机可读指令被处理器执行时实现以下步骤:确定三维电子地图中待添加三维虚拟物体的目标地图元素;获取目标地图元素的定位点;在三维电子地图中,生成从天空区指向定位点的射线;沿射线的方向,确定射线在三维电子地图中的交点;按照交点添加与目标地图元素匹配的三维虚拟物体。
在一个实施例中,确定三维电子地图中待添加三维虚拟物体的目标地图元素包括:获取待添加三维虚拟物体的地图元素类型;按照地图元素类型,从三维电子地图中选取目标地图元素;按照交点添加与目标地图元素匹配的三维虚拟物体,包括:在交点对应的地图空余空间中,添加与目标地图元素的地图元素类型匹配的三维虚拟物体。
在一个实施例中,获取目标地图元素的定位点包括:获取目标地图元素的几何属性;确定获取的几何属性所对应的定位点选取方式;按照定位点选取方式选取目标地图元素的定位点。
在一个实施例中,按照定位点选取方式选取目标地图元素的定位点,包括:当几何属性为点状属性时,将目标地图元素所在点作为目标地图元素的定位点。
在一个实施例中,按照定位点选取方式选取目标地图元素的定位点,包括:当几何属性为线状属性时,确定目标地图元素的边缘线;在边缘线上选取目标地图元素的定位点。
在一个实施例中,确定目标地图元素的边缘线,包括:获取目标地图元素的宽度;根据宽度生成大于宽度的一半的第一偏移距离;分别向目标地图元素的中线两侧偏移第一偏移距离,形成目标地图元素的两条边缘线。
在一个实施例中,按照定位点选取方式选取目标地图元素的定位点,包括:当几何属性为多边形属性时,确定目标地图元素的多边形区域;选取包含于多边形区域的子区域;在子区域中选取目标地图元素的定位点。
在一个实施例中,选取包含于多边形区域的子区域,包括:获取第二偏移距离;将多边形区域各边分别向多边形的内侧偏移第二偏移距离,形成包含于多边形区域的子区域。
在一个实施例中,按照交点添加与目标地图元素匹配的三维虚拟物体,包括:在交点处添加与目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体;当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置。
在一个实施例中,当碰撞触发器触发时,调整添加的三维虚拟物体的位置,直至碰撞触发器停止触发时停止调整添加的三维虚拟物体的位置,包括:当碰撞触发器被第一障碍物触发时,向背离第一障碍物的方向调整添加的三维虚拟物体的位置;调整添加的三维虚拟物体的位置时,若碰撞触发器被第二障碍物触发,则放弃添加的三维虚拟物体;调整添加的三维虚拟物体的位置时,若碰撞触发器停止触发,则停止调整添加的三维虚拟物体的位置。
本实施例中,确定三维电子地图中待添加三维虚拟物体的目标地图元素,获取目标地图元素的定位点,无需通过严格的计算才能确定三维虚拟物体的添加位置,只需通过在三维电子地图中生成从天空区指向定位点的射线,沿射线的方向确定射线在三维电子地图中的交点,根据交点添加与目标地图元素匹配的三维虚拟物体即可减少添加的三维虚拟物体出现相交的情况。在整个三维虚拟物体的添加过程中,降低了添加三维虚拟物体的计算量,节省了计算所耗费的时间,提高了三维虚拟物体的添加效率。
本领域普通技术人员可以理解实现上述实施例方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成,该计算机程序可存储于一计算机可读取存储介质中,该程序在执行时,可包括如上述各方法的实施例的流程。其中,前述的存储介质可为磁碟、光盘、只读存储记忆体(Read-Only Memory,ROM)等非易失性存储介质,或随机存储记忆体(Random Access Memory,RAM)等。
以上所述实施例的各技术特征可以进行任意的组合,为使描述简洁,未对上述实施例中的各个技术特征所有可能的组合都进行描述,然而,只要这些技术特征的组合不存在矛盾,都应当认为是本说明书记载的范围。
以上所述实施例仅表达了本发明的几种实施方式,其描述较为具体和详细,但并不能因此而理解为对发明专利范围的限制。应当指出的是,对于本领域的普通技术人员来说,在不脱离本发明构思的前提下,还可以做出若干变形和改进,这些都属于本发明的保护范围。因此,本发明专利的保护范围应以所附权利要求为准。

Claims (15)

1.一种电子地图处理方法,所述方法包括:
确定三维电子地图中待添加三维虚拟物体的目标地图元素;
获取所述目标地图元素的定位点;
在所述三维电子地图中,生成从天空区指向所述定位点的射线;
沿所述射线的方向,确定所述射线在所述三维电子地图中的交点;
按照所述交点添加与所述目标地图元素匹配的三维虚拟物体。
2.根据权利要求1所述的方法,其特征在于,所述确定三维电子地图中待添加三维虚拟物体的目标地图元素包括:
获取待添加三维虚拟物体的地图元素类型;
按照所述地图元素类型,从所述三维电子地图中选取目标地图元素;
所述按照所述交点添加与所述目标地图元素匹配的三维虚拟物体,包括:
在所述交点对应的地图空余空间中,添加与所述目标地图元素的地图元素类型匹配的三维虚拟物体。
3.根据权利要求1所述的方法,其特征在于,所述获取所述目标地图元素的定位点包括:
获取所述目标地图元素的几何属性;
确定获取的几何属性所对应的定位点选取方式;
按照所述定位点选取方式选取所述目标地图元素的定位点。
4.根据权利要求3所述的方法,其特征在于,所述按照所述定位点选取方式选取所述目标地图元素的定位点,包括:
当所述几何属性为点状属性时,将所述目标地图元素所在点作为所述目标地图元素的定位点。
5.根据权利要求3所述的方法,其特征在于,所述按照所述定位点选取方式选取所述目标地图元素的定位点,包括:
当所述几何属性为线状属性时,确定所述目标地图元素的边缘线;
在所述边缘线上选取所述目标地图元素的定位点。
6.根据权利要求5所述的方法,其特征在于,所述确定所述目标地图元素的边缘线,包括:
获取所述目标地图元素的宽度;
根据所述宽度生成大于所述宽度的一半的第一偏移距离;
分别向所述目标地图元素的中线两侧偏移所述第一偏移距离,形成所述目标地图元素的两条边缘线。
7.根据权利要求3所述的方法,其特征在于,所述按照所述定位点选取方式选取所述目标地图元素的定位点,包括:
当所述几何属性为多边形属性时,确定所述目标地图元素的多边形区域;
选取包含于所述多边形区域的子区域;
在所述子区域中选取所述目标地图元素的定位点。
8.根据权利要求7所述的方法,其特征在于,所述选取包含于所述多边形区域的子区域,包括:
获取第二偏移距离;
将所述多边形区域各边分别向所述多边形的内侧偏移所述第二偏移距离,形成包含于所述多边形区域的子区域。
9.根据权利要求1至8中任一项所述的方法,其特征在于,所述按照所述交点添加与所述目标地图元素匹配的三维虚拟物体,包括:
在所述交点处添加与所述目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体;
当所述碰撞触发器触发时,调整添加的所述三维虚拟物体的位置,直至所述碰撞触发器停止触发时停止调整添加的所述三维虚拟物体的位置。
10.根据权利要求9所述的方法,其特征在于,所述当所述碰撞触发器触发时,调整添加的所述三维虚拟物体的位置,直至所述碰撞触发器停止触发时停止调整添加的所述三维虚拟物体的位置,包括:
当所述碰撞触发器被第一障碍物触发时,向背离所述第一障碍物的方向调整添加的所述三维虚拟物体的位置;
调整添加的所述三维虚拟物体的位置时,若所述碰撞触发器被第二障碍物触发,则放弃添加的所述三维虚拟物体;
调整添加的所述三维虚拟物体的位置时,若所述碰撞触发器停止触发,则停止调整添加的所述三维虚拟物体的位置。
11.一种电子地图处理装置,其特征在于,所述装置包括:
元素确定模块,用于确定三维电子地图中待添加三维虚拟物体的目标地图元素;
定位点获取模块,用于获取所述目标地图元素的定位点;
射线生成模块,用于在所述三维电子地图中,生成从天空区指向所述定位点的射线;
交点确定模块,用于沿所述射线的方向,确定所述射线在所述三维电子地图中的交点;
物体添加模块,用于按照所述交点添加与所述目标地图元素匹配的三维虚拟物体。
12.根据权利要求11所述的装置,其特征在于,所述定位点获取模块包括:
几何属性获取模块,用于获取所述目标地图元素的几何属性;
选取方式确定模块,用于确定获取的几何属性所对应的定位点选取方式;
定位点选取模块,用于按照所述定位点选取方式选取所述目标地图元素的定位点。
13.根据权利要求11或12中所述的装置,其特征在于,所述物体添加模块包括:
虚拟物体添加模块,用于在所述交点处添加与所述目标地图元素匹配的、且具有碰撞触发器的三维虚拟物体;
添加位置调整模块,用于当所述碰撞触发器触发时,调整添加的所述三维虚拟物体的位置,直至所述碰撞触发器停止触发时停止调整添加的所述三维虚拟物体的位置。
14.根据权利要求13所述的装置,其特征在于,所述添加位置调整模块还用于当所述碰撞触发器被第一障碍物触发时,向背离所述第一障碍物的方向调整添加的所述三维虚拟物体的位置;调整添加的所述三维虚拟物体的位置时,若所述碰撞触发器被第二障碍物触发,则放弃添加的所述三维虚拟物体;调整添加的所述三维虚拟物体的位置时,若所述碰撞触发器停止触发,则停止调整添加的所述三维虚拟物体的位置。
15.一种计算机设备,包括存储器和处理器,所述存储器中存储有计算机可读指令,所述计算机可读指令被所述处理器执行时,使得所述处理器执行如权利要求1至8中任一项所述方法的步骤。
CN201710405645.7A 2017-06-01 2017-06-01 电子地图处理方法、装置和计算机设备 Active CN108986224B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201710405645.7A CN108986224B (zh) 2017-06-01 2017-06-01 电子地图处理方法、装置和计算机设备

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201710405645.7A CN108986224B (zh) 2017-06-01 2017-06-01 电子地图处理方法、装置和计算机设备

Publications (2)

Publication Number Publication Date
CN108986224A true CN108986224A (zh) 2018-12-11
CN108986224B CN108986224B (zh) 2021-08-17

Family

ID=64501843

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201710405645.7A Active CN108986224B (zh) 2017-06-01 2017-06-01 电子地图处理方法、装置和计算机设备

Country Status (1)

Country Link
CN (1) CN108986224B (zh)

Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102870146A (zh) * 2010-03-11 2013-01-09 株式会社吉奥技术研究所 三维地图绘制系统
CN103198522A (zh) * 2013-04-23 2013-07-10 清华大学 三维场景模型生成方法
CN103440682A (zh) * 2013-08-13 2013-12-11 北京农业信息技术研究中心 一种快速三维成图方法和系统
US20140071119A1 (en) * 2012-09-11 2014-03-13 Apple Inc. Displaying 3D Objects in a 3D Map Presentation
CN104995665A (zh) * 2012-12-21 2015-10-21 Metaio有限公司 用于在真实环境中表示虚拟信息的方法
CN105303595A (zh) * 2014-07-30 2016-02-03 Tcl集团股份有限公司 一种基于三维虚拟场景的物体智能避障方法及系统
CN105955455A (zh) * 2016-04-15 2016-09-21 北京小鸟看看科技有限公司 一种在虚拟场景中添加对象的装置和方法
CN105957144A (zh) * 2016-04-25 2016-09-21 上海梦然网络科技有限公司 三维游戏地图的呈现方法及其呈现系统
US9613454B2 (en) * 2013-08-08 2017-04-04 Adobe Systems Incorporated Automatic geometry and lighting inference for realistic image editing
KR20170045809A (ko) * 2015-10-20 2017-04-28 삼성전자주식회사 커스틱을 표현하는 방법 및 장치

Patent Citations (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN102870146A (zh) * 2010-03-11 2013-01-09 株式会社吉奥技术研究所 三维地图绘制系统
US20140071119A1 (en) * 2012-09-11 2014-03-13 Apple Inc. Displaying 3D Objects in a 3D Map Presentation
CN104995665A (zh) * 2012-12-21 2015-10-21 Metaio有限公司 用于在真实环境中表示虚拟信息的方法
CN103198522A (zh) * 2013-04-23 2013-07-10 清华大学 三维场景模型生成方法
US9613454B2 (en) * 2013-08-08 2017-04-04 Adobe Systems Incorporated Automatic geometry and lighting inference for realistic image editing
CN103440682A (zh) * 2013-08-13 2013-12-11 北京农业信息技术研究中心 一种快速三维成图方法和系统
CN105303595A (zh) * 2014-07-30 2016-02-03 Tcl集团股份有限公司 一种基于三维虚拟场景的物体智能避障方法及系统
KR20170045809A (ko) * 2015-10-20 2017-04-28 삼성전자주식회사 커스틱을 표현하는 방법 및 장치
CN105955455A (zh) * 2016-04-15 2016-09-21 北京小鸟看看科技有限公司 一种在虚拟场景中添加对象的装置和方法
CN105957144A (zh) * 2016-04-25 2016-09-21 上海梦然网络科技有限公司 三维游戏地图的呈现方法及其呈现系统

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
朱效民: "矢量地图叠加分析算法研究", 《中国图象图形学报》 *

Also Published As

Publication number Publication date
CN108986224B (zh) 2021-08-17

Similar Documents

Publication Publication Date Title
CN110309236B (zh) 地图中寻路的方法、装置、计算机设备和存储介质
CN108052662B (zh) 基于网页的组件布局方法、装置、设备及存储介质
CN104360816A (zh) 截屏方法及系统
CN103593861A (zh) 一种面向2.5维地图服务的瓦片加载方法
CN111197993B (zh) 地图的渲染方法、装置、计算机设备和存储介质
CN113010937B (zh) 构件截面钢筋的参数化建模方法及相关装置
EP3603761A1 (en) Method and device for locking target object in game scene, electronic device and storage medium
CN107466108A (zh) 一种通信连接方法和移动终端
CN103529959B (zh) 基于关键点射线碰撞检测的框选方法、系统及电子设备
EP4015999B1 (en) Road updating method and apparatus for electronic map, computer device, and storage medium
CN106372560A (zh) 一种二维码探测图形的检测方法和装置、终端
CN102779148A (zh) 产生数据库的方法、导航装置和确定高度信息的方法
CN109697733A (zh) 点云空间寻点方法、装置、计算机设备和存储介质
CN114166312A (zh) 一种车辆油量测量方法、装置、计算机设备及存储介质
KR101459005B1 (ko) 3차원 지도의 관심지점 표시 제어 방법
CN108986224A (zh) 电子地图处理方法、装置和计算机设备
CN112395375B (zh) 一种地图呈现方法及终端、计算机可读存储介质
CN111024113A (zh) 基于GMap的导航路径方向箭头绘制方法及系统、设备
US10275109B2 (en) Traversing between nodes
CN108536698B (zh) web数据三维展示方法及装置
CN115794980A (zh) 一种数据展示方法、设备、装置及介质
CN115390976A (zh) 界面设计的布局方法、界面的展示方法及相关设备
CN112634425B (zh) 模型的渲染方法、装置、存储介质及计算机设备
CN112484729B (zh) 导航地图切换方法、装置、终端设备及存储介质
CN109949360A (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