2 using System.Collections.Generic;
4 using Microsoft.Xna.Framework;
5 using Microsoft.Xna.Framework.Audio;
6 using Microsoft.Xna.Framework.Content;
7 using Microsoft.Xna.Framework.GamerServices;
8 using Microsoft.Xna.Framework.Graphics;
9 using Microsoft.Xna.Framework.Input;
10 using Microsoft.Xna.Framework.Media;
11 using Microsoft.Xna.Framework.Net;
12 using Microsoft.Xna.Framework.Storage;
13 using CS_3505_Project_06.CS_3505;
15 namespace CS_3505_Project_06
18 /// A game outline for testing network communications
20 public class Game06 : Microsoft.Xna.Framework.Game
22 GraphicsDeviceManager graphics;
23 SpriteBatch spriteBatch;
25 NetworkGame networkGame;
28 IDeterministicGame deterministicGame;
35 graphics = new GraphicsDeviceManager(this);
36 Content.RootDirectory = "Content";
38 Components.Add(new GamerServicesComponent(this));
40 lobby = new lobbyGUI();
41 deterministicGame = new TestHarness();
42 networkGame = new NetworkGame(lobby, deterministicGame);
46 /// Allows the game to perform any initialization it needs to before starting to run.
47 /// This is where it can query for any required services and load any non-graphic
48 /// related content. Calling base.Initialize will enumerate through any components
49 /// and initialize them as well.
51 protected override void Initialize()
53 // Set a fixed time span of 1/60th of a second.
54 IsFixedTimeStep = true;
55 TargetElapsedTime = networkGame.TargetTimeSpan;
57 // DEBUG: This is for the test harness.
58 Mouse.SetPosition(400, 300);
60 // Allow the base class to initialize.
65 /// LoadContent will be called once per game and is the place to load
66 /// all of your content.
68 protected override void LoadContent()
70 // Create a new SpriteBatch, which can be used to draw textures.
72 spriteBatch = new SpriteBatch(GraphicsDevice);
74 lobby.LoadContent(Content, graphics);
75 deterministicGame.LoadContent(Content);
79 /// UnloadContent will be called once per game and is the place to unload
82 protected override void UnloadContent()
84 lobby.UnloadContent();
85 deterministicGame.UnloadContent();
89 /// Allows the game to run logic such as updating the world,
90 /// checking for collisions, gathering input, and playing audio.
92 /// <param name="gameTime">Provides a snapshot of timing values.</param>
93 protected override void Update(GameTime gameTime)
95 networkGame.Update(gameTime);
97 // Allow the superclass to do any needed updates (unknown purpose).
98 base.Update(gameTime);
102 /// This is called when the game should draw itself.
104 /// <param name="gameTime">Provides a snapshot of timing values.</param>
105 protected override void Draw(GameTime gameTime)
107 // DEBUG: This is for the test harness.
108 GraphicsDevice.Clear(new Color(16, 16, 16, 255));
112 // Let the game draw itself.
113 networkGame.Draw(gameTime, spriteBatch);