Add base class for Server/ClientSyncer, fix #3
This commit is contained in:
parent
43059e57ca
commit
1a7e44b733
@ -1,46 +1,25 @@
|
||||
|
||||
using Cyber.Networking.Messages;
|
||||
using UnityEngine;
|
||||
|
||||
namespace Cyber.Networking.Clientside {
|
||||
|
||||
/// <summary>
|
||||
/// Syncer used on the clientside which sends sync packets from the client to the server containing their movement direction, rotation and possible checksums.
|
||||
/// </summary>
|
||||
public class ClientSyncer : MonoBehaviour {
|
||||
public class ClientSyncer : Syncer {
|
||||
|
||||
private const int ChecksumInterval = 10; // Every 10 ticks -> 1 per second
|
||||
public ClientSyncer() : base(1f / 10) {}
|
||||
|
||||
private const float TickInterval = 1 / 10f;
|
||||
private float TimeSinceLastTick = TickInterval;
|
||||
private int TickCounter = 0;
|
||||
|
||||
private int SyncIDCounter = 0;
|
||||
|
||||
private void Update() {
|
||||
TimeSinceLastTick += Time.deltaTime;
|
||||
if (TimeSinceLastTick >= TickInterval) {
|
||||
public override void PerformTick(int Tick) {
|
||||
|
||||
ClientSyncPkt SyncPkt = new ClientSyncPkt();
|
||||
|
||||
if (TickCounter % ChecksumInterval == 0) {
|
||||
// Add checksums
|
||||
}
|
||||
|
||||
var PlayerCharacter = Client.GetConnectedPlayer().Character;
|
||||
SyncPkt.ClientSyncID = SyncIDCounter++;
|
||||
SyncPkt.ClientSyncID = NextSyncID();
|
||||
SyncPkt.MoveDirection = PlayerCharacter.GetMovementDirection();
|
||||
SyncPkt.Rotation = PlayerCharacter.GetRotation();
|
||||
|
||||
Client.SendByChannel(PktType.ClientSync, SyncPkt, NetworkChannelID.Unreliable);
|
||||
|
||||
if (TickCounter < int.MaxValue) {
|
||||
TickCounter += 1;
|
||||
} else {
|
||||
TickCounter = 0;
|
||||
}
|
||||
TimeSinceLastTick -= TickInterval;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -21,9 +21,9 @@ namespace Cyber.Networking.Serverside {
|
||||
private Spawner Spawner;
|
||||
|
||||
/// <summary>
|
||||
/// The Syncer which syncs. <see cref="Syncer"/>
|
||||
/// The Syncer which syncs. <see cref="ServerSyncer"/>
|
||||
/// </summary>
|
||||
public Syncer Syncer;
|
||||
public ServerSyncer Syncer;
|
||||
|
||||
private ServerSyncHandler ServerSyncHandler;
|
||||
|
||||
@ -167,7 +167,7 @@ namespace Cyber.Networking.Serverside {
|
||||
Shutdown();
|
||||
});
|
||||
|
||||
Syncer = gameObject.AddComponent<Syncer>();
|
||||
Syncer = gameObject.AddComponent<ServerSyncer>();
|
||||
|
||||
ServerSyncHandler = new ServerSyncHandler(Players);
|
||||
|
||||
|
83
Assets/Scripts/Networking/Serverside/ServerSyncer.cs
Normal file
83
Assets/Scripts/Networking/Serverside/ServerSyncer.cs
Normal file
@ -0,0 +1,83 @@
|
||||
|
||||
using Cyber.Entities;
|
||||
using Cyber.Networking.Messages;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using UnityEngine;
|
||||
|
||||
namespace Cyber.Networking.Serverside {
|
||||
|
||||
/// <summary>
|
||||
/// Keeps stuff in-sync over at clients. Periodically collects stuff that needs to be synced and then sends them on the next 'tick.'
|
||||
/// </summary>
|
||||
public class ServerSyncer : Syncer {
|
||||
|
||||
private SyncDB Database;
|
||||
|
||||
private List<int> QueuedSyncs = new List<int>();
|
||||
private List<int> DirtySyncBases = new List<int>();
|
||||
|
||||
public ServerSyncer() : base(1f / 10) {}
|
||||
|
||||
/// <summary>
|
||||
/// Mark a SyncBase "Dirty", which makes it eligible to sync.
|
||||
/// </summary>
|
||||
/// <param name="syncBaseID">The ID of the SyncBase. See <see cref="SyncBase.ID"/></param>
|
||||
public void DirtSyncBase(int syncBaseID) {
|
||||
if (DirtySyncBases.Contains(syncBaseID)) {
|
||||
return;
|
||||
}
|
||||
DirtySyncBases.Add(syncBaseID);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
/// <param name="Tick"></param>
|
||||
public override void PerformTick(int Tick) {
|
||||
var Categorized = Database.GetCategorizedDatabase();
|
||||
List<int> checksummedIds = new List<int>();
|
||||
List<int> checksums = new List<int>();
|
||||
|
||||
foreach (Type type in Categorized.Keys) {
|
||||
SyncHandletype Handletype = Database.GetSyncHandletypes()[type];
|
||||
if (Tick % Handletype.TickInterval == 0) {
|
||||
foreach (int SyncBaseID in Categorized[type]) {
|
||||
bool Contains = DirtySyncBases.Contains(SyncBaseID);
|
||||
if (Contains == Handletype.RequireHash || Contains) {
|
||||
QueueSyncBase(SyncBaseID);
|
||||
if (Contains) {
|
||||
DirtySyncBases.Remove(SyncBaseID);
|
||||
}
|
||||
}
|
||||
if (Handletype.RequireHash) {
|
||||
checksummedIds.Add(SyncBaseID);
|
||||
checksums.Add(Database.Get(SyncBaseID).GenerateChecksum());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (QueuedSyncs.Count > 0) {
|
||||
int[] SyncIDs = QueuedSyncs.ToArray();
|
||||
SyncPkt SyncPacket = new SyncPkt(Database, SyncIDs, checksummedIds.ToArray(), checksums.ToArray(), NextSyncID());
|
||||
Server.SendToAllByChannel(PktType.Sync, SyncPacket, NetworkChannelID.Unreliable);
|
||||
|
||||
QueuedSyncs.Clear();
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Queue a SyncBase directly, so it will be synced next time a sync tick is called.
|
||||
/// </summary>
|
||||
/// <param name="SyncBaseID">The ID of the SyncBase. See <see cref="SyncBase.ID"/></param>
|
||||
public void QueueSyncBase(int SyncBaseID) {
|
||||
QueuedSyncs.Add(SyncBaseID);
|
||||
}
|
||||
|
||||
private void Start() {
|
||||
Database = GetComponent<SyncDB>();
|
||||
}
|
||||
|
||||
}
|
||||
}
|
@ -1,100 +0,0 @@
|
||||
|
||||
using Cyber.Console;
|
||||
using Cyber.Entities;
|
||||
using Cyber.Entities.SyncBases;
|
||||
using Cyber.Networking.Messages;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using UnityEngine;
|
||||
|
||||
namespace Cyber.Networking.Serverside {
|
||||
|
||||
/// <summary>
|
||||
/// Keeps stuff in-sync over at clients. Periodically collects stuff that needs to be synced and then sends them on the next 'tick.'
|
||||
/// </summary>
|
||||
public class Syncer : MonoBehaviour {
|
||||
|
||||
private SyncDB Database;
|
||||
|
||||
private int TickCounter = 0;
|
||||
private const float TickInterval = 1f / 10;
|
||||
|
||||
private float TimeSinceLastTick = TickInterval;
|
||||
|
||||
private List<int> QueuedSyncs = new List<int>();
|
||||
private List<int> DirtySyncBases = new List<int>();
|
||||
|
||||
private int SyncPacketID = 0;
|
||||
|
||||
/// <summary>
|
||||
/// Mark a SyncBase "Dirty", which makes it eligible to sync.
|
||||
/// </summary>
|
||||
/// <param name="syncBaseID">The ID of the SyncBase. See <see cref="SyncBase.ID"/></param>
|
||||
public void DirtSyncBase(int syncBaseID) {
|
||||
if (DirtySyncBases.Contains(syncBaseID)) {
|
||||
return;
|
||||
}
|
||||
DirtySyncBases.Add(syncBaseID);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Queue a SyncBase directly, so it will be synced next time a sync tick is called.
|
||||
/// </summary>
|
||||
/// <param name="SyncBaseID">The ID of the SyncBase. See <see cref="SyncBase.ID"/></param>
|
||||
public void QueueSyncBase(int SyncBaseID) {
|
||||
QueuedSyncs.Add(SyncBaseID);
|
||||
}
|
||||
|
||||
private void Start() {
|
||||
Database = GetComponent<SyncDB>();
|
||||
}
|
||||
|
||||
private void Update() {
|
||||
TimeSinceLastTick += Time.deltaTime;
|
||||
if (TimeSinceLastTick >= TickInterval) {
|
||||
|
||||
var Categorized = Database.GetCategorizedDatabase();
|
||||
List<int> checksummedIds = new List<int>();
|
||||
List<int> checksums = new List<int>();
|
||||
|
||||
foreach (Type type in Categorized.Keys) {
|
||||
SyncHandletype Handletype = Database.GetSyncHandletypes()[type];
|
||||
if (TickCounter % Handletype.TickInterval == 0) {
|
||||
foreach (int SyncBaseID in Categorized[type]) {
|
||||
bool Contains = DirtySyncBases.Contains(SyncBaseID);
|
||||
if (Contains == Handletype.RequireHash || Contains) {
|
||||
QueueSyncBase(SyncBaseID);
|
||||
if (Contains) {
|
||||
DirtySyncBases.Remove(SyncBaseID);
|
||||
}
|
||||
}
|
||||
if (Handletype.RequireHash) {
|
||||
checksummedIds.Add(SyncBaseID);
|
||||
checksums.Add(Database.Get(SyncBaseID).GenerateChecksum());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if (QueuedSyncs.Count > 0) {
|
||||
int[] SyncIDs = QueuedSyncs.ToArray();
|
||||
SyncPkt SyncPacket = new SyncPkt(Database, SyncIDs, checksummedIds.ToArray(), checksums.ToArray(), SyncPacketID++);
|
||||
Server.SendToAllByChannel(PktType.Sync, SyncPacket, NetworkChannelID.Unreliable);
|
||||
|
||||
QueuedSyncs.Clear();
|
||||
}
|
||||
|
||||
|
||||
if (TickCounter < int.MaxValue) {
|
||||
TickCounter++;
|
||||
} else {
|
||||
TickCounter = 0;
|
||||
}
|
||||
TimeSinceLastTick -= TickInterval;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
}
|
44
Assets/Scripts/Networking/Syncer.cs
Normal file
44
Assets/Scripts/Networking/Syncer.cs
Normal file
@ -0,0 +1,44 @@
|
||||
|
||||
using UnityEngine;
|
||||
|
||||
namespace Cyber.Networking {
|
||||
|
||||
|
||||
public abstract class Syncer : MonoBehaviour {
|
||||
|
||||
private int TickCounter = 0;
|
||||
|
||||
private readonly float TickInterval;
|
||||
private float TimeSinceLastTick = 0;
|
||||
|
||||
private int SyncPacketID = 0;
|
||||
|
||||
public Syncer(float tickInterval) {
|
||||
TickInterval = tickInterval;
|
||||
TimeSinceLastTick = tickInterval;
|
||||
}
|
||||
|
||||
public int NextSyncID() {
|
||||
return SyncPacketID++;
|
||||
}
|
||||
|
||||
private void Update() {
|
||||
TimeSinceLastTick += Time.deltaTime;
|
||||
|
||||
if (TimeSinceLastTick > TickInterval) {
|
||||
PerformTick(TickCounter);
|
||||
|
||||
if (TickCounter < int.MaxValue) {
|
||||
TickCounter++;
|
||||
} else {
|
||||
TickCounter = 0;
|
||||
}
|
||||
|
||||
TimeSinceLastTick -= TickInterval;
|
||||
}
|
||||
}
|
||||
|
||||
public abstract void PerformTick(int Tick);
|
||||
|
||||
}
|
||||
}
|
12
Assets/Scripts/Networking/Syncer.cs.meta
Normal file
12
Assets/Scripts/Networking/Syncer.cs.meta
Normal file
@ -0,0 +1,12 @@
|
||||
fileFormatVersion: 2
|
||||
guid: b9778f182f90b2a4291e31b85f12803c
|
||||
timeCreated: 1494793021
|
||||
licenseType: Free
|
||||
MonoImporter:
|
||||
serializedVersion: 2
|
||||
defaultReferences: []
|
||||
executionOrder: 0
|
||||
icon: {instanceID: 0}
|
||||
userData:
|
||||
assetBundleName:
|
||||
assetBundleVariant:
|
Loading…
Reference in New Issue
Block a user