This commit is contained in:
Bob
2010-03-09 22:47:05 +13:00
parent 106255066b
commit 79ce7c15d5
4 changed files with 97 additions and 4 deletions

View File

@@ -133,7 +133,10 @@ namespace OpenRA
ChangeMap(mapName);
if( Settings.Replay != "" )
throw new NotImplementedException();
{
var connection = new ReplayConnection( Settings.Replay );
orderManager = new OrderManager( connection );
}
else
{
JoinLocal();
@@ -266,6 +269,7 @@ namespace OpenRA
public static void StartGame()
{
if( Game.orderManager.GameStarted ) return;
Game.chat.Reset();
var taken = LobbyInfo.Clients.Where(c => c.SpawnPoint != 0)

View File

@@ -98,6 +98,8 @@ namespace OpenRA.Graphics
firstRow = r.Bottom - map.YOffset;
}
if( lastRow < firstRow ) lastRow = firstRow;
renderer.SpriteShader.SetValue( "DiffuseTexture", terrainSheet.Texture );
renderer.SpriteShader.Render(() =>
renderer.DrawBatch(vertexBuffer, indexBuffer,

View File

@@ -140,4 +140,56 @@ namespace OpenRA.Network
ms.WriteTo( socket.GetStream() );
}
}
class ReplayConnection : IConnection
{
uint nextFrame = 1;
FileStream replayStream;
public ReplayConnection( string replayFilename )
{
replayStream = File.OpenRead( replayFilename );
}
public int LocalClientId
{
get { return 0; }
}
public ConnectionState ConnectionState
{
get { return ConnectionState.Connected; }
}
public void Send( byte[] packet )
{
// do nothing; ignore locally generated orders
}
public void Receive( Action<int, byte[]> packetFn )
{
if( replayStream != null )
{
var reader = new BinaryReader( replayStream );
while( replayStream.Position < replayStream.Length )
{
var client = reader.ReadInt32();
var packetLen = reader.ReadInt32();
var packet = reader.ReadBytes( packetLen );
packetFn( client, packet );
if( !Game.orderManager.GameStarted )
return;
}
replayStream = null;
}
else
{
var ms = new MemoryStream();
ms.Write( BitConverter.GetBytes( nextFrame++ ) );
ms.Write( new byte[] { 0xEF } );
packetFn( 0, ms.ToArray() );
}
}
}
}

View File

@@ -40,6 +40,8 @@ namespace OpenRA.Network
List<int> readyForFrames = new List<int>();
List<Order> localOrders = new List<Order>();
FileStream replaySaveFile;
public void StartGame()
{
if (GameStarted) return;
@@ -59,6 +61,7 @@ namespace OpenRA.Network
public OrderManager( IConnection conn, string replayFilename )
: this( conn )
{
replaySaveFile = File.Create( replayFilename );
}
public void IssueOrders( Order[] orders )
@@ -96,8 +99,11 @@ namespace OpenRA.Network
} );
foreach( var p in immediatePackets )
{
foreach( var o in p.Second.ToOrderList( world ) )
UnitOrders.ProcessOrder( world, p.First, o );
WriteImmediateToReplay( immediatePackets );
}
}
Dictionary<int, byte[]> syncForFrame = new Dictionary<int, byte[]>();
@@ -150,9 +156,38 @@ namespace OpenRA.Network
var ss = sync.SerializeSync( FrameNumber );
Connection.Send( ss );
WriteToReplay( frameData, ss );
CheckSync( ss );
++frameNumber;
}
void WriteToReplay( Dictionary<int, byte[]> frameData, byte[] syncData )
{
if( replaySaveFile == null ) return;
foreach( var f in frameData )
{
replaySaveFile.Write( BitConverter.GetBytes( f.Key ) );
replaySaveFile.Write( BitConverter.GetBytes( f.Value.Length ) );
replaySaveFile.Write( f.Value );
}
replaySaveFile.Write( BitConverter.GetBytes( (int)0 ) );
replaySaveFile.Write( BitConverter.GetBytes( (int)syncData.Length ) );
replaySaveFile.Write( syncData );
}
void WriteImmediateToReplay( List<Pair<int, byte[]>> immediatePackets )
{
if( replaySaveFile == null ) return;
foreach( var i in immediatePackets )
{
replaySaveFile.Write( BitConverter.GetBytes( i.First ) );
replaySaveFile.Write( BitConverter.GetBytes( i.Second.Length ) );
replaySaveFile.Write( i.Second );
}
}
}
}