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.
55 IsFixedTimeStep = true;
56 TargetElapsedTime = networkGame.TargetTimeSpan;
58 // DEBUG: This is for the test harness.
59 Mouse.SetPosition(400, 300);
61 // Allow the base class to initialize.
67 /// LoadContent will be called once per game and is the place to load
68 /// all of your content.
70 protected override void LoadContent()
72 // Create a new SpriteBatch, which can be used to draw textures.
74 spriteBatch = new SpriteBatch(GraphicsDevice);
76 lobby.LoadContent(Content, graphics);
77 deterministicGame.LoadContent(Content);
81 /// UnloadContent will be called once per game and is the place to unload
84 protected override void UnloadContent()
86 lobby.UnloadContent();
87 deterministicGame.UnloadContent();
91 /// Allows the game to run logic such as updating the world,
92 /// checking for collisions, gathering input, and playing audio.
94 /// <param name="gameTime">Provides a snapshot of timing values.</param>
95 protected override void Update(GameTime gameTime)
97 networkGame.Update(gameTime);
99 // Allow the superclass to do any needed updates (unknown purpose).
100 base.Update(gameTime);
104 /// This is called when the game should draw itself.
106 /// <param name="gameTime">Provides a snapshot of timing values.</param>
107 protected override void Draw(GameTime gameTime)
109 // DEBUG: This is for the test harness.
110 GraphicsDevice.Clear(new Color(16, 16, 16, 255));
114 // Let the game draw itself.
115 networkGame.Draw(gameTime, spriteBatch);