]> Dogcows Code - chaz/carfire/blobdiff - CarFire/CarFire/CarFire/Display.cs
git-svn-id: https://bd85.net/svn/cs3505_group@168 92bb83a3-7c8f-8a45-bc97-515c4e399668
[chaz/carfire] / CarFire / CarFire / CarFire / Display.cs
index 98f91ed45eeeb9243301e05d35478b7a32545cf5..ed848fa31d07596d970b868cf8c55336765e1102 100644 (file)
@@ -1,4 +1,10 @@
-using System;\r
+#undef SINGLE_TEST\r
+\r
+// Define INGAME_ZOOM to allow zooming in and out with\r
+// the PageUp and PageDown keys.\r
+#define INGAME_ZOOM\r
+\r
+using System;\r
 using System.Collections.Generic;\r
 using System.Linq;\r
 using System.Text;\r
@@ -14,13 +20,19 @@ namespace CarFire
     /// </summary>\r
     public class Display\r
     {\r
-        List<Projectile> mProjectiles = new List<Projectile>();\r
-        List<Character> mCharacters = new List<Character>();\r
-        Map mMap;\r
-        int currentCenterX = 5;\r
-        int currentCenterY = 5;\r
-        public Display()\r
+        Texture2D everything;\r
+        Texture2D projectile1;\r
+        Game mGame;\r
+        GameLogic mGameLogic;\r
+        HUD theHUD;\r
+#if SINGLE_TEST\r
+        List<Keys> mLastPressedKeys = new List<Keys>();\r
+#endif\r
+        public Display(Game game)\r
         {\r
+            mGame = game;\r
+            mGameLogic = new GameLogic(game);\r
+            theHUD = new HUD(game);\r
             /*\r
             mMap = aMap;\r
             mCharacters = characters;\r
@@ -33,23 +45,9 @@ namespace CarFire
         /// </summary>\r
         public void LoadContent(ContentManager contentManager)\r
         {\r
-            Texture2D everything = contentManager.Load<Texture2D>("cs");\r
-            mMap = contentManager.Load<Map>("Maps/stable");\r
-            Map.DefaultTile = contentManager.Load<Texture2D>("default");\r
-            mMap.CenterCell = new Vector2(currentCenterX,currentCenterY);\r
-            //Debugging... Spawn eight projectiles.\r
-            //Diagonals\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(5,5), 10, 10, 300, 300));\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(-5, 5), 10, 10, 300, 300));\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(5, -5), 10, 10, 300, 300));\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(-5, -5), 10, 10, 300, 300));\r
-            //Vertical and horizontal\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(0, 5), 10, 10, 300, 300));\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(-5, 0), 10, 10, 300, 300));\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(5, 0), 10, 10, 300, 300));\r
-            mProjectiles.Add(new Projectile(mMap, everything, new Vector2(0, -5), 10, 10, 300, 300));\r
-\r
-            // TODO: use this.Content to load your game content here\r
+            everything = contentManager.Load<Texture2D>("cs");\r
+            projectile1 = contentManager.Load<Texture2D>("projectile");\r
+            theHUD.LoadContent(contentManager);\r
         }\r
 \r
         /// <summary>\r
@@ -66,27 +64,14 @@ namespace CarFire
         /// checking for collisions, gathering input, and playing audio.\r
         /// </summary>\r
         /// <param name="gameTime">Provides a snapshot of timing values.</param>\r
-        public void Update(TimeSpan timespan)\r
+        public void Update(TimeSpan timeSpan,int thisPlayer)\r
         {\r
-            mMap.CenterCell = new Vector2(currentCenterX, currentCenterY);\r
-            foreach (Projectile projectile in mProjectiles)\r
-            {\r
-                projectile.Update(timespan);\r
-            }\r
-            //Check for collisons\r
-            foreach (Character character in mCharacters)\r
-            {\r
-                foreach (Projectile projectile in mProjectiles)\r
-                {\r
-                    if (projectile.GridX == character.GridX && projectile.GridY == character.GridY)\r
-                    {\r
-                        //Debug - not sure if you can remove while doing for each\r
-                        //Alternative - while loop, and decrement projectile counter if projectile is removed.\r
-                        mProjectiles.Remove(projectile);\r
-                        character.Health -= projectile.Damage;\r
-                    }\r
-                }\r
-            }\r
+            mGameLogic.Update(timeSpan, thisPlayer);\r
+\r
+#if INGAME_ZOOM\r
+            if (Keyboard.GetState().IsKeyDown(Keys.PageUp)) mGame.State.Map.Zoom = mGame.State.Map.Zoom + 0.5f;\r
+            if (Keyboard.GetState().IsKeyDown(Keys.PageDown)) mGame.State.Map.Zoom = mGame.State.Map.Zoom - 0.5f;\r
+#endif\r
         }\r
 \r
         /// <summary>\r
@@ -95,19 +80,27 @@ namespace CarFire
         /// <param name="spriteBatch">Used to draw with</param>\r
         public void Draw(SpriteBatch spriteBatch)\r
         {\r
-            mMap.Draw(spriteBatch);\r
-            foreach(Projectile projectile in mProjectiles)\r
+            mGame.State.Map.Draw(spriteBatch);\r
+            mGame.State.Entities.ForEach(delegate(IEntity e) { e.Draw(spriteBatch); });\r
+\r
+            foreach(Projectile projectile in mGame.State.mProjectiles)\r
             {\r
                 projectile.Draw(spriteBatch);\r
-                \r
             }\r
-            foreach(Character character in mCharacters)\r
+            for(int i = 0; i < mGame.State.NumberOfPlayers; i++)//IPlayer character in mCharacters)\r
             {\r
-                character.Draw(spriteBatch);\r
+\r
+                if (mGame.State.mCharacters[i] != null)\r
+                {\r
+                    mGame.State.mCharacters[i].Draw(spriteBatch);\r
+                    \r
+                }\r
             }\r
+            theHUD.Draw(spriteBatch);\r
 \r
             \r
         }\r
+        \r
     }\r
 }\r
 \r
This page took 0.020327 seconds and 4 git commands to generate.