89 lines
3.4 KiB
C#
89 lines
3.4 KiB
C#
|
using System;
|
||
|
using System.Collections.Generic;
|
||
|
using System.IO;
|
||
|
using System.Linq;
|
||
|
using System.Text;
|
||
|
using System.Threading.Tasks;
|
||
|
using Microsoft.Xna.Framework;
|
||
|
using Microsoft.Xna.Framework.Graphics;
|
||
|
using StardewModdingAPI;
|
||
|
using StardewValley;
|
||
|
using xTile;
|
||
|
using xTile.Dimensions;
|
||
|
using xTile.Display;
|
||
|
using xTile.Layers;
|
||
|
|
||
|
namespace Revitalize.Framework.Minigame.SeasideScrambleMinigame
|
||
|
{
|
||
|
/// <summary>
|
||
|
/// TODO:
|
||
|
/// Force maps to all have the same layers as SDV maps so we can draw different things on a map.
|
||
|
///
|
||
|
/// </summary>
|
||
|
/*
|
||
|
* Back: Terrain, water, and basic features (like permanent paths).
|
||
|
Buildings: Placeholders for buildings (like the farmhouse). Any tiles placed on this layer will act like a wall unless the tile property has a "Passable" "T".
|
||
|
Paths: Flooring, paths, grass, and debris (like stones, weeds, and stumps from the 'paths' tilesheet) which can be removed by the player.
|
||
|
Front: Objects that are drawn on top of things behind them, like most trees. These objects will be drawn on top of the player if the player is North of them but behind the player if the player is south of them.
|
||
|
AlwaysFront: Objects that are always drawn on top of other layers as well as the player. This is typically used for foreground effects like foliage cover.
|
||
|
*/
|
||
|
public class SeasideScrambleMap
|
||
|
{
|
||
|
public xTile.Map map;
|
||
|
|
||
|
public SeasideScrambleMap()
|
||
|
{
|
||
|
|
||
|
}
|
||
|
|
||
|
public SeasideScrambleMap(Map Map)
|
||
|
{
|
||
|
this.map = Map;
|
||
|
//this.map.LoadTileSheets(Game1.mapDisplayDevice);
|
||
|
}
|
||
|
|
||
|
public virtual void update(GameTime time)
|
||
|
{
|
||
|
this.map.Update(time.TotalGameTime.Ticks);
|
||
|
}
|
||
|
|
||
|
public virtual void draw(SpriteBatch b)
|
||
|
{
|
||
|
b.Begin(SpriteSortMode.Deferred, BlendState.AlphaBlend, SamplerState.PointClamp, (DepthStencilState)null, (RasterizerState)null);
|
||
|
Game1.mapDisplayDevice.BeginScene(b);
|
||
|
|
||
|
for (int i = 0; i < this.map.Layers.Count; i++)
|
||
|
{
|
||
|
this.map.Layers[i].Draw(Game1.mapDisplayDevice, Game1.viewport, Location.Origin, false, 4);
|
||
|
}
|
||
|
Game1.mapDisplayDevice.EndScene();
|
||
|
b.End();
|
||
|
}
|
||
|
|
||
|
/// <summary>
|
||
|
/// Loads a map from a tbin file from the mod's asset folder.
|
||
|
/// </summary>
|
||
|
/// <param name="MapName"></param>
|
||
|
/// <returns></returns>
|
||
|
public static KeyValuePair<string, xTile.Map> LoadMap(string MapName)
|
||
|
{
|
||
|
// load the map file from your mod folder
|
||
|
string pathToMaps = Path.Combine("Content", "Minigames", "SeasideScramble", "Maps", MapName);
|
||
|
xTile.Map map = ModCore.ModHelper.Content.Load<Map>(pathToMaps, ContentSource.ModFolder);
|
||
|
for (int index = 0; index < map.TileSheets.Count; ++index)
|
||
|
{
|
||
|
string imageSource = map.TileSheets[index].ImageSource;
|
||
|
string fileName = Path.GetFileName(imageSource);
|
||
|
string path1 = Path.GetDirectoryName(imageSource);
|
||
|
map.TileSheets[index].ImageSource = Path.Combine(path1, fileName);
|
||
|
}
|
||
|
map.LoadTileSheets(Game1.mapDisplayDevice);
|
||
|
|
||
|
// get the internal asset key for the map file
|
||
|
string mapAssetKey = ModCore.ModHelper.Content.GetActualAssetKey(MapName, ContentSource.ModFolder);
|
||
|
return new KeyValuePair<string, Map>(mapAssetKey, map);
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|