replays.
This commit is contained in:
@@ -132,8 +132,11 @@ namespace OpenRA
|
|||||||
|
|
||||||
ChangeMap(mapName);
|
ChangeMap(mapName);
|
||||||
|
|
||||||
if (Settings.Replay != "")
|
if( Settings.Replay != "" )
|
||||||
throw new NotImplementedException();
|
{
|
||||||
|
var connection = new ReplayConnection( Settings.Replay );
|
||||||
|
orderManager = new OrderManager( connection );
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
JoinLocal();
|
JoinLocal();
|
||||||
@@ -266,6 +269,7 @@ namespace OpenRA
|
|||||||
|
|
||||||
public static void StartGame()
|
public static void StartGame()
|
||||||
{
|
{
|
||||||
|
if( Game.orderManager.GameStarted ) return;
|
||||||
Game.chat.Reset();
|
Game.chat.Reset();
|
||||||
|
|
||||||
var taken = LobbyInfo.Clients.Where(c => c.SpawnPoint != 0)
|
var taken = LobbyInfo.Clients.Where(c => c.SpawnPoint != 0)
|
||||||
|
|||||||
@@ -98,6 +98,8 @@ namespace OpenRA.Graphics
|
|||||||
firstRow = r.Bottom - map.YOffset;
|
firstRow = r.Bottom - map.YOffset;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if( lastRow < firstRow ) lastRow = firstRow;
|
||||||
|
|
||||||
renderer.SpriteShader.SetValue( "DiffuseTexture", terrainSheet.Texture );
|
renderer.SpriteShader.SetValue( "DiffuseTexture", terrainSheet.Texture );
|
||||||
renderer.SpriteShader.Render(() =>
|
renderer.SpriteShader.Render(() =>
|
||||||
renderer.DrawBatch(vertexBuffer, indexBuffer,
|
renderer.DrawBatch(vertexBuffer, indexBuffer,
|
||||||
|
|||||||
@@ -140,4 +140,56 @@ namespace OpenRA.Network
|
|||||||
ms.WriteTo( socket.GetStream() );
|
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() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,6 +40,8 @@ namespace OpenRA.Network
|
|||||||
List<int> readyForFrames = new List<int>();
|
List<int> readyForFrames = new List<int>();
|
||||||
List<Order> localOrders = new List<Order>();
|
List<Order> localOrders = new List<Order>();
|
||||||
|
|
||||||
|
FileStream replaySaveFile;
|
||||||
|
|
||||||
public void StartGame()
|
public void StartGame()
|
||||||
{
|
{
|
||||||
if (GameStarted) return;
|
if (GameStarted) return;
|
||||||
@@ -59,6 +61,7 @@ namespace OpenRA.Network
|
|||||||
public OrderManager( IConnection conn, string replayFilename )
|
public OrderManager( IConnection conn, string replayFilename )
|
||||||
: this( conn )
|
: this( conn )
|
||||||
{
|
{
|
||||||
|
replaySaveFile = File.Create( replayFilename );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void IssueOrders( Order[] orders )
|
public void IssueOrders( Order[] orders )
|
||||||
@@ -96,8 +99,11 @@ namespace OpenRA.Network
|
|||||||
} );
|
} );
|
||||||
|
|
||||||
foreach( var p in immediatePackets )
|
foreach( var p in immediatePackets )
|
||||||
|
{
|
||||||
foreach( var o in p.Second.ToOrderList( world ) )
|
foreach( var o in p.Second.ToOrderList( world ) )
|
||||||
UnitOrders.ProcessOrder( world, p.First, o );
|
UnitOrders.ProcessOrder( world, p.First, o );
|
||||||
|
WriteImmediateToReplay( immediatePackets );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Dictionary<int, byte[]> syncForFrame = new Dictionary<int, byte[]>();
|
Dictionary<int, byte[]> syncForFrame = new Dictionary<int, byte[]>();
|
||||||
@@ -150,9 +156,38 @@ namespace OpenRA.Network
|
|||||||
|
|
||||||
var ss = sync.SerializeSync( FrameNumber );
|
var ss = sync.SerializeSync( FrameNumber );
|
||||||
Connection.Send( ss );
|
Connection.Send( ss );
|
||||||
|
WriteToReplay( frameData, ss );
|
||||||
|
|
||||||
CheckSync( ss );
|
CheckSync( ss );
|
||||||
|
|
||||||
++frameNumber;
|
++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 );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user