diff --git a/AirBomber/AirBomber/MapsCollection.cs b/AirBomber/AirBomber/MapsCollection.cs new file mode 100644 index 0000000..20b280e --- /dev/null +++ b/AirBomber/AirBomber/MapsCollection.cs @@ -0,0 +1,85 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace AirBomber +{ + /// + /// Класс для хранения коллекции карт + /// + internal class MapsCollection + { + /// + /// Словарь (хранилище) с картами + /// + readonly Dictionary> _mapStorages; + /// + /// Возвращение списка названий карт + /// + public List Keys => _mapStorages.Keys.ToList(); + /// + /// Ширина окна отрисовки + /// + private readonly int _pictureWidth; + /// + /// Высота окна отрисовки + /// + private readonly int _pictureHeight; + /// + /// Конструктор + /// + /// + /// + public MapsCollection(int pictureWidth, int pictureHeight) + { + _mapStorages = new Dictionary>(); + _pictureWidth = pictureWidth; + _pictureHeight = pictureHeight; + } + /// + /// Добавление карты + /// + /// Название карты + /// Карта + public void AddMap(string name, AbstractMap map) + { + MapWithSetJetsGeneric mapJetsCollectionGeneric; + + // Если карта или её имя не задано - выходим + if (map == null || string.IsNullOrEmpty(name)) return; + + // Если совершается попытка добавить карту с уже существующим именем, то выходим + if (_mapStorages.ContainsKey(name)) return; + mapJetsCollectionGeneric = new MapWithSetJetsGeneric(_pictureWidth, _pictureHeight, map); + _mapStorages.Add(name, mapJetsCollectionGeneric); + + } + /// + /// Удаление карты + /// + /// Название карты + public void DelMap(string name) + { + // Если имя удаляемой карты не задано - выходим + if (string.IsNullOrEmpty(name)) return; + _mapStorages.Remove(name); + } + + /// + /// Доступ к ангару + /// + /// + /// + public MapWithSetJetsGeneric this[string ind] + { + get + { + if (string.IsNullOrEmpty(ind)) return null; + return _mapStorages[ind]; + + } + } + } +}