UE4网络同步属性笔记
GameMode只有服务端有,适合写游戏逻辑。PlayerController每个客户端拥有一个,并拥有主控权。GameState在服务端同步到全端。
CLIENT生成的Actor对其有Authority。
http://api.unrealengine.com/CHN/Gameplay/Framework/index.html
简单来讲 需要同步的操作写到Server,不需要同步的操作写到Client
变量同步
Replicated 复制模式
RepNotify:会创建一个变量改变通知的函数
属性复制条件介绍:http://api.unrealengine.com/CHN/Gameplay/Networking/Actors/Properties/Conditions/index.html
HasAuthority
对这个ACTOR是否有主控权限,Client对自己拥有的Pawn有Authority,Client生成的Actor也拥有Authority
Owner
给一个Actor设置拥有者,用于网络复制条件判断。源码里
Instigator
负责Destroy此Actor的Actor
UPROPERTY(ReplicatedUsing=OnRep_Owner)//属性复制,改变时调用函数onRep_Owner
AActor* Owner;
C++内写法
//.h
UFUNCTION(NetMulticast, reliable)
void Fun2();
//.cpp
void Cls1::Fun2_Implementation() {//这里要加_Implementation()
}//Fun2函数的实现被UHT(UnrealHeaderTool)使用了
相关代码
UObject::CallFunctionByNameWithArguments
UEngine::SetClientTravel
Actor的复制属性
OnlyRelevantToOwner 只和所有者相关
如果为真,则该角色(网络同步)仅与其所有者相关。如果在播放期间更改此标志,则所有非所有者信道都需要显式关闭。
如果这个Actor服务器只想让Actor的所有者得到同步信息,或者说,不想让整个地图的人都知道Actor的信息,只想让距离Actor的一定范围的人得到同步,又或者说,只想让某些付费玩家得到同步信息,怎么办?这时有一个叫“network relevant”的概念,也就是说,只有当一个Actor对于服务器是net relevant的时候,服务器才会同步信息给他。比如说:只想让Actor的所有者得到信息,我们可以设置Actor::bOnlyRelevantToOwner变量为true。
If true, this actor is only relevant to its owner. If this flag is changed during play, all non-owner channels would need to be explicitly closed
AlwaysRelevant
始终与网络相关(覆盖OnlyRelevantToOwner)
Always relevant for network (overrides bOnlyRelevantToOwner).
ReplicateMovement
如果是真的,复制移动/位置相关的属性,也必须是演员来复制。
If true, replicate movement/location related properties. Actor must also be set to replicate.
Net Load on Client
加载于地图加载期间
This actor will be loaded on network clients during map load
NetUseOwnerRelevancy
如果Actor有拥有者,调用业主的IsNetRelevantFor,GetNetPriority
覆盖IsNetRelevantFor,可自定义关联更新
If actor has valid Owner, call Owner's IsNetRelevantFor and GetNetPriority
Replicates 复写到远程机器
If true, this actor will replicate to remote machines
NetDormancy
Dormancy setting for actor to take itself off of the replication list without being destroyed on clients.
休眠设置,使演员从复制列表脱身而不被客户端损坏
- DORM_Never 永不休眠
This actor can never go network dormant. - DORM_Awake 当前醒着,可以关闭
This actor can go dormant, but is not currently dormant. Game code will tell it when it go dormant. - DORM_DormantAll 休眠 全体
This actor wants to go fully dormant for all connections. - DORM_DormantPartial 休眠部分
This actor may want to go dormant for some connections, GetNetDormancy() will be called to find out which. - DORM_Initial 初始休眠
This actor is initially dormant for all connection if it was placed in map.
NetCullDistanceSquared 网络剔除距离平方
最大距离的平方, 从客户视口来看, 这个演员是相关的, 将被复制。
Square of the max distance from the client's viewpoint that this actor is relevant and will be replicated.
NetUpdateFrequency 网络更新频率
How often (per second) this actor will be considered for replication, used to determine NetUpdateTime
MinNetUpdateFrequency 不经常更改时 速率
How often (per second) this actor will be considered for replication, used to determine NetUpdateTime
Net Priority 网络更新优先权
Priority for this actor when checking for replication in a low bandwidth or saturated situation, higher priority means it is more likely to replicate
Replicated Movement 移动复制
Velocity Quantization Level 量子化等级,把float后面的小数Round(四舍五入)
UE4 Actor复制流程
服务器遍历每一个actor查询是否参与属性复制
- 如果actor是 初始休眠 的,则跳过
- 通过AActor::netUpdateFrequency检查Actor是否需要更新
- 如果AActor::bOnlyRelevantToOwner为真,那么通过AActor::IsRelevancyOwnerFor栓查Actor所属connection
- 对于每一个通过最初检测的actor, 会调用AActor::PreReplication。
通过AActor::PreReplicatoin决定是否想要为连接复制这个属性。通过DorepLifeTime_Active _Override
- 全部条件通过会加入到ConsiderList
对于每一个在considerList的Actor
- 考虑是否休眠。
- 如果当前还未创建channel,考虑客户端是否加载了这个Actor,考虑actor与当前connection的相关性,未通过则跳过
- 将上述、前连接相关的actor加入列表,此时拥有了个与连接相关的需复制的actor列表,根据重要性对列表排序
对于每一个排序过后的Actor
- 如果当前连接仍未加载actor所在的level,则关掉channel
- 每一秒都通过调用AActor::IsNetRelevantFor来确定actor是否和当前连接相关
- 如果5秒不相关,关闭连接。如果相关但没有channel,则新开一个channel
如果在任意时刻connection饱和
- 对于剩余actors,如果相关小于1秒,强制下帧更新
- 如果大于1秒,调用AActor::IsNetRelevantFor瘊定下一帧是否更新
对于通过了以上规则的actor
通过调用UChannel::ReplicateActor对Actor进行复制
如果是channel打开后的第一次Update那么需要特殊初始化一些信息
如果该链接拥有这个actor,则设置actor::ENetRole=ROLE_AuonomousProxy,否则actor::ENetRole=Role_SimulatedProxy
相关文章
http://www.cnblogs.com/Leonhard-/p/6511821.html
https://blog.csdn.net/xiejihao/article/details/80264148#commentBox
https://blog.csdn.net/u012999985/article/details/78384199
UE4网络同步属性笔记的更多相关文章
- ue4网络同步概念笔记
网络同步主要的概念是 复制. 不是以前的S,C逻辑分离. 是S复制到C通过 Switch Has Authority 将S与C的逻辑在程序内分离. 所属权:每个连接到S的C都有自己的 控制权.从 ...
- UE4网络功能相关笔记
RepNotity的作用 把变量设置成RepNotify除了像C#语言中的"属性"一样,提供一个改变变量时调用一个函数的机会以外,其真正重要的作用其实是应对网通同步延迟问题. 一定 ...
- NetworkX学习笔记-5-NetworkX中怎样对多个网络赋属性,并根据属性排序
这是我在数据分析过程中遇到的实际问题,简单记录一下.这里以DiGraph为例,其他类型的网络(图)的处理方法是一样的. 按照这里:http://networkx.github.io/documenta ...
- UE4 内容示例网络同步Learn
一, 1.1 Actor的复制 Actor中的Replicates ,为true时,服务器会把该Actor同步,显示在客户端中. 1.2 Switch Has Authority判断是客户端还是服务器 ...
- 深入浅出UE4网络
UE4中的官方文档结构比较混乱,且有部分错误,不方便学习.笔者试图通过本文,整理出一篇关于UE4网络的文章,方便朋友们对UE4中的网络同步部分的认识,并有进一步理解.如有讲得不清楚明白的地方,还望批评 ...
- 小白探究UE4网络系列(一)、UE4网络基础类分析
转载请标明出处:http://www.cnblogs.com/zblade/ 一.概要 捣鼓UE4也有两个多月了,从这儿开始,逐步探究UE4中经典的值复制,RPC两种同步方式.想要弄到其复制和调用的原 ...
- SQL SERVER 数据库表同步复制 笔记
SQL SERVER 数据库表同步复制 笔记 同步复制可运行在不同版本的SQL Server服务之间 环境模拟需要两台数据库192.168.1.1(发布),192.168.1.10(订阅) 1.在发布 ...
- python网络爬虫学习笔记
python网络爬虫学习笔记 By 钟桓 9月 4 2014 更新日期:9月 4 2014 文章文件夹 1. 介绍: 2. 从简单语句中開始: 3. 传送数据给server 4. HTTP头-描写叙述 ...
- muduo网络库学习笔记(四) 通过eventfd实现的事件通知机制
目录 muduo网络库学习笔记(四) 通过eventfd实现的事件通知机制 eventfd的使用 eventfd系统函数 使用示例 EventLoop对eventfd的封装 工作时序 runInLoo ...
随机推荐
- 网络流24题 P1251 餐巾计划问题 拆点
题目描述 一个餐厅在相继的 NN 天里,每天需用的餐巾数不尽相同.假设第 ii 天需要 r_iri块餐巾( i=1,2,...,N).餐厅可以购买新的餐巾,每块餐巾的费用为 pp 分;或者把旧餐巾送 ...
- 云计算openstack介绍
一.云计算的前世今生 所有的新事物都不是突然冒出来的,都有前世和今生.云计算也是IT技术不断发展的产物. 要理解云计算,需要对IT系统架构的发展过程有所认识. 请看下 IT系统架构的发展到目前为止大致 ...
- 编译安装MySQL5.6失败的相关问题解决方案
Q0:需要安装git 解决方案: #CentOS yum install git #ubuntu apt-get install git Q1:CMAKE_CXX_COMPILER could be ...
- Windows服务器上使用phpstudy部署PHP程序
一.下载并安装PHPStudy 官网地址:http://phpstudy.php.cn/(安装包下载地址:链接:https://pan.baidu.com/s/1WOmbOwmLuUPt3_nmY6- ...
- kettle变量(var变量)
设置变量/set varibale 1.定义变量(子转换): 原始数据 设置获取变量:点击获取字段,自动获取变量名称和字段名称 引用变量: 输出: kettle.properties 文件存储在.ke ...
- Oracle篇 之 数据操作
一.DML 数据操作语言(Data Manipulation Language) 1.insert insert into student values(1,'briup1',20,'Male'); ...
- ctx中的body无法找到
学习koa的时候看到廖雪峰大大的文章 其中有一段写的总是报错找不到name 代码如下 router.get('/', async (ctx, next) => { ctx.response.bo ...
- Codeforces Round #522 (Div. 2, based on Technocup 2019 Elimination Round 3)B. Personalized Cup
题意:把一长串字符串 排成矩形形式 使得行最小 同时每行不能相差大于等于两个字符 每行也不能大于20个字符 思路: 因为使得行最小 直接行从小到大枚举即可 每行不能相差大于等于两个字符相当于 ...
- OpenFlow Flow-Mod消息学习
任务内容 1. 熟悉Flow-Mod消息触发场景. 2. 掌握Flow-Mod消息格式和常用字段含义. 实验原理 OpenFlow 协议支持3种消息类型:Controller-to-Switch(控制 ...
- Flink的高可用集群环境
Flink的高可用集群环境 Flink简介 Flink核心是一个流式的数据流执行引擎,其针对数据流的分布式计算提供了数据分布,数据通信以及容错机制等功能. 因现在主要Flink这一块做先关方面的学习, ...