| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- using System.Collections.Generic;
- namespace Model
- {
- public struct SessionFrameMessage
- {
- public Session Session;
- public FrameMessage FrameMessage;
- }
-
- [ObjectSystem]
- public class ClientFrameComponentSystem : ObjectSystem<ClientFrameComponent>, IStart
- {
- public void Start()
- {
- this.Get().Start();
- }
- }
- public class ClientFrameComponent: Component
- {
- public int Frame;
- public Queue<SessionFrameMessage> Queue = new Queue<SessionFrameMessage>();
- public int count = 1;
-
- public int waitTime;
- public const int maxWaitTime = 40;
- public void Start()
- {
- UpdateAsync();
- }
- public void Add(Session session, FrameMessage frameMessage)
- {
- this.Queue.Enqueue(new SessionFrameMessage() {Session = session, FrameMessage = frameMessage});
- }
- public async void UpdateAsync()
- {
- TimerComponent timerComponent = Game.Scene.GetComponent<TimerComponent>();
- while (true)
- {
- // 如果队列中消息多于4个,则加速跑帧
- this.waitTime = maxWaitTime;
- if (this.Queue.Count > 4)
- {
- this.waitTime = maxWaitTime - (this.Queue.Count - 4) * 2;
- }
- // 最快加速一倍
- if (this.waitTime < 20)
- {
- this.waitTime = 20;
- }
- await timerComponent.WaitAsync(waitTime);
- if (this.Id == 0)
- {
- return;
- }
-
- this.UpdateFrame();
- }
- }
- private void UpdateFrame()
- {
- if (this.Queue.Count == 0)
- {
- return;
- }
- SessionFrameMessage sessionFrameMessage = this.Queue.Dequeue();
- this.Frame = sessionFrameMessage.FrameMessage.Frame;
- for (int i = 0; i < sessionFrameMessage.FrameMessage.Messages.Count; ++i)
- {
- AFrameMessage message = sessionFrameMessage.FrameMessage.Messages[i];
- ushort opcode = Game.Scene.GetComponent<OpcodeTypeComponent>().GetOpcode(message.GetType());
- Game.Scene.GetComponent<MessageDispatherComponent>().Handle(sessionFrameMessage.Session, new MessageInfo() { Opcode= opcode, Message = message });
- }
- }
- }
- }
|