public string Name;\r
public Mode Type;\r
public string Author;\r
+ public string Next;\r
public HashSet<int> NumPlayers = new HashSet<int>();\r
public string Tileset;\r
public int GridWidth;\r
/// </summary>\r
public string Author { get { return mData.Metadata.Author; } }\r
\r
+ /// <summary>\r
+ /// Get the name of the next map to load after this one.\r
+ /// </summary>\r
+ public string Next { get { return mData.Metadata.Next; } }\r
+\r
/// <summary>\r
/// Get a set of integers containing each allowable number of players.\r
/// </summary>\r
/// <summary>\r
/// Get and set the tilemap with its associated texture and tile\r
/// character to coordinate mappings. This effects what the map looks\r
- /// like when it is drawn.\r
+ /// like when it is drawn. You will need to reset any map instances\r
+ /// after setting a new tilemap. You should also set a tilemap before\r
+ /// instantiating any maps.\r
/// </summary>\r
- public Tilemap Tilemap\r
- {\r
- get { return mData.Tilemap; }\r
- set { mData.Tilemap = value; }\r
- }\r
+ public static Tilemap Tilemap;\r
\r
/// <summary>\r
/// Get and set the zoom of the map view. The default zoom is\r
public List<RawEntity> Entities { get { return mEntities; } }\r
public Point[] PlayerPositions { get { return mPlayerPositions; } }\r
public bool[,] Grid { get { return mBooleanGrid; } }\r
- public Tilemap Tilemap;\r
\r
\r
public Model(Metadata metadata, char[,] grid, char defaultTile,\r
Debug.Assert(grid != null);\r
Debug.Assert(entities != null);\r
Debug.Assert(metadata.GridWidth * metadata.GridHeight == grid.Length);\r
+ Debug.Assert(Tilemap != null);\r
\r
mMetadata = metadata;\r
mCleanGrid = grid;\r
\r
public void Draw(SpriteBatch spriteBatch)\r
{\r
- if (mData.Tilemap == null) throw new Exception("Cannot draw map without first setting the tilemap.");\r
+ if (Tilemap == null) throw new Exception("Cannot draw map without first setting the tilemap.");\r
mViewport = spriteBatch.GraphicsDevice.Viewport;\r
\r
for (int y = 0; y < mData.Metadata.GridHeight; y++)\r
{\r
for (int x = 0; x < mData.Metadata.GridWidth; x++)\r
{\r
- mData.Tilemap.Draw(spriteBatch, mData.GetCell(x, y), GetRectangleFromCoordinates(x, y));\r
+ Tilemap.Draw(spriteBatch, mData.GetCell(x, y), GetRectangleFromCoordinates(x, y));\r
}\r
}\r
}\r