From 97b63e4382e38d697ba2ce0953bf5abd998f123d Mon Sep 17 00:00:00 2001
From: sin365 <353374337@qq.com>
Date: Tue, 12 Nov 2024 09:56:07 +0800
Subject: [PATCH 1/2] NetReplay
---
.../Assets/Plugins/AxiReplay/NetReplay.cs | 14 +++++++++++++-
1 file changed, 13 insertions(+), 1 deletion(-)
diff --git a/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs b/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs
index 086e06a3..9ed0edfb 100644
--- a/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs
+++ b/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs
@@ -51,10 +51,22 @@ namespace AxiReplay
TakeFrame(1, out data, out frameDiff, out inputDiff);
return frameDiff > 0;
}
+
+ public bool TryGetNextFrame(int targetFrame, out ReplayStep data, out int frameDiff, out bool inputDiff)
+ {
+ TakeFrameToTargetFrame(targetFrame, out data, out frameDiff, out inputDiff);
+ return frameDiff > 0;
+ }
+
void TakeFrame(int addFrame, out ReplayStep data, out int bFrameDiff, out bool inputDiff)
{
- inputDiff = false;
int targetFrame = mCurrClientFrameIdx + addFrame;
+ TakeFrameToTargetFrame(targetFrame, out data, out bFrameDiff, out inputDiff);
+ }
+
+ void TakeFrameToTargetFrame(int targetFrame, out ReplayStep data, out int bFrameDiff, out bool inputDiff)
+ {
+ inputDiff = false;
if (targetFrame <= mNextReplay.FrameStartID + 1 && targetFrame <= mRemoteFrameIdx && mNetReplayQueue.Count > 0)
{
//当前帧追加
From 6fbe29066a614e96218dc960a5d11691d5079b91 Mon Sep 17 00:00:00 2001
From: sin365 <353374337@qq.com>
Date: Tue, 12 Nov 2024 09:59:09 +0800
Subject: [PATCH 2/2] NetReplay
---
AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs | 3 ++-
1 file changed, 2 insertions(+), 1 deletion(-)
diff --git a/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs b/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs
index 9ed0edfb..162d5b95 100644
--- a/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs
+++ b/AxibugEmuOnline.Client/Assets/Plugins/AxiReplay/NetReplay.cs
@@ -11,7 +11,7 @@ namespace AxiReplay
///
/// 服务器远端当前帧
///
- public int mRemoteFrameIdx { get; private set; } = int.MinValue;
+ public int mRemoteFrameIdx { get; private set; }
///
/// Remote 2 Client Frame Gap
///
@@ -40,6 +40,7 @@ namespace AxiReplay
mCurrReplay.FrameStartID = int.MinValue;
mNextReplay = default(ReplayStep);
mNextReplay.FrameStartID = 0;
+ mRemoteFrameIdx = 0;
}
public void InData(ReplayStep inputData, int ServerFrameIdx)
{