开始之前先说一下网游中服务器与客户端的大致关系:
客户端职责:
1)接收玩家的输入翻译得到【玩家指令】上传服务器;
2)接收服务器下发的【游戏指令】并将其实现服务器职责:
1)接收客户端的指令并处理;
2)广播当前帧所需的游戏数据与游戏状态;强联网中的高带宽与游戏中的卡顿解释:
服务器压力:
我们打团战的时候会出现输入没有响应,正式因为让你的输入产生结果的模块不在客户端而是在服务器;此时服务器要处理大量用户指令计算时间过长外加网络限制,客户端得不到及时的数据更新;
【有预处理机制部分还是能动的,例如部分网游在延迟是时也能正常速率移动,但是在得到最新数据后,玩家将被纠到正确坐标;这正是一种降低小幅延迟的策略,所带来的现象。想继续了解如何解决网络延迟策略的可以传送门https://www.zhihu.com/question/36258781/answer/80841137】高带宽:
多名玩家同屏时,为了能看到其他玩家的样子和属性值,所以每次更新都需要所有需要绘制的玩家数据,所以高带宽是强联网的前提;
我们再来看局域网中的主机与客户端的关系
因为主机与客户端本身都是同一套应用程序,所以都包含完整功能;然而局域网游戏中,作为主机的一端除了运行完整的客户端(玩家操作接收处理和图像图形显示)职能外,还需要具有网络结构中的服务器端职能,对整个局域我那个游戏的数据进行计算与存储,逻辑处理与发送;而其他客户端进需要运行客户端部分功能即可参与局域网游戏;(故局域网中主机压力巨大,既要做逻辑与数据运算,还要完成图像显示处理)
--------------------开启本章内容(官方案例讲解)-----------------------------
书接上回在上一篇尾巴上留了RPC介绍,也就是虚幻的函数复制原理,本章我带着大家过一遍官方关于networke的案例,了解一下变量复制与函数复制以便后面使用节点时不会懵逼;
下载官方案例"内容示例"
这里推荐点击官方的帮助文档“食用”效果更佳:
案例1.1对象的复制
该场景的查看方式均使用多窗口浏览;
本案例将在两个【Target Point】的位置生成幽灵对象;由于对象的蓝图类的Replicates属性的不同,所以表现出不参与复制对象在主机端存在而客户端不存在的效果;
1)我们打开场景蓝图与两个幽灵的蓝图类;可以看到由于两个不同的对象类在复制选项上有所区别,故客户端与服务器的显示结果是不同的,
需要注意的(一定将核心处理限制在主机端):
这是联机蓝图的关键所在,逻辑也好数据处理也好,一定要交给服务器来操作,客户端只要做显示与用户操作采集相关的编辑即可;案例1.2 Switch Has Authority节点学习
该实例通过对服务器和客户端执行不同实现来加深对Switch Has Authority 节点的了解;
案例1.3值复制(仅更新变量值)
该实例主要使用值复制的方法来实现客户端与主机的数据同步;
知识点分析:
当变量被标记为Replicated后,在服务器修改该变量数值,系统会及时将其更新到客户端,此时对该变量进行调用则可以拿到更新后的值;【使用在角色属性或是绘制相关数据的同步情景,】
案例1.4值复制(更新变量值时触发一次函数调用)
本实例使用定时修改一个标记为RepNotify的浮点值得方式变更交通灯的状态;我们主要学习RepNotify标记所带来的一次事件调用;
知识点:
使用该标记后得到的函数调用,可以用来编辑一些诸如生命归零的死亡判断,或是与跟该变量有关的函数赋值操作就像本示例中的材质属性变更都可以写在该函数中;
案例1.5 事件广播Multicast的使用
本实例通过对自定义事添加Multicast标签使其成为服务器在调用时,所有客户端都会触发的事件,达到广播的目的;
案例2.1 不添加复制标记的蓝图效果
本实例应当是作为参照示例使用,并没有特殊之处
案例2.2 依旧是事件广播Multicast的使用
本实例中关于事件广播就不赘述了,我们可以发现一个有趣的事情就是有个圈,在圈外的客户端是无法接收到广播消息的,并且在进入环形范围内也不会再看到触发效果【广播事件是不会被保存的】(当然你站上去也是没用的,以为有DoOne节点,只可能发生一次)
看一下圈是怎么缩放设置的
该值是每个参与复制的对象,都需要设置的值,该值标示这个对象接收服务器消息数据更新的范围(这个值不能直接用,为了距离比较时削减运算开销所以是个平方值,这里注意一下)
案例2.3关于如何对进入复制检测范围的对象进行状态更新
本实例中使用了一个bool值来记录状态,当有客户端进入该范围内时更新这个客户端用户的变量值,这个时候会触发Replicated标记创建来的函数,也就实现了开箱和闪光效果
知识点:
我们可以模仿此方法,来实现对走入检测范围内的新对象的状态更新;
案例2.4 仅保留开箱后的结果更新,不显示闪光特效
我们可以看到这个版本的蓝图中开箱与闪光特效被分开触发了,这样在触发范围内的客户端可以接收到触发闪光特效也可通过变更bool值变量来完成开箱动画,但是后进入的客户端仅能触发开箱动画,即完成了新版组合方案;