FPS游戏框架漫谈第十天

2024-02-01 17:52

本文主要是介绍FPS游戏框架漫谈第十天,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

下面我们来谈谈PVE 他是什么呢 Player Vs Computer 即玩家对抗在游戏中玩家挑战游戏程序所控制的NPC怪物和BOSS
一般是多个玩家一起合作对抗 电脑程序

那么如何设计PVE的架构呢?????
1.如何刷怪 2.ai行走路径 客户端寻路还是服务器寻路 3.技能如何同步 4.移动同步

下面我来讲下我的思路 我的思路是对战开局之前 后台会通过Respawn的方式刷出boss和小怪 至于你协议是批量还是单个都ky
既然怪出来了,那么这个怪支持多少技能,具体技能是什么,那么技能属于应该有什么,很明显这个是可以策划配置的,针对不同的怪配置不同的技能,技能属性包括当前技能开始释放的时间,技能释放总时长也就是技能需要播放多久,技能释放的当前位置,技能释放的目标位置,当然技能释放目标位置这种肯定是服务器根据战场动态计算获得,技能释放多久策划配置。以及技能的类型 比如你是开枪还是喷火。
一般来说PVE AI最多具备5个阶段的技能 第一个阶段是移动 第二个阶段是旋转 第三个阶段是预攻击 第四个阶段是攻击
第五个阶段是攻击结束

每个阶段包含 开始释放时间,技能时长,技能开始目标,技能释放目标,技能需要的旋转角度,等等其实有了这些数据我们足够客户端模拟怪物的技能展示了。

技能如何保持同步 那么需要注意的是后台下发的技能阶段已经确定了技能播放的开始时间和结束时间,客户端只是进行模拟,这个方案其实就已经同步了,客户端要做的事就是技能的动作时长和后台给的技能播放时长必须匹配, 怎么做呢,通过后台给的技能播放时长来修改技能动作的播放速度即可同步。

寻路 我们这个是采用服务器进行寻路 后台会根据目标 对ai进行寻路,然后下发关键路径到客户端,客户端进行移动模拟即可
那么由于后台下发的移动包也是指定了当前PathNode是什么时间开始移动,以及需要移动的目标位置,以及移动的时长。并且后台会对特殊路点作为关键路径,因此客户端如何做到同步可以检测移动包是不是过期可以采用后台提供的数据进行强制同步。

还有策划提的各种情况 比如是否忽略动作 是否采用动作进行移动 等客户端需要进行正确的处理
第11天见

这篇关于FPS游戏框架漫谈第十天的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668010

相关文章

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

国产游戏崛起:技术革新与文化自信的双重推动

近年来,国产游戏行业发展迅猛,技术水平和作品质量均得到了显著提升。特别是以《黑神话:悟空》为代表的一系列优秀作品,成功打破了过去中国游戏市场以手游和网游为主的局限,向全球玩家展示了中国在单机游戏领域的实力与潜力。随着中国开发者在画面渲染、物理引擎、AI 技术和服务器架构等方面取得了显著进展,国产游戏正逐步赢得国际市场的认可。然而,面对全球游戏行业的激烈竞争,国产游戏技术依然面临诸多挑战,未来的

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO

Sentinel 高可用流量管理框架

Sentinel 是面向分布式服务架构的高可用流量防护组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 Sentinel 具有以下特性: 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应

火柴游戏java版

代码 /*** 火柴游戏* <p>* <li>有24根火柴</li>* <li>组成 A + B = C 等式</li>* <li>总共有多少种适合方式?</li>* <br>* <h>分析:</h>* <li>除去"+"、"="四根,最多可用火柴根数20根。</li>* <li>全部用两根组合成"1",最大数值为1111。使用枚举法,A和B范围在0~1111,C为A+B。判断</li>** @

利用Django框架快速构建Web应用:从零到上线

随着互联网的发展,Web应用的需求日益增长,而Django作为一个高级的Python Web框架,以其强大的功能和灵活的架构,成为了众多开发者的选择。本文将指导你如何从零开始使用Django框架构建一个简单的Web应用,并将其部署到线上,让世界看到你的作品。 Django简介 Django是由Adrian Holovaty和Simon Willison于2005年开发的一个开源框架,旨在简