游戏控制方法、装置、电子设备及存储介质与流程

文档序号:25109339发布日期:2021-05-19 00:20阅读:105来源:国知局
游戏控制方法、装置、电子设备及存储介质与流程

1.本申请涉及计算机技术领域,更具体地,涉及一种游戏控制方法、装置、电子设备及存储介质。


背景技术:

2.随着计算机技术和互联网技术的迅速发展,电子游戏越来越受欢迎,例如,射击类游戏、战术竞技游戏以及角色扮演类游戏等等。在游戏过程中,虚拟角色可能会与游戏场景中的可移动角色发生碰撞而使游戏画面发生卡顿,从而影响玩家的体验。


技术实现要素:

3.有鉴于此,本申请实施例提出了一种游戏控制方法、装置、电子设备及存储介质,可以避免因虚拟角色与游戏场景中的可移动角色发生碰撞而使游戏画面发生卡顿的情况。
4.第一方面,本申请实施例提供了一种游戏控制方法,包括:根据游戏场景配置信息,利用物理引擎创建虚拟场景;根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上执行动作;预测所述虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与所述虚拟角色发生碰撞;当预测存在时,控制所述虚拟角色躲避碰撞。
5.第二方面,本申请实施例提供了一种游戏控制装置,所述装置包括:场景创建模块、动作执行模块、碰撞预测模块、躲避控制模块。场景创建模块,用于根据游戏场景配置信息,利用物理引擎创建虚拟场景;动作执行模块,用于根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上执行动作;碰撞预测模块,用于预测所述虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与所述虚拟角色发生碰撞;躲避控制模块,用于当预测存在时,控制所述虚拟角色躲避碰撞。
6.第三方面,本申请实施例提供了一种电子设备,包括处理器以及存储器;一个或多个程序被存储在所述存储器中并被配置为由所述处理器执行以实现上述的方法。
7.第四方面,本申请实施例提供了一种计算机可读存储介质,所述计算机可读存储介质中存储有程序代码,其中,在所述程序代码被处理器运行时执行上述的方法。
8.第五方面,本申请实施例提供了一种计算机程序产品或计算机程序,该计算机程序产品或计算机程序包括计算机指令,该计算机指令存储在计算机可读存储介质中。计算机设备的处理器从计算机可读存储介质获取该计算机指令,处理器执行该计算机指令,使得该计算机设备执行上述的方法。
9.本申请实施例提供的一种游戏控制方法、装置、电子设备及存储介质,通过根据游戏场景配置信息,利用物理引擎创建虚拟场景,根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上执行动作时,在预测到虚拟角色沿寻路路径移动至目标位置的过程中,存在目标虚拟移动体与虚拟角色发生碰撞时,控制虚拟角色躲避碰撞,以在游戏过程中,有效避免因虚拟角色与其他玩家控制的虚拟角色或非玩家角色发生碰撞而使游戏画面发生卡顿,进而避免因游戏画面发生卡顿而影响玩家操作的情况,从而提升了玩家的体验。
附图说明
10.为了更清楚地说明本申请实施例中的技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本申请的一些实施例,对于本领域技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
11.图1示出了本申请实施例提出的一种系统架构示意图;
12.图2示出了本申请实施例提出的一种游戏控制方法的流程图;
13.图3示出了图2中步骤s110的流程示意图;
14.图4示出了图2中步骤s120的流程示意图;
15.图5示出了本申请实施例提供的一种游戏场景的寻路示意图;
16.图6示出了本申请实施例提出的一种游戏控制方法的另一流程图;
17.图7示出了图6中步骤s250的流程示意图;
18.图8示出了本申请实施例提供的一种游戏控制方法的另一流程图;
19.图9示出了本申请实施例提供的一种游戏控制方法的又一流程图;
20.图10示出了本申请实施例提供的一种游戏场景示意图;
21.图11示出了图10中s1对应的区域的具体场景示意图;
22.图12示出了本申请实施例提供的一种游戏场景另一示意图;
23.图13示出了本申请实施例提供的一种游戏场景另一示意图;
24.图14示出了本申请实施例提供的一种游戏场景另一示意图;
25.图15示出了本申请实施例提供的一种游戏场景另一示意图;
26.图16示出了本申请实施例提供的一种游戏场景另一示意图;
27.图17示出了本申请实施例提供的一种游戏场景又一示意图;
28.图18示出了图17中s2对应的区域的具体场景示意图;
29.图19示出了本申请实施例提出的一种游戏控制装置的结构框图;
30.图20示出了本申请实施例提出的一种游戏控制装置的另一结构框图
31.图21示出了用于执行本申请实施例的方法的电子设备的结构框图;
32.图22示出了本申请实施例的用于保存或者携带实现根据本申请实施例的方法的程序代码的存储单元。
具体实施方式
33.下面将结合本申请实施例中的附图,对本申请实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本申请一部分实施例,而不是全部的实施例。基于本申请中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本申请保护的范围。
34.人工智能(artificial intelligence,ai)是利用数字计算机或者数字计算机控制的机器模拟、延伸和扩展人的智能,感知环境、获取知识并使用知识获得最佳结果的理论、方法、技术及应用系统。换句话说,人工智能是计算机科学的一个综合技术,它企图了解智能的实质,并生产出一种新的能以人类智能相似的方式做出反应的智能机器。人工智能也就是研究各种智能机器的设计原理与实现方法,使机器具有感知、推理与决策的功能。
35.人工智能技术是一门综合学科,涉及领域广泛,既有硬件层面的技术也有软件层面的技术。人工智能软件技术主要包括计算机视觉技术、语音处理技术、自然语言处理技术以及机器学习/深度学习等几大方向。
36.其中,计算机视觉技术(computer vision,cv)是一门研究如何使机器“看”的科学。计算机视觉技术通常包括图像处理、图像识别、图像语义理解、图像检索、ocr、视频处理、视频语义理解、视频内容/行为识别、三维物体重建、3d技术、虚拟现实、增强现实、同步定位与地图构建等技术。
37.以计算机视觉技术应用在游戏领域为例,目前,越来越多游戏可以利用计算机视觉技术中包括的三维物体重建、3d技术、虚拟现实以及增强现实等技术中的至少一种来创建游戏场景和虚拟角色。
38.本申请中提供的游戏控制方法可以应用于一般的游戏测试终端,也可以应用于如图1所示的系统中,该系统可以包括服务器10以及终端20。游戏测试终端以及系统中的服务器10和终端20能够运行支持虚拟场景和虚拟角色的客户端。
39.其中,系统中的服务器10可以是独立的物理服务器,也可以是多个物理服务器构成的服务器集群或者分布式系统,还可以是提供基础云计算服务的云服务器。系统中的终端20可以是智能手机、平板电脑、笔记本电脑、台式计算机、游戏控制台、车载设备以及电视等,但并不局限于此。
40.虚拟场景是客户端在游戏测试终端、系统中的服务器10或终端20上运行时显示或提供的场景,可以由一个或多个游戏世界的地图构成。虚拟场景可以对真实世界的仿真世界,也可以是半仿真半虚构的世界,还可以是纯虚构的世界。虚拟场景可以是二维虚拟场景、2.5维虚拟场景和三维虚拟场景中的任意一种,本申请对此不加以限定。
41.虚拟场景中可以包括虚拟对象,若虚拟场景为三维虚拟场景,则虚拟对象是指在虚拟场景中的利用三维立体模型创建的对象。
42.虚拟对象可以包括虚拟角色和虚拟物体,虚拟物体可以是虚拟的动物、植物、油桶、墙壁、石块、塔、武器等,用户可以操控游戏中的虚拟角色在虚拟环境中进行行走、跑步、跳跃、射击、格斗、驾驶、使用虚拟武器攻击其他虚拟角色或虚拟物体等动作。
43.虚拟角色是指虚拟场景中的可活动对象。该可活动对象可以是虚拟人物、虚拟动物、虚拟载具等。其中,当虚拟场景为三维虚拟场景时,虚拟角色可以是基于动画骨骼技术创建的三维立体模型,且每个虚拟角色在虚拟场景中具有自身的形状和体积,占据虚拟场景中的一部分空间。
44.客户端是指军事仿真程序、虚拟现实游戏程序、增强现实游戏程序、射击类游戏程序(如,第一人称射击游戏程序(first

person shooting game,fps)、第三人称射击游戏(third

person shooting game,tps)、角色扮演类游戏程序、战术竞技游戏程序以及策略游戏程序(simulation game,slg)等中的任意一种程序,且客户端可以在游戏测试终端以及系统中的服务器10和终端20上运行。系统中的终端以及测试终端可以支持windows操作系统、苹果操作系统、安卓操作系统、ios操作系统和linux操作系统等操作系统中的至少一种操作系统,并且不同操作系统的终端20可以互联。
45.测试用例是指对上述客户端所指的任意一款程序进行测试任务描述后得到,具体地,测试用例是针对客户端配置一组测试输入、执行条件以及预期结果后得到,运行测试用
例是为了核实客户端是否满足某个特定软件需求,进而确保游戏开发的质量。
46.发明人经过认真的研究发现,目前,人机游戏中由机器(电子设备)控制的虚拟角色、挂机状态下由机器(电子设备)接管控制的虚拟角色或者测试状态下由电子设备控制的虚拟角色等在游戏场景内移动时,仅会控制虚拟角色按照解析得到控件对应的操作方式运动,不会主动进行躲避碰撞,因此,在机器控虚拟角色在游戏场景中移动过程中,可能会与游戏场景内中的可移动物体(如,游戏中的野怪、其他玩家控制的虚拟角色等)发生碰撞,在发生碰撞时,会造成渲染发生碰撞的游戏画面时的数据突增,进而可能会造成游戏卡顿,影响上述其他玩家的操作及体验。
47.基于此,发明人提出一种游戏控制方法,在该方法中,通过根据游戏场景配置信息,利用物理引擎创建虚拟场景后,当预测到目标虚拟移动体与虚拟角色会发生碰撞时,控制虚拟角色躲避碰撞,从而实现游戏过程中,避免因虚拟角色与游戏场景中的可移动物体发生碰撞而使游戏画面发生卡顿,进而避免因游戏画面发生卡顿而影响玩家操作的情况,从而提升了玩家的体验。
48.其中,物理引擎可以使用对象属性(动量、扭矩或者弹性)来模拟刚体行为,可以得到更加真实的结果,物理引擎允许有复杂的机械装置,像球形关节、轮子、气缸或者铰链。有些也支持非刚性体的物理属性,比如流体。物理引擎以技术分类进行划分,可以包括physx引擎、havok引擎、bullet引擎、ue引擎以及unity引擎等。
49.physx引擎是一种物理运算引擎,可以由cpu计算,但其程序本身在设计上还可以调用独立的浮点处理器(例如gpu和ppu)来计算,也正因为如此,physx引擎可以完成像流体力学模拟那样的大计算量的物理模拟计算,且可以使虚拟世界中的物体运动符合真实世界的物理定律,以使游戏更加富有真实感。
50.bullet引擎是一种跨平台的物理模拟计算引擎。且bullet引擎可以广泛应用于游戏开发和电影制作中。
51.havok引擎,是一种用于物理(动力学)效应模拟的游戏引擎,为电子游戏所设计,注重在游戏中对于真实世界的模拟。使用撞击监测功能的havok引擎可以让更多真实世界的情况以最大的拟真度反映在游戏中。
52.ue引擎,是一种游戏引擎。该引擎主要是为了开发第一人称射击游戏而设计,目前已经被成功地应用于开发潜行类游戏、格斗游戏、角色扮演游戏等多种不同类型的游戏。
53.unity引擎,是一种跨平台2d/3d游戏引擎,可以用于创作、运营和变现任何实时互动的2d和3d内容。
54.下面将结合附图具体描述本申请的各实施例。
55.请参阅图2,图2所示为本申请一实施例提出的一种可应用于电子设备的游戏控制方法的流程图,该电子设备可以是游戏测试终端,也可以是如图1所示的服务器10或者终端20,该方法包括:
56.步骤s110:根据游戏场景配置信息,利用物理引擎创建虚拟场景。
57.在创建虚拟场景前,可以先获得游戏场景配置信息,获取游戏场景配置信息的方式可以是,从源代码编辑器中获取,该源代码编辑器具体可以是ue编辑器,如:ue4编辑器。也可以是从电子设备的存储器或与电子设备关联的数据库中获取。
58.游戏场景配置信息用于配置虚拟场景,游戏场景配置信息可以包括策划配置信
息、导航配置信息、物理场景配置信息以及过滤数据等中的一种或多种。
59.策划配置信息用于配置地图id所对应的物理场景、虚拟角色、虚拟移动体、虚拟角色的出生点等信息。地图id是创建地图时定义的地图名称,物理场景是指地图中包括的物体及各物体对应在地图中的位置,地图中包括的物体可以包括:河流、石块、墙壁、草丛、树木、塔以及建筑等中的一种或多种。虚拟角色的出生点是指虚拟角色在游戏场景中出生时的位置。
60.导航配置信息用于配置虚拟角色及虚拟移动体等在地图中进行寻路时的可行走区域。
61.物理场景配置信息用于为上述的物理场景配置物理信息,供物理引擎使用,以使物理引擎为上述的物理场景赋予物理属性,物理属性可以包括:物体的弹性、扭矩、延展性等。
62.过滤数据与物理场景中的部分物体对应,用于将物理场景中与过滤数据对应的物体设置为不影响虚拟角色通行物体,如将河流、草丛等进行过滤设置,以使虚拟角色在遇到进行过滤设置后的物体时,直接通过而不产生碰撞。
63.应当理解,在创建虚拟场景前,也可以先获取物理引擎。获取物理引擎的方式可以是,从云端下载物理引擎或者从预设存储器中获取物理引擎。物理引擎可以是physx引擎、havok引擎、bullet引擎、ue引擎以及unity引擎等中的任意一种。由于物理引擎能够使虚拟环境中的物理场景、虚拟角色以及虚拟移动体等使用各自对应的属性来模拟刚体行为,因此,可以使创建得到的虚拟场景具有更加真实的视觉效果。
64.请参阅图3,作为一种实施方式,游戏场景配置信息可以包括导航配置信息、策划配置信息以及物理场景配置信息,上述步骤s110具体可以包括以下步骤:
65.步骤s112:根据导航配置信息、策划配置信息以及物理场景配置信息创建游戏场景。
66.具体的,可以根据策划配置信息配置地图所对应的物理场景、虚拟角色、虚拟移动体、虚拟角色的出生点等信息,根据导航配置信息配置虚拟角色及虚拟移动体等在地图中进行寻路时的可行走区域,以及根据物理场景配置信息为物理场景中的物体配置物理信息,从而完成游戏场景的创建。
67.步骤s114:利用物理引擎为游戏场景中的虚拟对象赋予物理属性得到虚拟场景,虚拟对象包括虚拟角色和虚拟移动体。
68.具体的,利用物理引擎为游戏场景中的物体,如:河流、石块、墙壁、草丛、树木、塔以及建筑等赋予物理属性,以使虚拟对象及游戏场景中的物体可以使用各自对应的物理属性来模拟刚体行为,从而得到虚拟场景。
69.应当理解,若游戏场景配置信息还包括过滤数据时,在根据策划配置信息配置地图所对应的物理场景、虚拟角色、虚拟移动体、虚拟角色的出生点等信息之后,可以根据过滤数据将物理场景中与过滤数据对应的物体设置为不影响虚拟角色通行的物体,并执行与上述步骤s112和s114相同或相应的步骤,从而得到虚拟场景。
70.步骤s120:根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上执行动作。
71.上述的虚拟角色可以是运行测试用例过程中用于模拟玩家操作的虚拟角色;也可
以是人机对战过程中,机器(电子设备,如终端或服务器)控制的虚拟角色;还可以是玩家在挂机状态下,机器(电子设备,如终端或服务器)接管控制的与该玩家对应的虚拟角色等。
72.其中,运行控制指令用于控制虚拟角色在虚拟场景中执行相应的行为动作。运行控制指令中可以包括与虚拟角色对应的寻路指令、技能释放指令、技能躲避指令以及物品使用指令中的一种或几种的组合。
73.利用物理引擎控制虚拟角色在寻路路径上执行动作,可以使得虚拟角色在执行行为动作时,基于物理引擎按照真实世界中的各种运动规律来模拟进行,行为动作更加真实,所获得的数据也更接近真实的游戏过程中产生的数据。
74.请参阅图4,作为一种实施方式,运行控制指令包括与虚拟角色对应的寻路指令,上述步骤s120包括:
75.步骤s122:根据与虚拟角色对应的寻路指令,得到起始位置和目标位置。
76.寻路指令对应有起始位置和目标位置,且寻路指令用于控制对应的虚拟角色在虚拟场景中根据起始位置和目标位置得到最优路径。
77.步骤s124:获取虚拟场景中障碍物的位置信息。
78.虚拟场景中的障碍物位置为虚拟角色不可通行的位置,障碍物可以是石块、墙壁、树木、塔以及建筑等。
79.步骤s126:根据障碍物的位置信息、起始位置和目标位置得到虚拟角色的寻路路径,并控制虚拟角色在寻路路径上执行动作。
80.根据障碍物的位置信息、起始位置和目标位置得到虚拟角色的寻路路径的方式具体可以是,利用寻路算法对障碍物的位置信息、起始位置和目标位置在虚拟场景的位置信息计算起始位置与目标位置之间的最优路径。上述的寻路算法具体可以是a*寻路算法、蚁群算法等中的任意一种。
81.如图5所示,获得如图5中的虚拟角色的起始位置k1、目标位置k2以及障碍物(花坛、建筑物等)的位置后,根据起始位置k1和目标位置k2以及障碍物(如图5中的花坛)的位置信息利用寻路算法可以得到虚拟角色的寻路路径,该寻路路径可以是如图5中k1和k2之间的虚线箭头所指向的路径,当虚拟角色在寻路路径上移动时,不会与图中所示的花坛发生碰撞。
82.考虑到障碍物通过在虚拟场景中占据一定的体积,虚拟角色在虚拟场景中移动过程中在遇到障碍物时需要绕过障碍物上述步骤s126具体可以是,根据障碍物的位置信息得到障碍物边界;根据障碍物边界以及虚拟角色的起始位置和目标位置得到虚拟角色的寻路路径,其中,寻路路径上的点位于障碍物边界外,即,如图5所示的,寻路路径上的点位于花坛的边界外。
83.具体的,在进行寻路时,可以对障碍物和虚拟角色的所在地图划分为大小相同的多个小方格,并按照a*寻路算法找出起始位置所在方格与目标位置所在方格之间的路径,使障碍物边界所对应的任意一个方格均不在该路径上。
84.作为另一种实施方式,运行控制指令包括寻路指令和虚拟角色对应的技能释放指令,上述步骤s120包括:根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上移动时,检测距离虚拟角色预设距离范围内是否存在待攻击角色,若存在,则根据待攻击角色的位置及虚拟角色所在位置生成攻击指向路径,并沿攻击指向路径释放攻击技能。
85.其中,待攻击角色是指虚拟场景中能够响应于虚拟角色释放的技能攻击,使其状态发生改变的物体或虚拟移动体,如虚拟场景中的野怪、塔等。
86.作为又一种实施方式,运行控制指令包括寻路指令和虚拟角色对应的技能躲避指令,上述步骤s120包括:根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上移动时,检测虚拟角色所在位置的预设距离范围内是否存在来自攻击角色释放的攻击技能,若存在,则根据待攻击角色的位置及攻击角色所在位置生成攻击指向路径,并根据攻击指向路径躲避技能。
87.作为再一种实施方式,运行控制指令包括寻路指令和物品使用指令,上述步骤s120包括:根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上移动时,检测与虚拟角色对应的物品剩余量(如,药包、血量等)是否小于预设阈值,在小于预设阈值时,检测是否存在对应的物品,并在存在时使用该物品以增加虚拟角色的物品剩余量。
88.步骤s130:预测所述虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与所述虚拟角色发生碰撞。
89.其中,上述的虚拟移动体可以是虚拟场景中的除虚拟角色之外可以移动的虚拟物体,如野怪、npc(non

player character,非玩家角色)等。
90.上述预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与虚拟角色发生碰撞的方式可以有多种。
91.作为一种实施方式,可以检测虚拟角色预设距离范围内是否存在虚拟移动体,若存在,则根据虚拟角色的位置和速度以及到所述虚拟角色的距离小于距离阈值的虚拟移动体的位置和速度预测虚拟角色沿寻路路径移动至目标位置的过程中,预测是否存在目标虚拟移动体与虚拟角色发生碰撞。
92.作为另一种实施方式,可以通过获取虚拟角色在虚拟场景中的位置和速度,以及获取虚拟场景中的各虚拟移动体的位置和速度,根据虚拟角色的位置和速度以及虚拟场景中的各虚拟移动体的位置和速度,预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在虚拟移动体与虚拟角色发生碰撞。
93.其中,上述各种方式中,预测是否存在目标虚拟移动体与虚拟角色发生碰撞的方式可以是利用碰撞检测算法预测是否存在目标虚拟移动体与该虚拟角色内发生碰撞。该碰撞检测算法可以包括gjk碰撞检测算法以及基于分离轴定理的碰撞检测算法等中的一种或多种。
94.作为又一种实施方式,还可以是利用测试碰撞盒检测在虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与该虚拟角色发生碰撞。具体的,在该种方式下,可以以虚拟角色的三维虚拟模型上的任意一点为起点,例如,以虚拟角色的三维虚拟模型的中心点为起点,向该虚拟角色的速度方向周期性地射出碰撞盒子。碰撞盒子用于进行碰撞检测,碰撞盒子在虚拟环境画面上不可见。且可以根据虚拟角色的三维虚拟模型的形状及大小来确定碰撞盒子的形状及大小,使碰撞盒子可以表征虚拟角色的三维虚拟模型,然后周期性地向虚拟角色的速度方向的前方发射碰撞盒子,用碰撞盒子来检测以当前的速度方向进行移动时虚拟角色会不会撞到虚拟环境中的其他三维虚拟模型,若碰撞盒子检测到了碰撞,则可以确定虚拟角色的前方存在虚拟移动体;若碰撞盒子没有检测到虚拟移动体,则可以确定虚拟角色的前方不存在虚拟移动体。碰撞盒子的射出距离和射出周期
可以任意配置,例如,碰撞盒子的射出距离可以是5cm,射出周期可以是0.1秒。此外,碰撞盒子的射出速度要远高于虚拟角色的速度,以便碰撞盒子在虚拟角色撞上虚拟移动体之前检测到虚拟移动体。
95.步骤s140:当预测存在时,控制所述虚拟角色躲避碰撞。
96.其中,控制虚拟角色躲避碰撞的方式可以有多种。
97.作为一种方式,控制虚拟角色躲避碰撞的方式可以是:控制虚拟角色按照与其原速度方向呈预设夹角的方向移动。其中,该夹角可以是180度,即沿原速度方向的反方向移动;该夹角也可以是90度,即沿垂直于原速度方向的方向移动;该夹角还可以是60度、45度、30度等任意角度。
98.作为另一种方式,控制虚拟角色躲避碰撞的方式还可以是,调整虚拟角色的移动速度,如增大或减小虚拟角色的速度大小,以躲避碰撞。如,在原有速度基础上不改变速度方向并增加或减少百分之十的速度大小。
99.作为另一种方式,控制虚拟角色躲避碰撞的方式还可以是,同时虚拟角色的速度大小和速度方向,例如,在增大速度的同时调整速度方向,或者在减小速度的同时调整速度方向。
100.作为另一种方式,控制虚拟角色躲避碰撞的方式还可以根据虚拟角色的位置和速度以及目标虚拟移动体的位置和速度,利用碰撞避免算法进行计算得到虚拟角色的目标速度,并控制虚拟角色按照目标速度移动以躲避碰撞。
101.应当理解,以上描述的各种方式中提到的速度为矢量,其具有速度大小和速度方向,即虚拟角色是按照其对应的速度的速度大小和速度方向移动的。
102.作为又一种方式,还可以是以虚拟角色的位置为起点,沿指向该虚拟角色的速度方向周期性的射出碰撞检测盒,碰撞检测盒用于检测与虚拟移动体的碰撞;获取碰撞检测盒与虚拟移动体发生碰撞的碰撞点;根据碰撞点确定虚拟角色的躲避方向,并根据躲避方向控制虚拟角色躲避碰撞。
103.本申请提供的一种游戏控制方法,通过根据游戏场景配置信息,利用物理引擎创建虚拟场景;根据运行控制指令,利用物理引擎控制虚拟角色在寻路路径上执行动作;预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与虚拟角色发生碰撞;当预测存在时,控制虚拟角色躲避碰撞,使得游戏过程中,避免因虚拟角色与游戏场景中的可移动物体发生碰撞而使游戏画面发生卡顿,进而避免因游戏画面发生卡顿而影响玩家操作的情况,从而提升了玩家的体验。进一步的,本申请通过在预测到虚拟角色与游戏场景内中的可移动物体发生碰撞时,控制虚拟角色躲避碰撞,从而使虚拟角色根据运行控制指令运行过程中真实模拟人的操作,从而进一步提升玩家的操作及体验。
104.请参阅图6,图6所示为本申请一实施例提出的一种可应用于电子设备的游戏控制方法的流程图,该电子设备可以是游戏测试终端,也可以是如图1所示的服务器10或者终端20,在游戏场景配置信息和运行控制指令来自测试用例时,该方法包括:
105.步骤s210:根据测试用例中的游戏场景配置信息,利用物理引擎创建虚拟场景。
106.在进行测试前,可以先获得测试用例,获取测试用例的方式可以是,从源代码编辑器中获取测试用例,该源代码编辑器具体可以是ue编辑器,如:ue4编辑器。
107.步骤s220:根据测试用例中的运行控制指令,利用物理引擎控制虚拟角色在寻路
路径上执行动作。
108.步骤s230:预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与虚拟角色发生碰撞。
109.步骤s240:当预测存在时,控制虚拟角色躲避碰撞,并采集运行测试用例过程中产生的数据。
110.其中,关于控制虚拟角色躲避碰撞的方式可以参阅前文对步骤s140的具体描述,在此处不做一一赘述。
111.运行测试用例过程中产生的数据可以包括电子设备在调度物理引擎运行渲染该测试用例对应的游戏画面的逻辑时获取的用于渲染该测试用例对应的游戏画面的内存数据。即,运行测试用例过程中产生的数据可以包括测试用例对应的游戏画面的内存数据。
112.运行测试用例过程中产生的数据也可以包括运行测试用例过程中产生的日志信息以及录屏数据等中的至少一种。其中,日志信息为中记录相关的运行记录,例如,记录针对运行测试指令的响应结果,录屏数据为运行测试用例中录制的游戏画面。
113.步骤s250:根据数据确定测试用例在运行时的测试结果。
114.其中,根据数据确定测试用例在运行时的测试结果可以是:根据内存数据、运行测试用例过程中产生的日志信息以及录屏数据中的至少一种确定测试用例在运行时的测试结果。
115.如图6所示,作为一种实施方式,数据包括用于渲染测试用例对应的游戏画面的内存数据,上述步骤s250包括:
116.步骤s252:根据该每帧游戏画面的内存数据和对应的预期数据确定每帧游戏画面的测试结果。
117.其中,每帧游戏画面的内存数据可以包括的虚拟角色或虚拟移动体等各自对应的在虚拟场景中的实际位置和实际速度,每帧游戏画面对应的预期数据可以包括虚拟角色或虚拟移动体等各自对应在虚拟场景中的预期位置和预期速度,通过检测每帧游戏画面的内存数据与对应的预期数据是否匹配来确定每帧游戏画面的测试结果。
118.步骤s254:根据每帧游戏画面的测试结果确定测试用例的测试结果。
119.根据每帧游戏画面的测试结果确定测试用例的测试结果的方式可以是:统计测试用例对应的所有游戏画面数量和测试结果为异常的游戏画面的数量,根据所有游戏画面数量和测试结果为异常的游戏画面的数量得到游戏画面为异常的比例,根据游戏画面为异常的比例和一比例阈值得到测试用例的测试结果。
120.作为另一种实施方式,数据包括内存数据和日志信息,上述步骤s150包括:根据运行测试用例过程中产生的日志信息和内存数据共同确定测试用例在运行过程中的测试结果。
121.在该种方式下,可以采用如步骤s152相同或相应的步骤根据每帧游戏画面的内存数据和对应的预期数据确定该每帧游戏画面的测试结果,并可以将每帧游戏画面的测试结果与对应的预期数据进行比对,得到每帧游戏画面对应的比对结果,并根据对比结果为异常的游戏画面对应的画面产生时刻和日志信息中记录的运行记录的记录时间对比对结果进行修正,并采用如步骤s154相似的步骤根据修正后的比对结果得到测试结果。
122.本申请提供的一种游戏控制方法,通过根据测试用例中的游戏场景配置信息,利
用物理引擎创建虚拟场景;根据测试用例中的运行控制指令,利用物理引擎控制虚拟角色在寻路路径上执行动作;预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与虚拟角色发生碰撞;当预测存在时,控制虚拟角色躲避碰撞,并采集运行测试用例过程中产生的数据;根据数据确定测试用例在运行时的测试结果。通过在测试过程中预测到存在目标虚拟移动体与虚拟角色发生碰撞时,控制虚拟角色躲避碰撞,以达到更真实地模拟玩家控制虚拟角色移动时的游戏场景的目的,从而使电子设备在更真实的游戏场景下使获得的测试过程中的数据更准确,进而使测试结果更准确。
123.请参阅图8,图8示出了一种游戏控制方法,该游戏控制方法可以应用于服务器中,服务器通常用于与多个终端连接,在服务器运行游戏时会接收终端发送的游戏操作信息,以根据游戏操作信息更新目标游戏的实时游戏画面,将更新后的实时游戏画面同步给终端从而实现多人在线游戏。为了使服务器运行测试用例来模拟多人在线游戏时,能够获得更准确测试结果,本申请提供的游戏控制方法包括以下步骤:
124.步骤s310:根据游戏场景配置信息,利用物理引擎创建虚拟场景,虚拟场景中包括至少两个虚拟角色。
125.步骤s320:根据每个虚拟角色分别对应的运行控制指令,利用物理引擎控制各虚拟角色在对应的寻路路径上执行动作。
126.步骤s330:预测目标虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体或者其他虚拟角色与目标虚拟角色发生碰撞。
127.其中,上述的目标虚拟角色为测试用例对应的至少两个虚拟角色中的任意一个。针对目标虚拟角色,可以利用与上述步骤s130相似的方式预测目标虚拟角色在对应的寻路路径上执行动作过程中,是否存在目标虚拟移动体或其他虚拟角色与目标虚拟角色发生碰撞。其他虚拟角色是指测试用例中对应的至少两个虚拟角色中除目标虚拟角色之外的虚拟角色。
128.步骤s340:当预测存在目标虚拟移动体与目标虚拟角色发生碰撞时,控制目标虚拟角色躲避碰撞,或者当预测存在其他虚拟角色与目标虚拟角色发生碰撞时,控制目标虚拟角色以及其他虚拟角色中的至少一个躲避碰撞。
129.控制目标虚拟角色以及控制其他虚拟角色躲避碰撞时,具体的控制方式可以参阅前文中对步骤s240的具体描述,在此不作一一赘述。
130.作为一种实施方式,游戏场景配置信息和运行控制指令来自测试用例,游戏控制方法还包括:
131.采集运行测试用例过程中产生的数据,并根据数据确定测试用例在运行时的测试结果。
132.通过采用本申请实施例中的游戏控制方法,根据游戏场景配置信息,利用物理引擎创建虚拟场景,根据与每个虚拟角色分别对应的运行控制指令,利用物理引擎控制各虚拟角色在对应的寻路路径上执行动作,预测目标虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体或者其他虚拟角色与目标虚拟角色发生碰撞,当预测存在目标虚拟移动体与目标虚拟角色发生碰撞时,控制目标虚拟角色躲避碰撞,或者当预测存在其他虚拟角色与目标虚拟角色发生碰撞时,控制目标虚拟角色以及其他虚拟角色中的至少一个躲避碰撞。实现在服务器执行游戏控制方法过程中真实模拟多人在线游戏时的场
景,避免因虚拟角色与游戏场景中的可移动物体发生碰撞而使游戏画面发生卡顿,进而避免因游戏画面发生卡顿而影响玩家操作的情况,从而提升了玩家的体验。进一步的,在游戏场景配置信息和运行控制指令来自测试用例时,通过在执行上述的游戏控制方法的过程中采集运行测试用例过程中产生的数据,并根据数据确定测试用例在运行时的测试结果,从而使服务器在更真实的游戏场景下使获得的测试过程中的数据更准确,进而使测试结果更准确。
133.请参阅图9,本申请提供了一种游戏控制方法,应用于电子设备,该方法包括:
134.步骤s401:获取导航配置信息、策划配置信息、物理场景配置信息以及过滤数据。
135.具体的,可以从游戏开发编辑器(如ue4编辑器)中导出上述的策划配置信息、导航配置信息、物理场景配置信息以及过滤数据,在获取到上述的配置信息之后,还可以从预设存储器或网址中获取物理引擎(如physx引擎,其具备刚体运动计算功能、碰撞检测功能以及角色控制功能),以及获取用户通过网页操作的方式输入的针对虚拟角色的配置信息(如,控制虚拟角色执行运行控制指令的控制信息,其中,该运行控制指令可以包括寻路指令)。
136.步骤s402:根据测试用例中的导航配置信息、策划配置信息以及物理场景配置信息创建游戏场景。
137.步骤s403:利用物理引擎为游戏场景中的虚拟对象赋予物理属性得到虚拟场景。
138.步骤s404:将虚拟场景中与过滤数据对应的虚拟对象进行过滤设置以完成虚拟场景的创建。
139.其中,测试用例中还可以包括多种场景配置逻辑,在完成过滤设置之后,还可以基于多种场景配置逻辑对虚拟场景进行配置。其中,多种场景配置逻辑可以包括终点变更配置逻辑、信息采集逻辑以及组队请求响应逻辑等中的至少一种。
140.步骤s405:获得虚拟角色的寻路路径。
141.具体的上述步骤s405可以是根据与虚拟角色对应的寻路指令得到起始位置和目标位置,获取虚拟场景中障碍物的位置信息,根据障碍物的位置信息、起始位置和目标位置得到虚拟角色的寻路路径。
142.步骤s406:控制虚拟角色在寻路路径上执行动作过程中躲避碰撞。
143.其中,步骤s406具体可以是:获取在虚拟角色的寻路路径上执行动作时的位置和速度,以及虚拟场景中的虚拟移动体的位置和速度;根据虚拟角色在寻路路径上执行动作时的位置和速度以及虚拟移动体的位置和速度,预测在虚拟角色的寻路路径上执行动作过程,是否存在虚拟移动体与该虚拟角色碰撞。若存在目标虚拟移动体与虚拟角色发生碰撞,则可以控制虚拟角色躲避虚拟移动体,避免碰撞,应当理解,在执行上述步骤的过程中,还可以运行测试用例中的各种场景配置逻辑。
144.在本实施方式中,在控制虚拟角色在寻路路径在执行动作过程中,还可以运行测试用例中的各种场景配置逻辑,以及可以为虚拟场景增加气象场景信息,如增加刮风、下雨以及雷电等气象场景信息。
145.作为一种方式,场景配置逻辑可以包括终点变更配置逻辑,在寻路路径上移动过程中运行测试用例中的场景配置逻辑的方式可以是:虚拟角色在寻路路径上移动过程中移动至与终点变更配置逻辑对应的目标位置时,响应于终点变更配置逻辑,根据目标位置和
终点变更配置逻辑对应的变更后的终点位置生成新的寻路路径,并在该新的寻路路径上执行动作。
146.作为另一种方式,场景配置逻辑可以包括信息采集逻辑,在寻路路径上移动过程中运行测试用例中的场景配置逻辑的方式可以是:在寻路路径上移动过程中,响应于信息采集逻辑,每间隔预设时长采集虚拟角色在虚拟场景中的位置和速度信息。
147.作为又一种方式,场景配置逻辑可以包括组队请求响应逻辑,在寻路路径上移动过程中运行测试用例中的场景配置逻辑的方式可以是:在寻路路径上移动过程中,响应于组队请求响应逻辑生成响应结果,该响应结果为同意组队或拒绝组队。步骤s407:获取运行测试用例过程中的数据。其中,步骤s407可以是:采用多线程数据方式以及udp数据收集方式收集运行测试用例过程中产生的数据,且运行测试用例过程的数据包括日志信息、录屏数据以及每帧游戏画面的内存数据等中的一种或多种。
148.步骤s408:根据数据确定测试用例在运行时的测试结果。
149.其中,步骤s408具体可以是,若数据包括每帧游戏画面对应的内存数据,电子设备根据该每帧游戏画面的内存数据和对应的预期数据确定该每帧游戏画面的测试结果,并根据该每帧游戏画面的测试结果确定该测试用例的测试结果,从而确保测试结果的准确性。
150.需要说明的是,当电子设备为终端时该终端可以与服务器连接,终端还可以获取虚拟角色的当前位置和速度等参数,通过接入层中的tcp协议或kcp协议对参数进行封装后发送给服务器,以使服务器校验和广播该参数以及基于该参数生成反馈数据,终端通过接入层接收服务器反馈的反馈数据,在采用多线程数据方式以及udp数据收集方式收集运行测试用例过程中产生的数据时,具体的,可以采用多线程数据收集方式用于收集运行测试用例过程中的内存数据,以及采用udp数据收集方式进行丢包统计以及获取反馈的错误数据等。
151.下面将结合参阅图10、图11、图12、图13以及图14,以该游戏控制方法应用在游戏测试终端或图1中的终端上进行游戏测试,且所使用的测试用例为多人在线战术竞技游戏程序对应的测试用例为例,对上述实施例中的方法进行详细的举例说明。
152.请参照图10,根据测试用例中的游戏场景配置信息,利用物理引擎创建虚拟场景,根据虚拟角色a对应的寻路指令得到的虚拟角色a对应的起始位置q1和目标位置q2,根据起始位置q1和目标位置q2以及虚拟场景中障碍物的位置信息得到虚拟角色a的寻路路径(如图10中的q1与q2之间的路径)。根据测试用例中的运行控制指令控制虚拟角色a利用物理引擎在寻路路径上按照速度v1移动。
153.其中,虚拟场景中还包括虚拟移动体b、虚拟移动体c、虚拟移动体d、虚拟移动体e以及虚拟移动体f。上述的各虚拟移动体可以根据对应的运行逻辑在游戏场景中移动。需要说明的是,虚拟移动体或虚拟移动体各自对应的箭头的指向表征其移动时的速度方向,虚拟移动体或虚拟移动体各自对应的箭头的长短表征其移动时的速度大小。
154.请结合参照图11,当预测到虚拟角色a在寻路路径上按照速度v1移动过程中,存在按照速度v2移动的虚拟移动体b与该虚拟角色a发生碰撞时,若不及时控制虚拟角色a躲避虚拟移动体b,虚拟角色a则会与虚拟移动体b发生如图12所示的碰撞,由于用户真实操作虚拟角色a时通常不会产生如图12所示的游戏画面,且虚拟角色a与虚拟移动体b发生碰撞时,会生成碰撞日志数据,同时在终端渲染游戏画面时,会使得渲染游戏画面过程中内存数据
突增,造成游戏测试结果不准确。基于此,为避免产生如图12所示的游戏画面,本申请中通过在预测到虚拟角色a在寻路路径上按照速度v1移动过程中,存在虚拟移动体b与该虚拟角色发生碰撞时,调整虚拟角色a的速度大小和/或方向,以使虚拟角色a按照调整后的速度v1’移动(图13仅示出了调整虚拟角色a的速度方向),使虚拟角色a不会与虚拟移动体b发生碰撞。在虚拟角色a按照调整后的速度v1’移动且虚拟移动体b按照原有的速度v2移动一段距离后,例如,虚拟角色a移动至图14所示的q3点时,若按照原有的速度v1移动时,不会再与虚拟移动体b发生碰撞,则可以根据q3和q2生成新的寻路路径(q2与q3之间的路径),并控制虚拟角色a按照速度v1在该新的寻路路径移动,采集运行测试用例过程产生的数据,以根据数据确定测试用例在运行时的测试结果。
155.通过在终端上运行上述的游戏控制方法,可以避免测试过程中,虚拟角色与虚拟移动体发生碰撞,而生成碰撞日志数据,以及避免因虚拟角色与虚拟移动体发生碰撞造成终端渲染游戏画面时内存数据突增的情况,因此,通过采用上述的游戏控制方法,可以确保测试过程中产生的数据的可靠性,从而使根据数据确定测试用例在运行时的测试结果更准确。
156.下面将结合参阅图15、图16、图17以及图18所示,以该游戏控制方法应用在图1中的服务器上进行测试,且该游戏控制方法所使用的测试用例为多人在线战术竞技游戏程序对应的测试用例为例,对上述实施例中的方法进行详细的举例说明。
157.根据测试用例中的游戏场景配置信息,利用物理引擎创建虚拟场景。测试用例中包括至少两个虚拟角色,(图15至图17仅示出了测试用例包括虚拟角色a和虚拟角色b的情况),应当理解虚拟场景中还包括其他的虚拟移动体,图中15至图17中仅示出了还包括虚拟移动体c、虚拟移动体d、虚拟移动体e、虚拟移动体f的情况,上述的各虚拟移动体可以根据对应的运行逻辑在游戏场景中移动。
158.请参照图15,根据虚拟角色a对应的寻路指令得到虚拟角色a对应的起始位置q1和目标位置q2,根据起始位置q1、目标位置q2以及虚拟场景中障碍物的位置信息得到虚拟角色a的寻路路径(如图14中的q1与q2之间的路径)。根据虚拟角色b对应的寻路指令得到虚拟角色b对应的起始位置p1和目标位置p2,根据起始位置p1、目标位置p2以及虚拟场景中障碍物的位置信息得到虚拟角色b的寻路路径(如图15中的p1与p2之间的路径)。
159.根据测试用例中与虚拟角色a和与虚拟角色b分别依据对应的运行控制指令控制虚拟角色a和虚拟角色b利用物理引擎在各自对应的寻路路路径上移动时(即,虚拟角色a按照速度v1在q1与q2之间的路径上移动,虚拟角色b按照速度v2在p1与p2之间的路径上移动),针对任意目标虚拟角色,预测是否存在虚拟移动体或其他虚拟角色与该目标虚拟角色发生碰撞。
160.根据上述的预测方式可以得到图15中的虚拟角色b与虚拟角色a会发生碰撞。通过调整虚拟角色a和虚拟角色b中的至少一个的速度,可以使虚拟角色a与虚拟角色b避免发生碰撞。
161.应当理解,关于控制虚拟角色a或虚拟角色b中的任意一个躲避碰撞的情况,可以参阅前文对图10至图14的具体描述,在此不做具体赘述。
162.请参照图16,图16示出了同时调整虚拟角色a和虚拟角色b的速度的示意图,即将虚拟角色a的速度由v1调整为v1’,以及将虚拟角色b的速度由v2调整为v2’,以使虚拟角色a
和虚拟角色b不会发生碰撞。请参照图17所示,在虚拟角色a按照速度v1’移动至q3位置,且在虚拟角色按照速度v2’移动至p3位置后,若虚拟角色a按照v2移动,虚拟角色b按照v2移动时不会发生碰撞,则还可以根据虚拟角色a躲避碰撞后的位置q3和对应的寻路路径的终点q2得到新的寻路路径(如图17中q2与q3之间的路径),以及根据虚拟角色b躲避碰撞后的位置p3及其对应的寻路路径的终点p2生成新的寻路路径(如图17中p2与p3之间的路径)。如图18所示,控制虚拟角色a按照速度v1在对应的新的路径上移动以及控制虚拟角色b按照速度v2在对应的新的寻路路径上移动,并采集运行测试用例过程产生的数据,以根据数据确定测试用例在运行时的测试结果。
163.通过在服务器上运行上述的游戏控制方法,可以避免测试过程中,目标虚拟角色与其他虚拟角色或虚拟移动体发生碰撞,而生成碰撞日志数据,以及避免服务器渲染目标虚拟角色与其他虚拟角色或虚拟移动体发生碰撞时的游戏画面时内存数据突增的情况。因此,通过采用上述的游戏控制方法,可以实现在服务器端真实模拟多人在线游戏时的效果,确保测试过程中产生的数据的可靠性,从而使根据数据确定测试用例在运行时的测试结果更准确。
164.请参阅图19,图19示出了本申请提供了一种游戏控制装置500,包括场景创建模块510、动作执行模块520、碰撞预测模块530以及躲避控制模块540。
165.场景创建模块510,用于根据游戏场景配置信息,利用物理引擎创建虚拟场景。
166.作为一种方式,场景创建模块510具体用于根据导航配置信息、策划配置信息以及物理场景配置信息创建游戏场景;利用物理引擎为游戏场景中的虚拟对象赋予物理属性得到虚拟场景,虚拟对象包括虚拟角色和虚拟移动体。
167.动作执行模块520,用于根据运行控制指令控制虚拟角色利用物理引擎在寻路路径上执行动作。
168.其中,动作执行模块520包括:位置信息获得子模块和动作执行子模块。
169.位置信息获得子模块用于根据与虚拟角色对应的寻路指令得到虚拟角色的起始位置和目标位置,以及用于获取虚拟场景中障碍物的位置信息。
170.动作执行子模块,用于根据虚拟移动体的位置信息以及虚拟角色的起始位置和目标位置得到虚拟角色的寻路路径,控制虚拟角色在寻路路径上执行动作。
171.动作执行子模块具体还用于,根据障碍物的位置信息得到障碍物边界;根据障碍物边界、起始位置和目标位置得到虚拟角色的寻路路径,其中,寻路路径上的点位于障碍物边界外。
172.碰撞预测模块530,用于预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与虚拟角色发生碰撞。
173.作为一种方式,碰撞预测模块530,还用于根据虚拟角色的位置和各障碍物的位置确定是否存在到虚拟角色的距离小于距离阈值的虚拟移动体;在存在时,基于虚拟角色的位置和速度以及到虚拟角色的距离小于距离阈值的虚拟移动体的位置和速度,利用碰撞检测算法,预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与虚拟角色发生碰撞。
174.躲避控制模块540,用于当预测存在虚拟移动体与该虚拟角色发生碰撞时,控制虚拟角色躲避碰撞。
175.其中,躲避控制模块540还用于根据虚拟角色的位置和速度以及目标虚拟移动体的位置和速度,利用碰撞避免算法进行计算得到虚拟角色的目标速度,并控制虚拟角色按照目标速度移动以躲避碰撞。
176.请参阅图20,作为一种实施方式,游戏场景配置信息和运行控制指令来自测试用例时,装置还包括数据采集模块550和结果确定模块560。
177.数据采集模块,用于采集运行测试用例过程中产生的数据。
178.结果确定模块550,用于根据数据确定测试用例在运行时的测试结果。
179.作为一种方式,结果确定模块550包括:内存数据获取子模块和结果确定子模块。
180.内存数据获取子模块,用于获取测试用例对应的每帧游戏画面的内存数据。
181.结果确定子模块,用于根据每帧游戏画面的内存数据和对应的预期数据确定每帧游戏画面的测试结果,以及用于根据每帧游戏画面的测试结果确定测试用例的测试结果。
182.作为一种方式,当游戏控制方法应用于服务器,且虚拟场景中的虚拟角色为至少两个时,动作执行模块520还用于根据测试用例中与每个虚拟角色分别对应的运行控制指令,利用物理引擎控制各虚拟角色在对应的寻路路径上执行动作;碰撞预测模块530,还用于预测目标虚拟角色沿寻路路径移动至目标位置的过程中,是否存在障碍物或者其他虚拟角色与目标虚拟角色发生碰撞。躲避控制模块540,还用于当预测存在目标虚拟移动体与目标虚拟角色发生碰撞时,控制目标虚拟角色躲避碰撞,或者当预测存在其他虚拟角色与目标虚拟角色发生碰撞时,控制目标虚拟角色以及其他虚拟角色中的至少一个躲避碰撞。
183.需要说明的是,本申请中装置实施例与前述方法实施例是相互对应的,装置实施例中具体的原理可以参见前述方法实施例中的内容,此处不再赘述。
184.下面将结合图21对本申请提供的一种电子设备进行说明。
185.请参阅图21,基于上述实施例提供的游戏控制方法,本申请实施例还提供的另一种包括可以执行前述方法的处理器102的电子设备100,该电子设备100可以为如图1所示的游戏系统中的游戏服务端10或终端20,终端20可以是智能手机、平板电脑、计算机或者便携式计算机等设备。
186.电子设备100还包括存储器104。其中,该存储器104中存储有可以执行前述实施例中内容的程序,而处理器102可以执行该存储器104中存储的程序。
187.其中,处理器102可以包括一个或者多个用于处理数据的核以及消息矩阵单元。处理器102利用各种接口和线路连接整个电子设备100内的各个部分,通过运行或执行存储在存储器104内的指令、程序、代码集或指令集,以及调用存储在存储器104内的数据,执行电子设备100的各种功能和处理数据。可选地,处理器102可以采用数字信号处理(digital signal processing,dsp)、现场可编程门阵列(field-programmable gate array,fpga)、可编程逻辑阵列(programmable logic array,pla)中的至少一种硬件形式来实现。处理器102可集成中央处理器(central processing unit,cpu)、图像处理器(graphics processing unit,gpu)和调制解调器等中的一种或几种的组合。其中,cpu主要处理操作系统、用户界面和应用程序等;gpu用于负责显示内容的渲染和绘制;调制解调器用于处理无线通信。可以理解的是,上述调制解调器也可以不集成到处理器102中,单独通过一块通信芯片进行实现。
188.存储器104可以包括随机存储器(random access memory,ram),也可以包括只读
存储器(read

only memory)。存储器104可用于存储指令、程序、代码、代码集或指令集。存储器104可包括存储程序区和存储数据区,其中,存储程序区可存储用于实现操作系统的指令、用于实现至少一个功能的指令(如,指标移动分析指令)、用于实现下述各个方法实施例的指令等。存储数据区还可以存储电子设备100在使用中所获取的数据等。
189.电子设备100还可以包括网络模块以及屏幕,网络模块用于接收以及发送电磁波,实现电磁波与电信号的相互转换,从而与通讯网络或者其他设备进行通讯,例如和音频播放设备进行通讯。网络模块可包括各种现有的用于执行这些功能的电路元件,例如,天线、射频收发器、数字信号处理器、加密/解密芯片、用户身份模块(sim)卡、存储器等等。网络模块可与各种网络如互联网、企业内部网、无线网络进行通讯或者通过无线网络与其他设备进行通讯。屏幕可以进行界面内容的显示以及进行数据交互。
190.请参考图22,其示出了本申请实施例提供的一种计算机可读存储介质的结构框图。该计算机可读介质600中存储有程序代码,程序代码可被处理器调用执行上述方法实施例中所描述的方法。
191.计算机可读存储介质600可以是诸如闪存、eeprom(电可擦除可编程只读存储器)、eprom、硬盘或者rom之类的电子存储器。可选地,计算机可读存储介质600包括非易失性计算机可读介质(non

transitory computer

readable storage medium)。计算机可读存储介质600具有执行上述方法中的任何方法步骤的程序代码610的存储空间。这些程序代码可以从一个或者多个计算机程序产品中读出或者写入到这一个或者多个计算机程序产品中。程序代码610可以例如以适当形式进行压缩。
192.本申请实施例还提供了一种计算机程序产品或计算机程序,该计算机程序产品或计算机程序包括计算机指令,该计算机指令存储在计算机可读存储介质中。计算机设备的处理器从计算机可读存储介质读取该计算机指令,处理器执行该计算机指令,使得该计算机设备执行上述各种可选实现方式中描述的方法。
193.综上,本申请提供的一种游戏控制方法、装置、电子设备及存储介质。方法包括:根据游戏场景配置信息,利用物理引擎创建虚拟场景;根据运行控制指令控制虚拟角色利用物理引擎在寻路路径上执行动作;预测虚拟角色沿寻路路径移动至目标位置的过程中,是否存在目标虚拟移动体与虚拟角色发生碰撞;当存在时,控制虚拟角色躲避碰撞。通过在预测到存在目标虚拟移动体与虚拟角色发生碰撞时,控制虚拟角色躲避碰撞,可以有效避免因虚拟角色与游戏场景中的可移动物体发生碰撞而使游戏画面发生卡顿,进而避免因游戏画面发生卡顿而影响玩家操作的情况,从而提升了玩家的体验。此外,通过在预测到虚拟角色与游戏场景内中的可移动物体发生碰撞时,控制虚拟角色躲避碰撞,从而使虚拟角色根据运行控制指令运行过程中真实模拟人的操作,从而进一步提升玩家的体验。
194.最后应说明的是:以上实施例仅用以说明本申请的技术方案,而非对其限制;尽管参照前述实施例对本申请进行了详细的说明,本领域的普通技术人员当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分技术特征进行等同替换;而这些修改或者替换,并不驱使相应技术方案的本质脱离本申请各实施例技术方案的精神和范围。
当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1