]> Dogcows Code - chaz/carfire/blobdiff - CarFire/CarFire/CarFire/Display.cs
SaberMonster loads from map file and walks around using the path finder, and a lot...
[chaz/carfire] / CarFire / CarFire / CarFire / Display.cs
index d40c7e80c87d928b29394791d8b46c1bcacd5ffe..aceadfe14dddf4165520be4f47d56a8aab6409e9 100644 (file)
@@ -1,5 +1,9 @@
 #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
@@ -22,14 +26,13 @@ namespace CarFire
         IPlayer[] mCharacters = new IPlayer[4];\r
         Texture2D everything;\r
         Texture2D projectile1;\r
-        Map mMap;\r
-        int currentCenterX = 5;\r
-        int currentCenterY = 5;\r
+        Game mGame;\r
 #if SINGLE_TEST\r
         List<Keys> mLastPressedKeys = new List<Keys>();\r
 #endif\r
-        public Display()\r
+        public Display(Game game)\r
         {\r
+            mGame = game;\r
             /*\r
             mMap = aMap;\r
             mCharacters = characters;\r
@@ -44,25 +47,6 @@ namespace CarFire
         {\r
             everything = contentManager.Load<Texture2D>("cs");\r
             projectile1 = contentManager.Load<Texture2D>("projectile");\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
-            /*\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
-\r
-            \r
-            // TODO: use this.Content to load your game content here\r
         }\r
 \r
         /// <summary>\r
@@ -107,16 +91,20 @@ namespace CarFire
             mMap.CenterCell = new Vector2(mCharacters[0].GridX, mCharacters[0].GridY);\r
 #endif\r
             \r
-            \r
+            //Handle projectiles - update and check for wall collisions\r
             for (int i = 0; i < mProjectiles.Count; i++ )\r
             {\r
-                mProjectiles[i].Update(timespan);\r
-                if (!mMap.IsCellOpen(new Point(mProjectiles[i].GridX, mProjectiles[i].GridY)))\r
+                bool removed = false;\r
+                if (!mGame.State.Map.IsCellOpen(new Point(mProjectiles[i].Coordinates.X, mProjectiles[i].Coordinates.Y)))\r
                 {\r
                \r
                     mProjectiles.RemoveAt(i);\r
+                    removed = true;\r
                     i--;\r
                 }\r
+                if(!removed)\r
+                mProjectiles[i].Update(timespan);\r
+                \r
             }\r
             //Check for collisons\r
             for (int j = 0; j < mCharacters.Length; j++) \r
@@ -125,7 +113,7 @@ namespace CarFire
                 if(mCharacters[j] != null)\r
                 for (int i = 0; i < mProjectiles.Count; i++)\r
                 {\r
-                    if (mProjectiles[i].GridX == mCharacters[j].GridX && mProjectiles[i].GridY == mCharacters[j].GridY)\r
+                    if (mProjectiles[i].Coordinates.X == mCharacters[j].Coordinates.X && mProjectiles[i].Coordinates.Y == mCharacters[j].Coordinates.Y)\r
                     {\r
                         mCharacters[j].causeDamageTo(mProjectiles[i].Damage);\r
                         Console.WriteLine(mCharacters[j].Health);\r
@@ -134,25 +122,44 @@ namespace CarFire
                     }\r
                 }\r
             }\r
-            for (int i = 0; i < 4; i++)\r
+            //Update input for each player\r
+            for (int i = 0; i < mGame.State.NumberOfPlayers; i++)\r
             {\r
                 //If player has not selected a player yet let them select one.\r
                 if (mCharacters[i] == null)\r
                 {\r
-                    if (state.keysDown[i].Contains(Keys.Enter))\r
+                    if (mGame.State.GetKeysDown(i).Contains(Keys.Enter))\r
                     {\r
-                        mCharacters[i] = (new Human(mMap, "", everything, projectile1, this));\r
-                        mCharacters[i].GridX = mMap.GetStartingPositionForPlayer(i + 1).X;\r
-                        mCharacters[i].GridY = mMap.GetStartingPositionForPlayer(i + 1).Y;\r
+                        mCharacters[i] = new Human(mGame, "", everything, projectile1, this, mGame.State.Map.GetStartingPositionForPlayer(i + 1));\r
                     }\r
                 }\r
+                //Regular player input updates\r
                 else\r
                 {\r
 \r
-                    mCharacters[i].MovePlayer(state.keysDown[i]);\r
-                    mMap.CenterCell = new Vector2(mCharacters[0].GridX, mCharacters[0].GridY);\r
+                    mCharacters[i].MovePlayer(timespan, mGame.State.GetKeysDown(i));\r
+                   \r
                 }\r
             }\r
+            if (mCharacters[0] != null)\r
+            {\r
+                mGame.State.Map.CenterCell = mCharacters[0].Position;\r
+            }\r
+                //Handle wall collisions of projectiles again...\r
+            for (int i = 0; i < mProjectiles.Count; i++)\r
+            {\r
+                if (!mGame.State.Map.IsCellOpen(new Point(mProjectiles[i].Coordinates.X, mProjectiles[i].Coordinates.Y)))\r
+                {\r
+                    mProjectiles.RemoveAt(i);\r
+                    i--;\r
+                }          \r
+\r
+            }\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
@@ -161,25 +168,28 @@ namespace CarFire
         /// <param name="spriteBatch">Used to draw with</param>\r
         public void Draw(SpriteBatch spriteBatch)\r
         {\r
-            mMap.Draw(spriteBatch);\r
+            mGame.State.Map.Draw(spriteBatch);\r
+            mGame.State.Entities.ForEach(delegate(IEntity e) { e.Draw(spriteBatch); });\r
+\r
             foreach(Projectile projectile in mProjectiles)\r
             {\r
                 projectile.Draw(spriteBatch);\r
-                \r
             }\r
-            for(int i = 0; i < 4; i++)//IPlayer character in mCharacters)\r
+            for(int i = 0; i < mGame.State.NumberOfPlayers; i++)//IPlayer character in mCharacters)\r
             {\r
-                if(mCharacters[i] != null)\r
+\r
+                if (mCharacters[i] != null)\r
+                {\r
                     mCharacters[i].Draw(spriteBatch);\r
-            } \r
-        }\r
-        /*\r
-        public void AddCharacters(IPlayer player)\r
-        {\r
-            mCharacters[mCharacters.Length] = player;\r
-            //mCharacters.Add(player);\r
+                    \r
+                }\r
+            }\r
+            \r
         }\r
-         */\r
+        /// <summary>\r
+        /// Add a projectile to the Display.\r
+        /// </summary>\r
+        /// <param name="projectile"></param>\r
         public void AddProjectiles(Projectile projectile)\r
         {\r
             mProjectiles.Add(projectile);\r
This page took 0.022408 seconds and 4 git commands to generate.