UE4 HTC VIVE - 番外篇 - 局域网联机(二)

 
  
开始之前先说一下网游中服务器与客户端的大致关系:
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第1张图片
网络游戏中各段关系图
客户端职责:

1)接收玩家的输入翻译得到【玩家指令】上传服务器;
2)接收服务器下发的【游戏指令】并将其实现

服务器职责:

1)接收客户端的指令并处理;
2)广播当前帧所需的游戏数据与游戏状态;

强联网中的高带宽与游戏中的卡顿解释:
服务器压力:

我们打团战的时候会出现输入没有响应,正式因为让你的输入产生结果的模块不在客户端而是在服务器;此时服务器要处理大量用户指令计算时间过长外加网络限制,客户端得不到及时的数据更新;
【有预处理机制部分还是能动的,例如部分网游在延迟是时也能正常速率移动,但是在得到最新数据后,玩家将被纠到正确坐标;这正是一种降低小幅延迟的策略,所带来的现象。想继续了解如何解决网络延迟策略的可以传送门https://www.zhihu.com/question/36258781/answer/80841137】

高带宽:

多名玩家同屏时,为了能看到其他玩家的样子和属性值,所以每次更新都需要所有需要绘制的玩家数据,所以高带宽是强联网的前提;

我们再来看局域网中的主机与客户端的关系
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第2张图片
主机与客户端的关系

因为主机与客户端本身都是同一套应用程序,所以都包含完整功能;然而局域网游戏中,作为主机的一端除了运行完整的客户端(玩家操作接收处理和图像图形显示)职能外,还需要具有网络结构中的服务器端职能,对整个局域我那个游戏的数据进行计算与存储,逻辑处理与发送;而其他客户端进需要运行客户端部分功能即可参与局域网游戏;(故局域网中主机压力巨大,既要做逻辑与数据运算,还要完成图像显示处理)

--------------------开启本章内容(官方案例讲解)-----------------------------

书接上回在上一篇尾巴上留了RPC介绍,也就是虚幻的函数复制原理,本章我带着大家过一遍官方关于networke的案例,了解一下变量复制与函数复制以便后面使用节点时不会懵逼;

下载官方案例"内容示例"

UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第3张图片
在这里下载
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第4张图片
下载完当然是打开了
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第5张图片
打开后我们点击根目录Content,然后使用筛选功能,找出所有场景
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第6张图片
然后找到【Network_Features】
这里推荐点击官方的帮助文档“食用”效果更佳:
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第7张图片
找到绿色的帮助对象,点击打开帮助文档
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第8张图片
英语不好的同学可以切换到中文

案例1.1对象的复制

该场景的查看方式均使用多窗口浏览;
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第9张图片
不要忘了上一章讲的多窗口浏览方式和设置方法
本案例将在两个【Target Point】的位置生成幽灵对象;由于对象的蓝图类的Replicates属性的不同,所以表现出不参与复制对象在主机端存在而客户端不存在的效果;
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第10张图片
运行结果


1)我们打开场景蓝图与两个幽灵的蓝图类;

UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第11张图片
两个生成对象所使用的蓝图类是不一样的
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第12张图片
虽然是继承关系但是在复制选项上有所区别

可以看到由于两个不同的对象类在复制选项上有所区别,故客户端与服务器的显示结果是不同的,

需要注意的(一定将核心处理限制在主机端):
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第13张图片
确认服务器执行


这是联机蓝图的关键所在,逻辑也好数据处理也好,一定要交给服务器来操作,客户端只要做显示与用户操作采集相关的编辑即可;

案例1.2 Switch Has Authority节点学习

该实例通过对服务器和客户端执行不同实现来加深对Switch Has Authority 节点的了解;
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第14张图片
显示结果
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第15张图片
该幽灵的蓝图

案例1.3值复制(仅更新变量值)

该实例主要使用值复制的方法来实现客户端与主机的数据同步;
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第16张图片
运行结果,客户端观察到左侧幽灵的健康值一直为0而右侧的则与服务器同步
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第17张图片
右侧的幽灵中关于Health这个int值进做了复制设置
知识点分析:

当变量被标记为Replicated后,在服务器修改该变量数值,系统会及时将其更新到客户端,此时对该变量进行调用则可以拿到更新后的值;【使用在角色属性或是绘制相关数据的同步情景,】

案例1.4值复制(更新变量值时触发一次函数调用)

本实例使用定时修改一个标记为RepNotify的浮点值得方式变更交通灯的状态;我们主要学习RepNotify标记所带来的一次事件调用;
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第18张图片
1,创建一个变量
2,标记为Replicated
3,你会发现蹦出来一个与该变量关联的函数
4,桶盖这个函数来对变量赋值即可
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第19张图片
标记提供的一次函数调用,此处用来变更材质颜色属性值
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第20张图片
为什么灯有变化?有兴趣的同学看看材质蓝图
知识点:

使用该标记后得到的函数调用,可以用来编辑一些诸如生命归零的死亡判断,或是与跟该变量有关的函数赋值操作就像本示例中的材质属性变更都可以写在该函数中;

案例1.5 事件广播Multicast的使用

本实例通过对自定义事添加Multicast标签使其成为服务器在调用时,所有客户端都会触发的事件,达到广播的目的;
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第21张图片
触发事件的广播设置

案例2.1 不添加复制标记的蓝图效果

本实例应当是作为参照示例使用,并没有特殊之处
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第22张图片
我们可以看到永远是服务器端触发金闪闪实现,
毕竟事件没有加复制标记客户端未接收任何事件调用

案例2.2 依旧是事件广播Multicast的使用

本实例中关于事件广播就不赘述了,我们可以发现一个有趣的事情就是有个圈,在圈外的客户端是无法接收到广播消息的,并且在进入环形范围内也不会再看到触发效果【广播事件是不会被保存的】(当然你站上去也是没用的,以为有DoOne节点,只可能发生一次)
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第23张图片
Paste_Image.png
看一下圈是怎么缩放设置的
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第24张图片
缩放环形模型大小
该值是每个参与复制的对象,都需要设置的值,该值标示这个对象接收服务器消息数据更新的范围(这个值不能直接用,为了距离比较时削减运算开销所以是个平方值,这里注意一下)
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第25张图片
注意该对象的Replicates属性

案例2.3关于如何对进入复制检测范围的对象进行状态更新

本实例中使用了一个bool值来记录状态,当有客户端进入该范围内时更新这个客户端用户的变量值,这个时候会触发Replicated标记创建来的函数,也就实现了开箱和闪光效果
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第26张图片
UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第27张图片
此处将特效显示与箱子翻起的显示部分都放在这个函数内了
知识点:

我们可以模仿此方法,来实现对走入检测范围内的新对象的状态更新;

案例2.4 仅保留开箱后的结果更新,不显示闪光特效

我们可以看到这个版本的蓝图中开箱与闪光特效被分开触发了,这样在触发范围内的客户端可以接收到触发闪光特效也可通过变更bool值变量来完成开箱动画,但是后进入的客户端仅能触发开箱动画,即完成了新版组合方案;

UE4 HTC VIVE - 番外篇 - 局域网联机(二)_第28张图片
变更后的蓝图

你可能感兴趣的:(UE4)