From be78916b6def0e630ee6bf28fd0f983b1449d745 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=BA=D1=80=D0=B8=D1=81=D1=82=D0=B8=D0=BD=D0=B0=20=D0=BB?= =?UTF-8?q?=D0=B0=D0=B2=D1=80=D0=BE=D0=B2=D0=B0?= Date: Thu, 23 May 2024 11:15:50 +0400 Subject: [PATCH] =?UTF-8?q?4=20=D0=BB=D0=B0=D0=B1=20=D0=A4=D0=98=D0=9D?= =?UTF-8?q?=D0=98=D0=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../MassiveGenericObjects.cs | 23 ++- .../StorageCollection.cs | 39 ++--- .../FormTrackedVehicleCollection.Designer.cs | 5 - solution/lab1/FormTrackedVehicleCollection.cs | 151 ++++++++---------- 4 files changed, 105 insertions(+), 113 deletions(-) diff --git a/solution/lab1/CollectionGenericObjects/MassiveGenericObjects.cs b/solution/lab1/CollectionGenericObjects/MassiveGenericObjects.cs index 8353bdf..280370a 100644 --- a/solution/lab1/CollectionGenericObjects/MassiveGenericObjects.cs +++ b/solution/lab1/CollectionGenericObjects/MassiveGenericObjects.cs @@ -15,10 +15,25 @@ public class MassiveGenericObjects : ICollectionGenericObjects private T?[] _collection; public int Count => _collection.Length; - public int SetMaxCount { set { if (value > 0) { _collection = new T?[value]; } } } - /// - /// Конструктор - /// + public int SetMaxCount + { + set + { + if (value > 0) + { + if (_collection.Length > 0) + { + Array.Resize(ref _collection, value); + } + else + { + _collection = new T?[value]; + } + } + } + } /// + /// Конструктор + /// public MassiveGenericObjects() { _collection = Array.Empty(); diff --git a/solution/lab1/CollectionGenericObjects/StorageCollection.cs b/solution/lab1/CollectionGenericObjects/StorageCollection.cs index 3139ef4..e5bd5c6 100644 --- a/solution/lab1/CollectionGenericObjects/StorageCollection.cs +++ b/solution/lab1/CollectionGenericObjects/StorageCollection.cs @@ -10,16 +10,18 @@ namespace lab1.CollectionGenericObjects; /// /// public class StorageCollection - where T : class + where T : class { /// - /// Словарь(хранилище) с коллекциями + /// Словарь (хранилище) с коллекциями /// readonly Dictionary> _storages; + /// /// Возвращение списка названий коллекций /// public List Keys => _storages.Keys.ToList(); + /// /// Конструктор /// @@ -27,54 +29,45 @@ public class StorageCollection { _storages = new Dictionary>(); } + /// /// Добавление коллекции в хранилище /// /// Название коллекции - /// Тип коллекции + /// тип коллекции public void AddCollection(string name, CollectionType collectionType) { - // TODO проверка, что name не пустой и нет в словаре записи с таким ключом - // TODO Прописать логику для добавления - if (!(collectionType == CollectionType.None) && !_storages.ContainsKey(name)) - { - if (collectionType == CollectionType.List) - { - _storages.Add(name, new ListGenericObjects()); - } - else if (collectionType == CollectionType.Massive) - { - _storages.Add(name, new MassiveGenericObjects()); - } - } + + if (_storages.ContainsKey(name)) return; + if (collectionType == CollectionType.None) return; + else if (collectionType == CollectionType.Massive) + _storages[name] = new MassiveGenericObjects(); + else if (collectionType == CollectionType.List) + _storages[name] = new ListGenericObjects(); } + /// /// Удаление коллекции /// /// Название коллекции public void DelCollection(string name) { - // TODO Прописать логику для удаления коллекции if (_storages.ContainsKey(name)) - { _storages.Remove(name); - } - } + /// /// Доступ к коллекции /// - /// + /// Название коллекции /// public ICollectionGenericObjects? this[string name] { get { - // TODO Продумать логику получения объекта if (_storages.ContainsKey(name)) return _storages[name]; return null; } - } } diff --git a/solution/lab1/FormTrackedVehicleCollection.Designer.cs b/solution/lab1/FormTrackedVehicleCollection.Designer.cs index 27b833e..037a526 100644 --- a/solution/lab1/FormTrackedVehicleCollection.Designer.cs +++ b/solution/lab1/FormTrackedVehicleCollection.Designer.cs @@ -133,7 +133,6 @@ maskedTextBox.Size = new Size(284, 31); maskedTextBox.TabIndex = 4; maskedTextBox.ValidatingType = typeof(int); - maskedTextBox.MaskInputRejected += maskedTextBox1_MaskInputRejected; // // buttonGoToCheck // @@ -221,7 +220,6 @@ radioButtonMassive.TabStop = true; radioButtonMassive.Text = "Массив"; radioButtonMassive.UseVisualStyleBackColor = true; - radioButtonMassive.CheckedChanged += radioButtonMassive_CheckedChanged; // // textBoxCollectionName // @@ -249,7 +247,6 @@ comboBoxSelectorCompany.Name = "comboBoxSelectorCompany"; comboBoxSelectorCompany.Size = new Size(284, 33); comboBoxSelectorCompany.TabIndex = 1; - comboBoxSelectorCompany.SelectedIndexChanged += comboBoxSelectorCompany_SelectedIndexChanged; // // pictureBox // @@ -259,7 +256,6 @@ pictureBox.Size = new Size(677, 710); pictureBox.TabIndex = 1; pictureBox.TabStop = false; - pictureBox.Click += pictureBox1_Click; // // FormTrackedVehicleCollection // @@ -270,7 +266,6 @@ Controls.Add(groupBoxTools); Name = "FormTrackedVehicleCollection"; Text = "Коллекция гусеничных машин"; - Load += FormTrackedVehicleCollection_Load; groupBoxTools.ResumeLayout(false); panelCompanyTools.ResumeLayout(false); panelCompanyTools.PerformLayout(); diff --git a/solution/lab1/FormTrackedVehicleCollection.cs b/solution/lab1/FormTrackedVehicleCollection.cs index 6f13647..e33a787 100644 --- a/solution/lab1/FormTrackedVehicleCollection.cs +++ b/solution/lab1/FormTrackedVehicleCollection.cs @@ -1,17 +1,18 @@ using lab1.CollectionGenericObjects; using lab1.Drawnings; +using System.Windows.Forms; namespace lab1; + /// -///Форма работы с компанией и её коллекцией +/// Форма работы с компанией и ее коллекцией /// public partial class FormTrackedVehicleCollection : Form { - /// - /// Хранилище коллекций - /// - private readonly StorageCollection _storageCollection; + /// Хранилише коллекций + /// + private readonly StorageCollection _storageCollection; /// /// Компания /// @@ -25,25 +26,31 @@ public partial class FormTrackedVehicleCollection : Form InitializeComponent(); _storageCollection = new(); } + /// /// Выбор компании /// /// /// - - private void comboBoxSelectorCompany_SelectedIndexChanged(object sender, EventArgs e) + private void ComboBoxSelectorCompany_SelectedIndexChanged(object sender, EventArgs e) { - panelCompanyTools.Enabled = false; + switch (comboBoxSelectorCompany.Text) + { + case "Хранилище": + _company = new TrackedVehicleSharingService(pictureBox.Width, pictureBox.Height, new MassiveGenericObjects()); + break; + } } /// - /// Добавление гусеничной машины + /// Добавление обычного автомобиля /// /// /// private void ButtonAddTrackedVehicle_Click(object sender, EventArgs e) => CreateObject(nameof(DrawningTrackedVehicle)); + /// - /// Добавление истребителя + /// Добавление спортивного автомобиля /// /// /// @@ -52,49 +59,48 @@ public partial class FormTrackedVehicleCollection : Form /// /// Создание объекта класса-перемещения /// - /// + /// Тип создаваемого объекта private void CreateObject(string type) { if (_company == null) { return; } + Random random = new(); - DrawningTrackedVehicle drawningTrackedVehicle; + DrawningTrackedVehicle drawingTrans; switch (type) { case nameof(DrawningTrackedVehicle): - drawningTrackedVehicle = new DrawningTrackedVehicle(random.Next(100, 300), random.Next(1000, 3000), GetColor(random)); + drawingTrans = new DrawningTrackedVehicle(random.Next(100, 300), random.Next(1000, 3000), GetColor(random)); break; case nameof(DrawningEntityFighter): - //TODO Выбор цветов - drawningTrackedVehicle = new DrawningEntityFighter(random.Next(100, 300), random.Next(1000, 3000), - GetColor(random), - GetColor(random), - Convert.ToBoolean(random.Next(0, 2)), Convert.ToBoolean(random.Next(0, 2))); + // вызов диалогового окна для выбора цвета + drawingTrans = new DrawningEntityFighter(random.Next(100, 300), random.Next(1000, 3000), + GetColor(random), + GetColor(random), + Convert.ToBoolean(random.Next(0, 2)), Convert.ToBoolean(random.Next(0, 2))); break; default: return; - } - if (_company + drawningTrackedVehicle != -1) + + if (_company + drawingTrans != -1) { MessageBox.Show("Объект добавлен"); pictureBox.Image = _company.Show(); } else { - MessageBox.Show("Не удалось добавить объект"); + _ = MessageBox.Show(drawingTrans.ToString()); } - - - } + /// - /// Получение цвета - /// - /// Генератор случайных чисел - /// + /// Получение цвета + /// + /// Генератор случайных чисел + /// private static Color GetColor(Random random) { Color color = Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256)); @@ -103,6 +109,7 @@ public partial class FormTrackedVehicleCollection : Form { color = dialog.Color; } + return color; } @@ -111,20 +118,18 @@ public partial class FormTrackedVehicleCollection : Form /// /// /// - private void ButtonRemoveTrackedVehicle_Click(object sender, EventArgs e) + private void buttonCollectionDel_Click(object sender, EventArgs e) { - if (_company == null) - { - return; - } if (string.IsNullOrEmpty(maskedTextBox.Text) || _company == null) { return; } - if (MessageBox.Show("Удалить объект?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No) + + if (MessageBox.Show("Удалить объект?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes) { return; } + int pos = Convert.ToInt32(maskedTextBox.Text); if (_company - pos != null) { @@ -136,42 +141,43 @@ public partial class FormTrackedVehicleCollection : Form MessageBox.Show("Не удалось удалить объект"); } } + /// /// Передача объекта в другую форму /// /// /// - private void button1_Click(object sender, EventArgs e) { if (_company == null) { return; } - DrawningTrackedVehicle? fighter = null; + + DrawningTrackedVehicle? car = null; int counter = 100; - while (fighter == null) + while (car == null) { - fighter = _company.GetRandomObject(); + car = _company.GetRandomObject(); counter--; if (counter <= 0) { break; } } - if (fighter == null) + + if (car == null) { return; } + FormFighter form = new() { - SetTrackedVehicle = fighter + SetTrackedVehicle = car }; form.ShowDialog(); - } - /// /// Перерисовка коллекции /// @@ -183,41 +189,23 @@ public partial class FormTrackedVehicleCollection : Form { return; } + pictureBox.Image = _company.Show(); } - private void pictureBox1_Click(object sender, EventArgs e) - { - } - - private void maskedTextBox1_MaskInputRejected(object sender, MaskInputRejectedEventArgs e) - { - - } - - - - private void FormTrackedVehicleCollection_Load(object sender, EventArgs e) - { - - } - - private void radioButtonMassive_CheckedChanged(object sender, EventArgs e) - { - - } /// - /// Добавление коллекции - /// - /// - /// - private void buttonCollectionAdd_Click(object sender, EventArgs e) + /// Добавление коллекции + /// + /// + /// + private void buttonCollectionAdd_Click(object sender, EventArgs e) { if (string.IsNullOrEmpty(textBoxCollectionName.Text) || (!radioButtonList.Checked && !radioButtonMassive.Checked)) { MessageBox.Show("Не все данные заполнены", "Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error); return; } + CollectionType collectionType = CollectionType.None; if (radioButtonMassive.Checked) { @@ -230,46 +218,44 @@ public partial class FormTrackedVehicleCollection : Form _storageCollection.AddCollection(textBoxCollectionName.Text, collectionType); RerfreshListBoxItems(); - } + /// /// Удаление коллекции /// /// /// - private void buttonCollectionDel_Click(object sender, EventArgs e) + private void ButtonRemoveTrackedVehicle_Click(object sender, EventArgs e) { - // TODO прописать логику удаления элемента из коллекции - // нужно убедиться, что есть выбранная коллекция - // спросить у пользователя через MessageBox, что он подтверждает, что хочет удалить запись - // удалить и обновить ListBox if (listBoxCollection.SelectedIndex < 0 || listBoxCollection.SelectedItem == null) { MessageBox.Show("Коллекция не выбрана"); return; } - if (MessageBox.Show("Удалить объект?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes) + if (MessageBox.Show("Удалить коллекцию?", "Удаление", MessageBoxButtons.YesNo, MessageBoxIcon.Question) != DialogResult.Yes) { return; } _storageCollection.DelCollection(listBoxCollection.SelectedItem.ToString()); RerfreshListBoxItems(); } + /// /// Обновление списка в listBoxCollection /// private void RerfreshListBoxItems() { listBoxCollection.Items.Clear(); - for (int i = 0; i < _storageCollection.Keys?.Count; ++i) + foreach (var key in _storageCollection.Keys ?? Enumerable.Empty()) { - string? colName = _storageCollection.Keys?[i]; - if (!string.IsNullOrEmpty(colName)) + if (!string.IsNullOrEmpty(key)) { - listBoxCollection.Items.Add(colName); + listBoxCollection.Items.Add(key); } } + } + /// /// Создание компании /// @@ -282,21 +268,24 @@ public partial class FormTrackedVehicleCollection : Form MessageBox.Show("Коллекция не выбрана"); return; } - ICollectionGenericObjects? collection = _storageCollection[listBoxCollection.SelectedItem?.ToString() ?? string.Empty]; + + ICollectionGenericObjects? collection = _storageCollection[listBoxCollection.SelectedItem.ToString() ?? string.Empty]; if (collection == null) { MessageBox.Show("Коллекция не проинициализирована"); return; } + switch (comboBoxSelectorCompany.Text) { case "Хранилище": _company = new TrackedVehicleSharingService(pictureBox.Width, pictureBox.Height, collection); break; } + panelCompanyTools.Enabled = true; RerfreshListBoxItems(); - } -} + +} \ No newline at end of file