CN107952243B - 路径确定方法及装置 - Google Patents

路径确定方法及装置 Download PDF

Info

Publication number
CN107952243B
CN107952243B CN201711230909.6A CN201711230909A CN107952243B CN 107952243 B CN107952243 B CN 107952243B CN 201711230909 A CN201711230909 A CN 201711230909A CN 107952243 B CN107952243 B CN 107952243B
Authority
CN
China
Prior art keywords
node
path
obstacle
nodes
position information
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
Application number
CN201711230909.6A
Other languages
English (en)
Other versions
CN107952243A (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.)
Hangzhou Electronic Soul Network Technology Co Ltd
Original Assignee
Hangzhou Electronic Soul Network Technology 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 Hangzhou Electronic Soul Network Technology Co Ltd filed Critical Hangzhou Electronic Soul Network Technology Co Ltd
Priority to CN201711230909.6A priority Critical patent/CN107952243B/zh
Publication of CN107952243A publication Critical patent/CN107952243A/zh
Application granted granted Critical
Publication of CN107952243B publication Critical patent/CN107952243B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F13/00Video games, i.e. games using an electronically generated display having two or more dimensions
    • A63F13/55Controlling game characters or game objects based on the game progress
    • A63F13/56Computing the motion of game characters with respect to other game characters, game objects or elements of the game scene, e.g. for simulating the behaviour of a group of virtual soldiers or for path finding
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/011Arrangements for interaction with the human body, e.g. for user immersion in virtual reality
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/04Forecasting or optimisation specially adapted for administrative or management purposes, e.g. linear programming or "cutting stock problem"
    • G06Q10/047Optimisation of routes or paths, e.g. travelling salesman problem
    • AHUMAN NECESSITIES
    • A63SPORTS; GAMES; AMUSEMENTS
    • A63FCARD, BOARD, OR ROULETTE GAMES; INDOOR GAMES USING SMALL MOVING PLAYING BODIES; VIDEO GAMES; GAMES NOT OTHERWISE PROVIDED FOR
    • A63F2300/00Features of games using an electronically generated display having two or more dimensions, e.g. on a television screen, showing representations related to the game
    • A63F2300/60Methods for processing data by generating or executing the game program
    • A63F2300/64Methods for processing data by generating or executing the game program for computing dynamical parameters of game objects, e.g. motion determination or computation of frictional forces for a virtual car
    • A63F2300/646Methods for processing data by generating or executing the game program for computing dynamical parameters of game objects, e.g. motion determination or computation of frictional forces for a virtual car for calculating the trajectory of an object

Landscapes

  • Engineering & Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Theoretical Computer Science (AREA)
  • Human Resources & Organizations (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • Economics (AREA)
  • Strategic Management (AREA)
  • Multimedia (AREA)
  • Human Computer Interaction (AREA)
  • General Physics & Mathematics (AREA)
  • Game Theory and Decision Science (AREA)
  • Tourism & Hospitality (AREA)
  • General Business, Economics & Management (AREA)
  • Quality & Reliability (AREA)
  • Operations Research (AREA)
  • Marketing (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Development Economics (AREA)
  • Data Exchanges In Wide-Area Networks (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

本发明提供一种路径确定方法及装置,涉及计算机技术领域。本发明提供的方案通过沿障碍区的边缘搜索路径,以减少计算量,从而降低对电子设备对计算资源的消耗。具体地,该方案通过获取场景地图上起点位置的第一位置信息及终点位置的第二位置信息;根据第一位置信息、第二位置信息及曼哈顿算法,构建第一路径;判断第一路径是否经过所述障碍区;当第一路径经过所述障碍区时,获取与障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径;将第一路径中位于障碍区内的路径替换成避障路径,以形成目标路径,该目标路径为起点位置到终点位置的路径。

Description

路径确定方法及装置
技术领域
本发明涉及计算机技术领域,具体而言,涉及一种路径确定方法及装置。
背景技术
目前,由于互联网传输速度的提升,大量应用、虚拟现实服务在互联网上逐步扩展,例如虚拟展馆、虚拟博物馆、3D游戏等,这些应用服务必须使用寻路系统,帮助移动单位绕过障碍物到达目的地。特别是在带有多人在线版本的虚拟现实应用中,例如3D游戏,其寻路系统需要计算当前位置与目的位置之间的移动的路径,通常通过穷举的方式计算两点之间的路径,计算过程中要消耗服务器大量的计算资源。
发明内容
为了克服上述现有技术中的不足,本发明提供一种路径确定方法及装置,通过沿障碍区的边缘进行搜索减少了计算量,进而解决上述问题。
为了实现上述目的,本发明较佳实施例所提供的技术方案如下所示:
本发明较佳实施例提供一种路径确定方法,应用于电子设备,所述电子设备存储有场景地图,所述场景地图包括可达的畅通区域及不可达的障碍区,所述场景地图包括呈阵列分布的节点,所述节点包括畅通节点及障碍节点,每个所述节点关联有对应的位置信息,所述位置信息包括所述节点对应的横纵坐标数据;该方法包括:
获取所述场景地图上起点位置的第一位置信息及终点位置的第二位置信息;
根据所述第一位置信息、第二位置信息及曼哈顿算法,构建第一路径;
判断所述第一路径是否经过所述障碍区;
当所述第一路径经过所述障碍区时,获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径;
将所述第一路径中位于所述障碍区内的路径替换成所述避障路径,以形成目标路径,所述目标路径为所述起点位置到所述终点位置的路径。
可选地,上述获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径的步骤,包括:
将所述第一路径中靠近所述起点位置且与所述障碍区相邻的畅通节点作为第1避障节点;
从与第i避障节点相邻的周边节点中选取与所述障碍区相邻的畅通节点,以作为与所述第i避障节点连接的第i+1避障节点,其中,i为大于等于1的整数;
当选取的所述第i+1避障节点为中断节点时,停止选取,并连接相邻的避障节点,以形成所述避障路径,其中,所述中断节点为所述第一路径中靠近所述终点位置且与所述障碍区相邻的畅通节点。
可选地,若所述第1避障节点与所述中断节点存在至少两条避障路径时,所述方法还包括:
选取包含的节点数最少的避障路径作为目标避障路径。
可选地,上述方法还包括:
对所述目标路径进行优化,将优化后的目标路径作为所述起点位置到所述终点位置的新路径。
可选地,上述对所述目标路径进行优化,将优化后的目标路径作为所述起点位置到所述终点位置的新路径的步骤,包括:
对所述目标路径上的各节点进行连续编号,将所述起点位置的节点作为第1节点;
判断第k节点与第k+1节点的横坐标或纵坐标是否相同,其中,k为大于等于1的整数,所述第k+1节点为与所述第k节点相邻的下一节点,均位于所述目标路径中;
若所述第k节点与第k+1节点横坐标相同,从所述第k节点之后的节点中查找是否存在与第k节点的纵坐标相同的节点,且查找的所述节点与所述第k节点之间的形成的直线路径不经过所述障碍区;
若存在查找的节点,以查找的所述节点与所述第k节点之间的形成的直线路径,替换原目标路径中查找的所述节点与所述第k+1节点的路径,以形成新的目标路径。
可选地,上述对所述目标路径进行优化,将优化后的目标路径作为所述起点位置到所述终点位置的新路径的步骤,包括:
对所述目标路径上的各节点进行连续编号,将所述起点位置的节点作为第1节点;
判断第k节点与第k+1节点的横坐标或纵坐标是否相同,其中,k为大于等于1的整数,所述第k+1节点为与所述第k节点相邻的下一节点,均位于所述目标路径中;
若所述第k节点与第k+1节点纵坐标相同,从所述第k节点之后的节点中查找是否存在与第k节点的横坐标相同的节点,且查找的所述节点与所述第k节点之间的形成的直线路径不经过所述障碍区;
若存在查找的节点,以查找的所述节点与所述第k节点之间的形成的直线路径,替换原目标路径中查找的所述节点与所述第k+1节点的路径,以形成新的目标路径。
可选地,上述判断所述第一路径是否经过障碍区的步骤,包括:
若所述第一路径中的节点的位置信息中存在位于所述障碍区对应的位置范围内的位置信息,所述第一路径便经过所述障碍区;
若所述第一路径中的节点的位置信息均不位于所述障碍区对应的位置范围内,所述第一路径便不经过所述障碍区。
可选地,当所述第一路径不经过所述障碍区时,所述方法还包括:
将构建的所述第一路径作为所述目标路径。
本发明的较佳实施例还提供一种路径确定装置,应用于电子设备,所述电子设备存储有场景地图,所述场景地图包括可达的畅通区域及不可达的障碍区,所述场景地图包括呈阵列分布的节点,所述节点包括畅通节点及障碍节点,每个所述节点关联有对应的位置信息,所述位置信息包括所述节点对应的横纵坐标数据;所述路径确定装置包括:
位置获取单元,用于获取所述场景地图上起点位置的第一位置信息及终点位置的第二位置信息;
路径构建单元,用于根据所述第一位置信息、第二位置信息及曼哈顿算法,构建第一路径;
障碍判断单元,用于判断所述第一路径是否经过所述障碍区;
获取连接单元,用于当所述第一路径经过所述障碍区时,获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径;
路径替换单元,用于将所述第一路径中位于所述障碍区内的路径替换成所述避障路径,以形成目标路径,所述目标路径为所述起点位置到所述终点位置的路径。
可选地,上述获取连接单元还用于:
将所述第一路径中靠近所述起点位置且与所述障碍区相邻的畅通节点作为第1避障节点;
从与第i避障节点相邻的周边节点中选取与所述障碍区相邻的畅通节点,以作为与所述第i避障节点连接的第i+1避障节点,其中,i为大于等于1的整数;
当选取的所述第i+1避障节点为中断节点时,停止选取,并连接相邻的避障节点,以形成所述避障路径,其中,所述中断节点为所述第一路径中靠近所述终点位置且与所述障碍区相邻的畅通节点。
相对于现有技术而言,本发明提供的路径确定方法及装置至少具有以下有益效果:本发明提供的方案通过沿障碍区的边缘搜索路径,以减少计算量,从而降低对电子设备对计算资源的消耗。具体地,该方案通过获取场景地图上起点位置的第一位置信息及终点位置的第二位置信息;根据第一位置信息、第二位置信息及曼哈顿算法,构建第一路径;判断第一路径是否经过所述障碍区;当第一路径经过所述障碍区时,获取与障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径;将第一路径中位于障碍区内的路径替换成避障路径,以形成目标路径,该目标路径为起点位置到终点位置的路径。
为使本发明的上述目的、特征和优点能更明显易懂,下文特举本发明较佳实施例,并配合所附附图,作详细说明如下。
附图说明
为了更清楚地说明本发明实施例的技术方案,下面将对实施例中所需要使用的附图作简单地介绍。应当理解,以下附图仅示出了本发明的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
图1为本发明较佳实施例提供的电子设备的方框示意图。
图2为本发明较佳实施例提供的路径确定方法的流程示意图。
图3为本发明较佳实施例提供的图2中步骤S240的子步骤的流程示意图。
图4为本发明方法的节点状态标识示意图。
图5为本发明方法得到的路径的示意图。
图6为本发明较佳实施例提供的路径确定装置的方框示意图。
图标:10-电子设备;11-处理单元;12-通信单元;13-存储单元;100-路径确定装置;110-位置获取单元;120-路径构建单元;130-障碍判断单元;140-获取连接单元;150-路径替换单元。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述。显然,所描述的实施例仅仅是本发明的一部分实施例,而不是全部的实施例。通常在此处附图中描述和示出的本发明实施例的组件可以以各种不同的配置来布置和设计。
因此,以下对在附图中提供的本发明的实施例的详细描述并非旨在限制要求保护的本发明的范围,而是仅仅表示本发明的选定实施例。基于本发明的实施例,本领域技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。此外,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
在现有技术中,例如,在游戏地图中确定两目标之间的路径时(两目标之间存在障碍),通常通过穷举的方式得到两目标之间的路径,导致对计算资源的消耗较大。可理解地,该计算资源可以为电子设备的处理器中用于计算距离的部分所占百分比。
如何提供一种科学的路径确定方法,能够降低对计算资源的消耗,是本领域技术人员的一大难题。鉴于上述问题,本申请发明人经过长期研究探索,提出以下实施例以解决上述问题。下面结合附图,对本发明实施例作详细说明。在不冲突的情况下,下述的实施例及实施例中的特征可以相互组合。
请参照图1,为本发明较佳实施例提供的电子设备10的方框示意图。该电子设备10可以是,但不限于,智能手机、个人电脑(personal computer,PC)、平板电脑、个人数字助理(personal digital assistant,PDA)、移动上网设备(mobile Internet device,MID)等。
在本实施例中,所述电子设备10可以包括处理单元11、通信单元12、存储单元13以及路径确定装置100,所述处理单元11、通信单元12、存储单元13以及路径确定装置100各个元件之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通讯总线或信号线实现电性连接。
所述处理单元11可以是处理器。例如,该处理器可以是中央处理器(CentralProcessing Unit,CPU)、网络处理器(Network Processor,NP)、图形处理器(GraphicsProcessing Unit,GPU)等;还可以是数字信号处理器(DSP)、专用集成电路(ASIC)、现场可编程门阵列(FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本发明实施例中的公开的各方法、步骤及逻辑框图。
所述通信单元12用于通过网络与服务器的通信连接,并通过所述网络收发数据。该服务器可以为用于游戏服务的游戏服务器。
所述存储单元13可以是,但不限于,随机存取存储器,只读存储器,可编程只读存储器,可擦除可编程只读存储器,电可擦除可编程只读存储器等。在本实施例中,所述存储单元13可以用于存储场景地图。当然,所述存储器还可以用于存储程序,所述处理单元11在接收到执行指令后,执行该程序。
进一步地,所述路径确定装置100包括至少一个可以软件或固件(firmware)的形式存储于所述存储单元13中或固化在所述电子设备10操作系统(operating system,OS)中的软件功能模块。所述处理单元11用于执行所述存储单元13中存储的可执行模块,例如路径确定装置100所包括的软件功能模块及计算机程序等。
可以理解的是,图1所示的结构仅为电子设备10的一种结构示意图,所述电子设备10还可以包括比图1所示更多或更少的组件。比如,该电子设备10可以作为单机游戏设备,不设置通信单元12。图1中所示的各组件可以采用硬件、软件或其组合实现。
请参照图2,为本发明较佳实施例提供的路径确定方法的流程示意图。在本实施例中,路径确定方法可应用于上述的电子设备10,通过该电子设备10执行该路径确定方法,以减少对计算资源的消耗。其中,该电子设备10存储有场景地图,所述场景地图包括可达的畅通区域及不可达的障碍区,所述场景地图包括呈阵列分布的节点,所述节点包括畅通节点及障碍节点,每个所述节点关联有对应的位置信息,所述位置信息包括所述节点对应的横纵坐标数据。
可理解地,一个节点可以指场景地图中的一个矩形网格区域,障碍区内的节点为游戏角色不可经过的节点,也就是障碍节点;畅通区域内的节点为游戏角色可经过的节点,也就是畅通节点。
下面将对图2中所示路径确定方法的各步骤进行详细阐述,在本实施例中,该路径确定方法可以包括以下步骤:
步骤S210,获取所述场景地图上起点位置的第一位置信息及终点位置的第二位置信息。
可理解地,起点位置可以为目标游戏角色所在的位置(节点)的坐标数据,终点位置为目标游戏角色需要到达的目的位置的坐标数据。
步骤S220,根据所述第一位置信息、第二位置信息及曼哈顿算法,构建第一路径。
可选地,沿与起点的横坐标相同的方向向靠近终点的方向构建第一路径,在构建的节点的纵坐标与终点的纵坐标相同时,以当前节点为拐点,沿直线向终点继续构建路径,直到构建的节点与终点相邻,便停止构建。
或者,沿与起点的纵坐标相同的方向向靠近终点的方向构建第一路径,在构建的节点的横坐标与终点的横坐标相同时,以当前节点为拐点,沿直线向终点继续构建路径,直到构建的节点与终点相邻,便停止构建。
步骤S230,判断所述第一路径是否经过所述障碍区。
可理解地,若所述第一路径中的节点的位置信息中存在位于所述障碍区对应的位置范围内的位置信息,所述第一路径便经过所述障碍区;
若所述第一路径中的节点的位置信息均不位于所述障碍区对应的位置范围内,所述第一路径便不经过所述障碍区。
进一步地,若第一路径不经过障碍区,构建的第一路径便为起点位置与终点位置之间的路径,也就是目标路径。若第一路径经过障碍区,则沿该障碍区的边缘构建路径。
步骤S240,当所述第一路径经过所述障碍区时,获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径。
请参照图3,为本发明较佳实施例提供的图2中步骤S240的子步骤的流程示意图。可选地,步骤S240可以包括子步骤S241至子步骤S243。
子步骤S241,将所述第一路径中靠近所述起点位置且与所述障碍区相邻的畅通节点作为第1避障节点。
子步骤S242,从与第i避障节点相邻的周边节点中选取与所述障碍区相邻的畅通节点,以作为与所述第i避障节点连接的第i+1避障节点,其中,i为大于等于1的整数。
子步骤S243,当选取的所述第i+1避障节点为中断节点时,停止选取,并连接相邻的避障节点,以形成所述避障路径,其中,所述中断节点为所述第一路径中靠近所述终点位置且与所述障碍区相邻的畅通节点。
可理解地,避障节点为预组成避障路径的节点,而所述第一路径中靠近所述起点位置且与所述障碍区相邻的畅通节点作为第1避障节点,与第1避障节点相邻的避障节点为第2避障节点。也就是从与第i避障节点相邻的周边节点中选取与所述障碍区相邻的畅通节点,以作为与所述第i避障节点连接的第i+1避障节点,然后针对选取的每个避障节点,分别将相邻的两个避障节点连接(或者按照避障节点的递增顺序或递减顺序依次将各避障节点连接起来),以组成避障路径。
可选地,若所述第1避障节点与所述中断节点存在至少两条避障路径时,所述方法还包括:选取包含的节点数最少的避障路径作为目标避障路径,以优化确定的路径,进而减少起点到终点的路径的距离。
步骤S250,将所述第一路径中位于所述障碍区内的路径替换成所述避障路径,以形成目标路径,所述目标路径为所述起点位置到所述终点位置的路径。
可选地,该方法在步骤S250之后,还可以对目标路径进行优化。例如,该方法还可以包括:对所述目标路径进行优化,将优化后的目标路径作为所述起点位置到所述终点位置的新路径。
可选地,对目标路径进行优化的步骤可以包括:对所述目标路径上的各节点进行连续编号,将所述起点位置的节点作为第1节点;判断第k节点与第k+1节点的横坐标或纵坐标是否相同,其中,k为大于等于1的整数,所述第k+1节点为与所述第k节点相邻的下一节点,均位于所述目标路径中;若所述第k节点与第k+1节点横坐标相同,从所述第k节点之后的节点中查找是否存在与第k节点的纵坐标相同的节点,且查找的所述节点与所述第k节点之间的形成的直线路径不经过所述障碍区;若存在查找的节点,以查找的所述节点与所述第k节点之间的形成的直线路径,替换原目标路径中查找的所述节点与所述第k+1节点的路径,以形成新的目标路径。
或者,对目标路径进行优化的步骤包括:对所述目标路径上的各节点进行连续编号,将所述起点位置的节点作为第1节点;判断第k节点与第k+1节点的横坐标或纵坐标是否相同,其中,k为大于等于1的整数,所述第k+1节点为与所述第k节点相邻的下一节点,均位于所述目标路径中;若所述第k节点与第k+1节点纵坐标相同,从所述第k节点之后的节点中查找是否存在与第k节点的横坐标相同的节点,且查找的所述节点与所述第k节点之间的形成的直线路径不经过所述障碍区;若存在查找的节点,以查找的所述节点与所述第k节点之间的形成的直线路径,替换原目标路径中查找的所述节点与所述第k+1节点的路径,以形成新的目标路径。
请结合参照图4和图5,其中,图4为本发明方法的节点状态标识示意图,图5为本发明方法得到的路径的示意图。其中,A所在的节点可用于表示起点位置,B所在的节点可用于表示终点位置。目标路径可以为如图5中所示的待优化节点及确定的路径节点组合成的路径。而待优化节点组成的路径可被优化节点组成的路径进行替换,以得到新的目标路径,而该新的目标路径也就是确定的起点位置与终点位置的路径。
进一步地,图5中所示m、n均为大于等于1的整数,m表示当前节点沿确定的路径到起点位置的节点数(或者距离);n表示起点位置到终点位置的曼哈顿距离,且m小于等于n。可理解地,上述第1避障节点为图5中m=3的节点,上述中断节点为m=21的节点,在对首次确定的目标路径进行优化时,m=9的节点便为优化时查找的节点(在图5中,可理解为m=9的节点与起点的横坐标相同)。
基于上述设计,通过沿障碍区的边缘计算确定起点到终点的路径,减少了对路径确定的计算量,进而降低对计算资源的消耗,另外,通过对首次得到的目标路径进行优化,可得到路径距离更短的目标路径。
请参照图6,为本发明较佳实施例提供的路径确定装置100的方框示意图。该路径确定装置100可以应用于电子设备10,用于执行上述的路径确定方法。该电子设备10存储有场景地图,所述场景地图包括可达的畅通区域及不可达的障碍区,所述场景地图包括呈阵列分布的节点,所述节点包括畅通节点及障碍节点,每个所述节点关联有对应的位置信息,所述位置信息包括所述节点对应的横纵坐标数据。其中,该路径确定装置100可以包括位置获取单元110、路径构建单元120、障碍判断单元130、获取连接单元140及路径替换单元150。
位置获取单元110,用于获取所述场景地图上起点位置的第一位置信息及终点位置的第二位置信息。具体地,位置获取单元110可以用于执行图2所示的步骤S210,具体执行的操作内容可参照对步骤S210的详细描述。
路径构建单元120,用于根据所述第一位置信息、第二位置信息及曼哈顿算法,构建第一路径。具体地,路径构建单元120可以用于执行图2所示的步骤S220,具体执行的操作内容可参照对步骤S220的详细描述。
障碍判断单元130,用于判断所述第一路径是否经过所述障碍区。具体地,障碍判断单元130可以用于执行图2所示的步骤S230,具体执行的操作内容可参照对步骤S230的详细描述。
获取连接单元140,用于当所述第一路径经过所述障碍区时,获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径。
可选地,获取连接单元140还用于:将所述第一路径中靠近所述起点位置且与所述障碍区相邻的畅通节点作为第1避障节点;从与第i避障节点相邻的周边节点中选取与所述障碍区相邻的畅通节点,以作为与所述第i避障节点连接的第i+1避障节点,其中,i为大于等于1的整数;当选取的所述第i+1避障节点为中断节点时,停止选取,并连接相邻的避障节点,以形成所述避障路径,其中,所述中断节点为所述第一路径中靠近所述终点位置且与所述障碍区相邻的畅通节点。
具体地,获取连接单元140可以用于执行图2所示的步骤S240及图3所示的步骤S240的各子步骤,具体执行的操作内容可参照对步骤S240及其子步骤的详细描述。
路径替换单元150,用于将所述第一路径中位于所述障碍区内的路径替换成所述避障路径,以形成目标路径,所述目标路径为所述起点位置到所述终点位置的路径。具体地,路径替换单元150可以用于执行图2所示的步骤S250,具体执行的操作内容可参照对步骤S250的详细描述。
通过以上的实施方式的描述,本领域的技术人员可以清楚地了解到本发明可以通过硬件实现,也可以借助软件加必要的通用硬件平台的方式来实现,基于这样的理解,本发明的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本发明各个实施场景所述的方法。
综上所述,本发明提供一种路径确定方法及装置。本发明提供的方案通过沿障碍区的边缘搜索路径,以减少计算量,从而降低对电子设备对计算资源的消耗。具体地,该方案通过获取场景地图上起点位置的第一位置信息及终点位置的第二位置信息;根据第一位置信息、第二位置信息及曼哈顿算法,构建第一路径;判断第一路径是否经过所述障碍区;当第一路径经过所述障碍区时,获取与障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径;将第一路径中位于障碍区内的路径替换成避障路径,以形成目标路径,该目标路径为起点位置到终点位置的路径。
以上所述仅为本发明的优选实施例而已,并不用于限制本发明,对于本领域的技术人员来说,本发明可以有各种更改和变化。凡在本发明的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本发明的保护范围之内。

Claims (8)

1.一种路径确定方法,其特征在于,应用于电子设备,所述电子设备存储有场景地图,所述场景地图包括可达的畅通区域及不可达的障碍区,所述场景地图包括呈阵列分布的节点,所述节点包括畅通节点及障碍节点,每个所述节点关联有对应的位置信息,所述位置信息包括所述节点对应的横纵坐标数据;该方法包括:
获取所述场景地图上起点位置的第一位置信息及终点位置的第二位置信息;
根据所述第一位置信息、第二位置信息及曼哈顿算法,构建第一路径;
判断所述第一路径是否经过所述障碍区;
当所述第一路径经过所述障碍区时,获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径;
将所述第一路径中位于所述障碍区内的路径替换成所述避障路径,以形成目标路径,所述目标路径为所述起点位置到所述终点位置的路径;
其中,所述获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径的步骤,包括:
将所述第一路径中靠近所述起点位置且与所述障碍区相邻的畅通节点作为第1避障节点;
从与第i避障节点相邻的周边节点中选取与所述障碍区相邻的畅通节点,以作为与所述第i避障节点连接的第i+1避障节点,其中,i为大于等于1的整数;
当选取的所述第i+1避障节点为中断节点时,停止选取,并连接相邻的避障节点,以形成所述避障路径,其中,所述中断节点为所述第一路径中靠近所述终点位置且与所述障碍区相邻的畅通节点。
2.根据权利要求1所述的方法,其特征在于,若所述第1避障节点与所述中断节点存在至少两条避障路径时,所述方法还包括:
选取包含的节点数最少的避障路径作为目标避障路径。
3.根据权利要求1所述的方法,其特征在于,所述方法还包括:
对所述目标路径进行优化,将优化后的目标路径作为所述起点位置到所述终点位置的新路径。
4.根据权利要求3所述的方法,其特征在于,所述对所述目标路径进行优化,将优化后的目标路径作为所述起点位置到所述终点位置的新路径的步骤,包括:
对所述目标路径上的各节点进行连续编号,将所述起点位置的节点作为第1节点;
判断第k节点与第k+1节点的横坐标或纵坐标是否相同,其中,k为大于等于1的整数,所述第k+1节点为与所述第k节点相邻的下一节点,均位于所述目标路径中;
若所述第k节点与第k+1节点横坐标相同,从所述第k节点之后的节点中查找是否存在与第k节点的纵坐标相同的节点,且查找的所述节点与所述第k节点之间的形成的直线路径不经过所述障碍区;
若存在查找的节点,以查找的所述节点与所述第k节点之间的形成的直线路径,替换原目标路径中查找的所述节点与所述第k+1节点的路径,以形成新的目标路径。
5.根据权利要求3所述的方法,其特征在于,所述对所述目标路径进行优化,将优化后的目标路径作为所述起点位置到所述终点位置的新路径的步骤,包括:
对所述目标路径上的各节点进行连续编号,将所述起点位置的节点作为第1节点;
判断第k节点与第k+1节点的横坐标或纵坐标是否相同,其中,k为大于等于1的整数,所述第k+1节点为与所述第k节点相邻的下一节点,均位于所述目标路径中;
若所述第k节点与第k+1节点纵坐标相同,从所述第k节点之后的节点中查找是否存在与第k节点的横坐标相同的节点,且查找的所述节点与所述第k节点之间的形成的直线路径不经过所述障碍区;
若存在查找的节点,以查找的所述节点与所述第k节点之间的形成的直线路径,替换原目标路径中查找的所述节点与所述第k+1节点的路径,以形成新的目标路径。
6.根据权利要求1-5中任意一项所述的方法,其特征在于,所述判断所述第一路径是否经过障碍区的步骤,包括:
若所述第一路径中的节点的位置信息中存在位于所述障碍区对应的位置范围内的位置信息,所述第一路径便经过所述障碍区;
若所述第一路径中的节点的位置信息均不位于所述障碍区对应的位置范围内,所述第一路径便不经过所述障碍区。
7.根据权利要求1-5中任意一项所述的方法,其特征在于,当所述第一路径不经过所述障碍区时,所述方法还包括:
将构建的所述第一路径作为所述目标路径。
8.一种路径确定装置,其特征在于,应用于电子设备,所述电子设备存储有场景地图,所述场景地图包括可达的畅通区域及不可达的障碍区,所述场景地图包括呈阵列分布的节点,所述节点包括畅通节点及障碍节点,每个所述节点关联有对应的位置信息,所述位置信息包括所述节点对应的横纵坐标数据;所述路径确定装置包括:
位置获取单元,用于获取所述场景地图上起点位置的第一位置信息及终点位置的第二位置信息;
路径构建单元,用于根据所述第一位置信息、第二位置信息及曼哈顿算法,构建第一路径;
障碍判断单元,用于判断所述第一路径是否经过所述障碍区;
获取连接单元,用于当所述第一路径经过所述障碍区时,获取与所述障碍区相邻的畅通节点的位置信息,连接相邻的畅通节点以作为避障路径;
路径替换单元,用于将所述第一路径中位于所述障碍区内的路径替换成所述避障路径,以形成目标路径,所述目标路径为所述起点位置到所述终点位置的路径;
所述获取连接单元还用于:
将所述第一路径中靠近所述起点位置且与所述障碍区相邻的畅通节点作为第1避障节点;
从与第i避障节点相邻的周边节点中选取与所述障碍区相邻的畅通节点,以作为与所述第i避障节点连接的第i+1避障节点,其中,i为大于等于1的整数;
当选取的所述第i+1避障节点为中断节点时,停止选取,并连接相邻的避障节点,以形成所述避障路径,其中,所述中断节点为所述第一路径中靠近所述终点位置且与所述障碍区相邻的畅通节点。
CN201711230909.6A 2017-11-29 2017-11-29 路径确定方法及装置 Active CN107952243B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201711230909.6A CN107952243B (zh) 2017-11-29 2017-11-29 路径确定方法及装置

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201711230909.6A CN107952243B (zh) 2017-11-29 2017-11-29 路径确定方法及装置

Publications (2)

Publication Number Publication Date
CN107952243A CN107952243A (zh) 2018-04-24
CN107952243B true CN107952243B (zh) 2020-08-04

Family

ID=61962560

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201711230909.6A Active CN107952243B (zh) 2017-11-29 2017-11-29 路径确定方法及装置

Country Status (1)

Country Link
CN (1) CN107952243B (zh)

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN108744517B (zh) * 2018-04-27 2022-02-22 网易(杭州)网络有限公司 音频处理方法、装置、终端和存储介质
CN108939547B (zh) * 2018-07-04 2019-06-21 苏州玩友时代科技股份有限公司 一种最佳路径获取方法、装置、设备及存储介质
CN109011575B (zh) * 2018-07-04 2019-07-02 苏州玩友时代科技股份有限公司 一种自动寻路方法、装置和设备
CN109529341A (zh) * 2018-10-23 2019-03-29 深圳豪客互联网有限公司 一种路径规划方法、装置及计算机可读存储介质
CN109657585A (zh) * 2018-12-10 2019-04-19 北京远特科技股份有限公司 倒车控制方法及装置
CN111562778A (zh) * 2019-01-29 2020-08-21 北京奇虎科技有限公司 一种扫地机器人的清扫方法和扫地机器人
CN110141862B (zh) * 2019-06-21 2023-05-05 网易(杭州)网络有限公司 游戏中移动控制的方法及装置、电子设备、存储介质
CN111097167B (zh) * 2019-11-28 2022-05-20 腾讯科技(深圳)有限公司 移动控制方法、服务器、电子装置及存储介质
CN112870720B (zh) * 2021-03-09 2024-07-02 网易(杭州)网络有限公司 游戏中的寻路方法、装置、存储介质及计算机设备

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20070043126A (ko) * 2005-10-20 2007-04-25 (주)아라게이트 게임용 인공지능 엔진시스템
CN104238560A (zh) * 2014-09-26 2014-12-24 深圳市科松电子有限公司 一种非线性路径规划方法及系统
CN104759097A (zh) * 2015-04-13 2015-07-08 四川天上友嘉网络科技有限公司 游戏中的自动寻路方法
CN105138859A (zh) * 2015-09-30 2015-12-09 四川师范大学 三维全景漫游寻路方法及系统
CN106075906A (zh) * 2016-06-03 2016-11-09 腾讯科技(深圳)有限公司 一种模拟对象的寻路方法、场景的搭建方法和对应的装置
CN107228668A (zh) * 2017-05-17 2017-10-03 桂林电子科技大学 一种基于规则网格dem数据的路径规划新方法

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20070043126A (ko) * 2005-10-20 2007-04-25 (주)아라게이트 게임용 인공지능 엔진시스템
CN104238560A (zh) * 2014-09-26 2014-12-24 深圳市科松电子有限公司 一种非线性路径规划方法及系统
CN104759097A (zh) * 2015-04-13 2015-07-08 四川天上友嘉网络科技有限公司 游戏中的自动寻路方法
CN105138859A (zh) * 2015-09-30 2015-12-09 四川师范大学 三维全景漫游寻路方法及系统
CN106075906A (zh) * 2016-06-03 2016-11-09 腾讯科技(深圳)有限公司 一种模拟对象的寻路方法、场景的搭建方法和对应的装置
CN107228668A (zh) * 2017-05-17 2017-10-03 桂林电子科技大学 一种基于规则网格dem数据的路径规划新方法

Also Published As

Publication number Publication date
CN107952243A (zh) 2018-04-24

Similar Documents

Publication Publication Date Title
CN107952243B (zh) 路径确定方法及装置
US9001059B2 (en) Method and apparatus for choosing an intended target element from an imprecise touch on a touch screen display
CN109308386B (zh) 工程图墙体识别方法、装置及电子设备
CN111127612A (zh) 游戏场景节点的更新方法、装置、存储介质和电子设备
CN108303098A (zh) 机器人路径规划方法及设备
CN113254797B (zh) 一种社交网络社区的搜索方法、装置以及处理设备
CN112328880A (zh) 地理区域聚类方法、装置、存储介质和电子设备
CN111135558A (zh) 游戏同步方法、游戏客户端、计算机存储介质及电子设备
CN112711647B (zh) 地图信息显示方法和装置、存储介质及电子设备
CN113730915A (zh) 目标路径的确定方法、装置和存储介质及电子设备
CN110743161B (zh) 虚拟对象控制方法、装置、终端及存储介质
CN113658342A (zh) Ar导航路径生成的方法、系统、电子装置和存储介质
CN111790151A (zh) 一种场景中物体加载方法、装置、存储介质及电子设备
CN108564637B (zh) 几何模型排布方法及装置
CN113723405B (zh) 区域轮廓的确定方法、装置和电子设备
CN105677843A (zh) 一种自动获取宗地四至属性的方法
CN113792170B (zh) 图数据划分方法、装置和计算机设备
CN114470746A (zh) 服务器系统、数据传输方法、装置、设备及存储介质
CN114328783A (zh) 地图数据输出方法、地图数据处理方法、装置和电子设备
CN107895381B (zh) 距离确定方法及装置
CN114201568A (zh) 信息处理方法、生成方法、装置、电子设备以及存储介质
CN114519762A (zh) 模型法线处理方法、装置、存储介质及电子设备
CN110917624A (zh) 路径确定方法、装置及设备
CN108009099B (zh) 一种应用于K-Mean聚类算法中的加速方法及其装置
CN108958902B (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
EE01 Entry into force of recordation of patent licensing contract

Application publication date: 20180424

Assignee: Hangzhou spoon Network Technology Co., Ltd

Assignor: Hangzhou dianhun Network Technology Co., Ltd

Contract record no.: X2021330000727

Denomination of invention: Path determination method and device

Granted publication date: 20200804

License type: Common License

Record date: 20211109

EE01 Entry into force of recordation of patent licensing contract