X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fcarfire;a=blobdiff_plain;f=CarFire%2FCarFire%2FCarFire%2FGame.cs;h=8b9b0759e9bacb46f6756aef25afe6e3075d41c9;hp=38ec627d1456dcff5531f055f9e4a3f45808872d;hb=f41d1413bdee1a69450ca6c2bca9932a4c61a6d9;hpb=16658241429e8befc3cb171a62163f36dedb6a33 diff --git a/CarFire/CarFire/CarFire/Game.cs b/CarFire/CarFire/CarFire/Game.cs index 38ec627..8b9b075 100644 --- a/CarFire/CarFire/CarFire/Game.cs +++ b/CarFire/CarFire/CarFire/Game.cs @@ -15,6 +15,10 @@ namespace CarFire public class GameState { #region Public Properties + private const int hitMonsterScore = 20; + private const int killMonsterScore = 100; + public int HitMonsterScore { get { return hitMonsterScore; } } + public int KillMonsterScore { get { return killMonsterScore; } } public long FrameNumber { get { return mFrameNumber; } } @@ -24,7 +28,10 @@ namespace CarFire public Map Map; public List Entities = new List(); - + public List mProjectiles = new List(); + public Player[] mCharacters; + public Display mDisplay; + public AI AIData; #endregion @@ -39,6 +46,8 @@ namespace CarFire mNumberOfPlayers = numPlayers; mFrameNumber = 0; + mCharacters = new Player[numPlayers]; + mIsGameOver = new bool[numPlayers]; mIsTerminated = new bool[numPlayers]; @@ -220,7 +229,7 @@ namespace CarFire foreach (IEntity entity in State.Entities) { Point coordinates = entity.Coordinates; - grid[coordinates.X, coordinates.Y] = true; + if (State.Map.IsCellOpen(coordinates)) grid[coordinates.X, coordinates.Y] = false; } return grid; } @@ -231,24 +240,55 @@ namespace CarFire #region Public Methods - public bool IsCellOpen(Point point) + public IEntity GetEntityAtCoordinates(Point point) { - if (!State.Map.IsCellOpen(point)) return false; foreach (IEntity entity in State.Entities) { - if (entity.Coordinates == point) return false; + if (entity.Coordinates == point) return entity; + } + return null; + } + + public Player GetPlayerAtCoordinates(Point point) + { + foreach (Player player in State.mCharacters) + { + if (player != null && player.Coordinates == point) return player; } + return null; + } + + public bool IsCellOpen(Point point) + { + if (!State.Map.IsCellOpen(point)) return false; + if (GetEntityAtCoordinates(point) != null) return false; return true; } public Game() { - mDisplay = new Display(this); + + } + /// + /// This method should be called whenever the players want to move to a new map. + /// Not implemented yet. Need some way to get next map. + /// + public void startNewMap() + { + //TODO somehow get next map + State.Entities.Clear(); + //State.Map = State.Map.getNextMap(); + for (int i = 0; i < State.mCharacters.Length; i++) + { + State.mCharacters[i].Coordinates = State.Map.GetStartingPositionForPlayer(i + 1); + } + State.Entities = State.Map.GetAllEntities(this); } public void LoadContent(ContentManager contentManager) { mContentManager = contentManager; - mDisplay.LoadContent(contentManager); + menu = mContentManager.Load("menuFont"); + } public void UnloadContent() @@ -290,11 +330,50 @@ namespace CarFire State = new GameState(numPlayers); mInputs = new NextInputs(numPlayers); - - State.Map = mContentManager.Load("Maps/stable"); - State.Map.Game = this; - State.Entities = State.Map.GetAllEntities(); - Map.DefaultTile = mContentManager.Load("default"); + State.mDisplay = new Display(this); + State.mDisplay.LoadContent(mContentManager); + + Texture2D mapTiles = mContentManager.Load("graphics/wallAndFloorTilesNoEdgeScale"); + Tilemap tilemap = new Tilemap(mapTiles, 10, 7); + tilemap.SetTile(' ', new Point(4, 5)); + tilemap.SetTile('`', new Point(0, 1)); + tilemap.SetTile('~', new Point(1, 1)); + tilemap.SetTile('!', new Point(3, 1)); + tilemap.SetTile('@', new Point(4, 1)); + tilemap.SetTile('#', new Point(5, 1)); + tilemap.SetTile('$', new Point(6, 1)); + tilemap.SetTile('%', new Point(8, 1)); + tilemap.SetTile('^', new Point(9, 1)); + tilemap.SetTile('&', new Point(0, 2)); + tilemap.SetTile('=', new Point(1, 2)); + tilemap.SetTile('*', new Point(2, 2)); + tilemap.SetTile('(', new Point(4, 2)); + tilemap.SetTile(')', new Point(0, 3)); + tilemap.SetTile('_', new Point(2, 3)); + tilemap.SetTile('-', new Point(9, 3)); + tilemap.SetTile(',', new Point(1, 4)); + tilemap.SetTile('+', new Point(2, 4)); + tilemap.SetTile('[', new Point(3, 4)); + tilemap.SetTile(']', new Point(4, 4)); + tilemap.SetTile('{', new Point(5, 4)); + tilemap.SetTile('}', new Point(6, 4)); + tilemap.SetTile('\\', new Point(8, 4)); + tilemap.SetTile('|', new Point(9, 4)); + tilemap.SetTile(';', new Point(0, 5)); + tilemap.SetTile(':', new Point(1, 5)); + tilemap.SetTile('\'', new Point(2, 5)); + tilemap.SetTile('"', new Point(3, 5)); + tilemap.SetTile('.', new Point(5, 5)); + tilemap.SetTile('<', new Point(6, 5)); + tilemap.SetTile('>', new Point(7, 5)); + tilemap.SetTile('/', new Point(8, 5)); + tilemap.SetTile('?', new Point(9, 5)); + + State.Map = mContentManager.Load("Maps/level1"); + State.Map.Tilemap = tilemap; + State.Entities = State.Map.GetAllEntities(this); + + State.AIData = new AI(this); /* mPlayers.Clear(); @@ -361,7 +440,7 @@ namespace CarFire public long Update(TimeSpan elapsedTime) { State.AdvanceFrame(mInputs, elapsedTime.Milliseconds); // Apply the inputs, advance game state. - mDisplay.Update(elapsedTime, State, mThisPlayerID); + State.mDisplay.Update(elapsedTime, mThisPlayerID); State.Entities.ForEach(delegate(IEntity e) { e.Update(elapsedTime); }); mInputs = new NextInputs(State.NumberOfPlayers); // Start with inputs cleared on the next frame. //mDisplay.Update(elapsedTime); @@ -371,7 +450,35 @@ namespace CarFire public long Draw(SpriteBatch spriteBatch) { - mDisplay.Draw(spriteBatch); + bool allCharactersSelected = true; + for (int i = 0; i < State.NumberOfPlayers; i++) + { + //If player has not selected a player yet let them select one. + if (State.mCharacters[i] == null) + { + allCharactersSelected = false; + if (State.GetKeysDown(i).Contains(Keys.M)) + { + State.mCharacters[i] = new Melee(this, "", State.Map.GetStartingPositionForPlayer(i + 1), i); + State.mCharacters[i].LoadContent(mContentManager); + } + else if (State.GetKeysDown(i).Contains(Keys.R)) + { + State.mCharacters[i] = new Ranged(this, "", State.Map.GetStartingPositionForPlayer(i + 1), i); + State.mCharacters[i].LoadContent(mContentManager); + } + } + } + if (allCharactersSelected) + { + + State.mDisplay.Draw(spriteBatch); + } + else + { + spriteBatch.GraphicsDevice.Clear(Color.Black); + spriteBatch.DrawString(menu, "Press R to select a Ranged Character and M to select a Melee Character", new Vector2(30, 30), Color.RosyBrown); + } return CurrentFrameNumber; } @@ -380,7 +487,7 @@ namespace CarFire #region Private Variables - Display mDisplay; + SpriteFont menu; ContentManager mContentManager; NextInputs mInputs;