2021-04-08 20:09:59 +08:00
|
|
|
|
using System;
|
|
|
|
|
|
|
|
|
|
namespace ET
|
|
|
|
|
{
|
|
|
|
|
[ObjectSystem]
|
|
|
|
|
public class PingComponentAwakeSystem: AwakeSystem<PingComponent>
|
|
|
|
|
{
|
|
|
|
|
public override void Awake(PingComponent self)
|
|
|
|
|
{
|
|
|
|
|
self.C2G_Ping = new C2G_Ping();
|
|
|
|
|
PingAsync(self).Coroutine();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static async ETVoid PingAsync(PingComponent self)
|
|
|
|
|
{
|
|
|
|
|
Session session = self.GetParent<Session>();
|
|
|
|
|
long instanceId = self.InstanceId;
|
|
|
|
|
|
|
|
|
|
while (true)
|
|
|
|
|
{
|
|
|
|
|
if (self.InstanceId != instanceId)
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
long time1 = TimeHelper.ClientNow();
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
G2C_Ping response = await session.Call(self.C2G_Ping) as G2C_Ping;
|
|
|
|
|
|
|
|
|
|
if (self.InstanceId != instanceId)
|
|
|
|
|
{
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
long time2 = TimeHelper.ClientNow();
|
|
|
|
|
self.Ping = time2 - time1;
|
|
|
|
|
Game.EventSystem.Publish_Sync(new ET.EventType.ChangePing
|
|
|
|
|
{
|
|
|
|
|
ping = (int)self.Ping
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
Game.TimeInfo.ServerMinusClientTime = response.Time + (time2 - time1) / 2 - time2;
|
2021-04-20 00:25:04 +08:00
|
|
|
|
session.ZoneScene().GetComponent<GlobalVariable>().Token = response.Token;
|
2021-04-08 20:09:59 +08:00
|
|
|
|
|
|
|
|
|
await TimerComponent.Instance.WaitAsync(2000);
|
|
|
|
|
}
|
|
|
|
|
catch (RpcException e)
|
|
|
|
|
{
|
|
|
|
|
// session断开导致ping rpc报错,记录一下即可,不需要打成error
|
|
|
|
|
Log.Info($"ping error: {self.Id} {e.Error}");
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
catch (Exception e)
|
|
|
|
|
{
|
|
|
|
|
Log.Error($"ping error: \n{e}");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[ObjectSystem]
|
|
|
|
|
public class PingComponentDestroySystem: DestroySystem<PingComponent>
|
|
|
|
|
{
|
|
|
|
|
public override void Destroy(PingComponent self)
|
|
|
|
|
{
|
|
|
|
|
self.Ping = default;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|