diff --git a/Boats/Boats/MapsCollection.cs b/Boats/Boats/MapsCollection.cs new file mode 100644 index 0000000..dd761e7 --- /dev/null +++ b/Boats/Boats/MapsCollection.cs @@ -0,0 +1,83 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace Boats +{ + /// + /// Класс для хранения коллекции карт + /// + 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) + { + // Добавление карты + MapWithSetBoatsGeneric newMap = new(_pictureWidth, _pictureHeight, map); + _mapStorages.Add(name, newMap); + } + /// + /// Удаление карты + /// + /// Название карты + public void DelMap(string name) + { + // Удаление карты + if (!_mapStorages.ContainsKey(name)) + { + return; + } + _mapStorages.Remove(name); + } + /// + /// Доступ к гавани + /// + /// + /// + public MapWithSetBoatsGeneric this[string index] + { + get + { + // Получение объекта + if (_mapStorages.ContainsKey(index)) + { + return _mapStorages[index]; + } + return null; + } + } + } +}