4 лаба без допов.

This commit is contained in:
MariaBelkina 2024-05-07 09:12:53 +04:00
parent c9ce2eac8c
commit dbcbcb24ea
8 changed files with 231 additions and 159 deletions

View File

@ -63,9 +63,9 @@ public abstract class AbstractCompany
/// <param name="company">Компания</param> /// <param name="company">Компания</param>
/// <param name="dozer">Добавляемый объект</param> /// <param name="dozer">Добавляемый объект</param>
/// <returns></returns> /// <returns></returns>
public static bool operator +(AbstractCompany company, DrawningDozer dozer) public static int operator +(AbstractCompany company, DrawningDozer dozer)
{ {
return company._collection?.Insert(dozer) ?? false; return company._collection.Insert(dozer);
} }
/// <summary> /// <summary>
@ -74,9 +74,9 @@ public abstract class AbstractCompany
/// <param name="company">Компания</param> /// <param name="company">Компания</param>
/// <param name="position">Номер удаляемого объекта</param> /// <param name="position">Номер удаляемого объекта</param>
/// <returns></returns> /// <returns></returns>
public static bool operator -(AbstractCompany company, int position) public static DrawningDozer? operator -(AbstractCompany company, int position)
{ {
return company._collection?.Remove(position) ?? false; return company._collection.Remove(position);
} }
/// <summary> /// <summary>
@ -100,7 +100,8 @@ public abstract class AbstractCompany
DrawBackground(graphics); DrawBackground(graphics);
SetObjectsPosition(); SetObjectsPosition();
for (int i = 0; i < (_collection?.Count ?? 0); i++) { for (int i = 0; i < (_collection?.Count ?? 0); ++i)
{
DrawningDozer? obj = _collection?.Get(i); DrawningDozer? obj = _collection?.Get(i);
obj?.DrawTransport(graphics); obj?.DrawTransport(graphics);
} }

View File

@ -31,8 +31,10 @@ public class Garage : AbstractCompany
{ {
int cntVertically = _pictureHeight / _placeSizeHeight; //Колличество мест по вертикали int cntVertically = _pictureHeight / _placeSizeHeight; //Колличество мест по вертикали
int cntHorizontally = _pictureWidth / _placeSizeWidth; //Колличество мест по горизонтали int cntHorizontally = _pictureWidth / _placeSizeWidth; //Колличество мест по горизонтали
Pen pen = new Pen(Color.FromArgb(185, 140, 0)); Pen pen = new(Color.FromArgb(185, 140, 0))
pen.Width = 3; {
Width = 3
};
for (int i = 0; i < cntHorizontally; i++) for (int i = 0; i < cntHorizontally; i++)
{ {
@ -78,7 +80,5 @@ public class Garage : AbstractCompany
placeVertically--; placeVertically--;
} }
} }
//throw new NotImplementedException();
} }
} }

View File

@ -28,7 +28,7 @@ public interface ICollectoinGenericObjects<T>
/// </summary> /// </summary>
/// <param name="obj">Добавляемый объект</param> /// <param name="obj">Добавляемый объект</param>
/// <returns>true - вставка прошла удачно, false - вставка не удалась</returns> /// <returns>true - вставка прошла удачно, false - вставка не удалась</returns>
bool Insert(T obj); int Insert(T obj);
/// <summary> /// <summary>
/// Добавление объекта в коллекцию на конкретную позицию /// Добавление объекта в коллекцию на конкретную позицию
@ -36,14 +36,14 @@ public interface ICollectoinGenericObjects<T>
/// <param name="obj">Добавляемый объект</param> /// <param name="obj">Добавляемый объект</param>
/// <param name="position">Позиция</param> /// <param name="position">Позиция</param>
/// <returns>true - вставка прошла удачно, false - вставка не удалась</returns> /// <returns>true - вставка прошла удачно, false - вставка не удалась</returns>
bool Insert(T obj, int position); int Insert(T obj, int position);
/// <summary> /// <summary>
/// Удаление объекта из коллекции на конкретной позиции /// Удаление объекта из коллекции на конкретной позиции
/// </summary> /// </summary>
/// <param name="position">Позиция</param> /// <param name="position">Позиция</param>
/// <returns></returns> /// <returns></returns>
bool Remove(int position); T? Remove(int position);
/// <summary> /// <summary>
/// Получение объекта по позиции /// Получение объекта по позиции

View File

@ -10,7 +10,8 @@ namespace ProjectBulldozer.CollectionGenericObjects;
/// Параметрезированный набор объектов /// Параметрезированный набор объектов
/// </summary> /// </summary>
/// <typeparam name="T">Параметр: ограничение - ссылочный тип</typeparam> /// <typeparam name="T">Параметр: ограничение - ссылочный тип</typeparam>
public class ListGenericObjects<T> :ICollectoinGenericObjects<T> where T : class public class ListGenericObjects<T> : ICollectoinGenericObjects<T>
where T : class
{ {
/// <summary> /// <summary>
/// Список объектов, которые храним /// Список объектов, которые храним
@ -36,29 +37,57 @@ public class ListGenericObjects<T> :ICollectoinGenericObjects<T> where T : class
public T? Get(int position) public T? Get(int position)
{ {
//TODO проверка позиции // Проверка позиции.
if (position < 0 || position >= _collection.Count || _collection == null || _collection.Count == 0)
{
return null;
}
return _collection[position]; return _collection[position];
} }
public bool Insert(T obj) public int Insert(T obj)
{ {
//TODO проверка, что не привышено максимальное колличество элементов // Проверка, что не привышено максимальное колличество элементов.
//TODO вставка в конец набора if (Count == _maxCount)
return true; {
return -1;
}
// Вставка в конец набора.
_collection.Add(obj);
return _collection.Count;
} }
public bool Insert(T obj, int position) public int Insert(T obj, int position)
{ {
//TODO проверка, что не превышено максимальное колличество элементов // Проверка, что не превышено максимальное колличество элементов.
//TODO проверка позиции if (Count == _maxCount)
//TODO вставка по позиции {
return true; return -1;
}
// Проверка позиции.
if (position < 0 || position >= _collection.Count || _collection == null || _collection.Count == 0) //TODO проверить, что если заменить _Collection.Count на Count
{
return -1;
}
// Вставка по позиции.
_collection.Insert(position, obj);
return position;
} }
public bool Remove(int position) public T? Remove(int position)
{ {
//TODO проверка позиции // Проверка позиции.
//TODO удаление объекта из спписка if (position < 0 || position >= _collection.Count || _collection == null || _collection.Count == 0)
return true; {
return null;
}
// Удаление объекта из списка.
T? obj = _collection[position];
_collection[position] = null;
return obj;
} }
} }

View File

@ -22,11 +22,14 @@ public class MassiveGenericObject<T> : ICollectoinGenericObjects<T>
{ {
if (value > 0) if (value > 0)
{ {
Array.Resize(ref _collection, value); if (_collection.Length > 0)
} {
else Array.Resize(ref _collection, value);
{ }
_collection =new T?[value]; else
{
_collection = new T[value];
}
} }
} }
} }
@ -52,7 +55,7 @@ public class MassiveGenericObject<T> : ICollectoinGenericObjects<T>
} }
} }
public bool Insert(T obj) public int Insert(T obj)
{ {
//Вставка в свободное место набора //Вставка в свободное место набора
for (int i = 0; i < Count; i++) for (int i = 0; i < Count; i++)
@ -60,19 +63,19 @@ public class MassiveGenericObject<T> : ICollectoinGenericObjects<T>
if (_collection[i] == null) if (_collection[i] == null)
{ {
_collection[i] = obj; _collection[i] = obj;
return true; return i;
} }
} }
return false; return -1;
} }
public bool Insert(T obj, int position) public int Insert(T obj, int position)
{ {
//Проверка позиции //Проверка позиции
if ((position < 0) || (position >= Count)) if ((position < 0) || (position >= Count))
{ {
return false; return -1;
} }
//Проверка, что элемент массива по этой позиции пустой, если нет, то ищется свободное место после этой //Проверка, что элемент массива по этой позиции пустой, если нет, то ищется свободное место после этой
@ -105,25 +108,26 @@ public class MassiveGenericObject<T> : ICollectoinGenericObjects<T>
if (placed == false) if (placed == false)
{ {
return false; return -1;
} }
} }
//Вставка //Вставка
_collection[position] = obj; _collection[position] = obj;
return true; return position;
} }
public bool Remove(int position) public T? Remove(int position)
{ {
//Проверка позиции //Проверка позиции
if ((position < 0) || (position >= Count) || (_collection[position] == null)) if ((position < 0) || (position >= Count) || (_collection[position] == null))
{ {
return false; return null;
} }
//Удаление объекта из массива, присвоив элементу массива значение null //Удаление объекта из массива, присвоив элементу массива значение null
T? elem = _collection[position];
_collection[position] = null; _collection[position] = null;
return true; return elem;
} }
} }

View File

@ -10,7 +10,8 @@ namespace ProjectBulldozer.CollectionGenericObjects;
/// Класс-хранилище коллекций /// Класс-хранилище коллекций
/// </summary> /// </summary>
/// <typeparam name="T"></typeparam> /// <typeparam name="T"></typeparam>
public class StorageCollection<T> where T : class public class StorageCollection<T>
where T : class
{ {
/// <summary> /// <summary>
/// Словарь (хранилище) с коллекциями /// Словарь (хранилище) с коллекциями
@ -37,8 +38,20 @@ public class StorageCollection<T> where T : class
/// <param name="collectionType">тип коллекции</param> /// <param name="collectionType">тип коллекции</param>
public void AddCollection(string name, CollectionType collectionType) public void AddCollection(string name, CollectionType collectionType)
{ {
// TODO проверка, что name не пустой и нет в словаре записи с таким ключом // Проверка, что name не пустой и нет в словаре записи с таким ключом.
// TODO прописать логику для добавления if (_storages.ContainsKey(name) && name == "")
{
return;
}
// Логика для добавления.
if (collectionType == CollectionType.Massive)
{
_storages[name] = new MassiveGenericObject<T>();
}
else
{
_storages[name] = new ListGenericObjects<T>();
}
} }
/// <summary> /// <summary>
@ -47,7 +60,11 @@ public class StorageCollection<T> where T : class
/// <param name="name">Название коллекции</param> /// <param name="name">Название коллекции</param>
public void DelCollection(string name) public void DelCollection(string name)
{ {
// TODO Прописать логику для удаления коллекции // Логика для удаления коллекции.
if (_storages.ContainsKey(name))
{
_storages.Remove(name);
}
} }
/// <summary> /// <summary>
@ -59,7 +76,11 @@ public class StorageCollection<T> where T : class
{ {
get get
{ {
// TODO Продумать логику получения объекта // Логика получения объекта.
if (_storages.ContainsKey(name))
{
return _storages[name];
}
return null; return null;
} }
} }

View File

@ -29,6 +29,13 @@
private void InitializeComponent() private void InitializeComponent()
{ {
groupBoxTools = new GroupBox(); groupBoxTools = new GroupBox();
panelCompanyTools = new Panel();
buttonAddDozer = new Button();
buttonAddBulldozer = new Button();
buttonDelBulldozer = new Button();
maskedTextBox = new MaskedTextBox();
buttonGoToCheck = new Button();
buttonRefresh = new Button();
panelStorage = new Panel(); panelStorage = new Panel();
listBoxCollection = new ListBox(); listBoxCollection = new ListBox();
buttonCollectionDel = new Button(); buttonCollectionDel = new Button();
@ -38,19 +45,12 @@
textBoxCollectionName = new TextBox(); textBoxCollectionName = new TextBox();
labelCollectionName = new Label(); labelCollectionName = new Label();
buttonCreateCompany = new Button(); buttonCreateCompany = new Button();
maskedTextBox = new MaskedTextBox();
buttonRefresh = new Button();
buttonGoToCheck = new Button();
buttonDelBulldozer = new Button();
buttonAddBulldozer = new Button();
buttonAddDozer = new Button();
comboBoxSelectorCompany = new ComboBox(); comboBoxSelectorCompany = new ComboBox();
pictureBox = new PictureBox(); pictureBox = new PictureBox();
panelCompanyTools = new Panel();
groupBoxTools.SuspendLayout(); groupBoxTools.SuspendLayout();
panelCompanyTools.SuspendLayout();
panelStorage.SuspendLayout(); panelStorage.SuspendLayout();
((System.ComponentModel.ISupportInitialize)pictureBox).BeginInit(); ((System.ComponentModel.ISupportInitialize)pictureBox).BeginInit();
panelCompanyTools.SuspendLayout();
SuspendLayout(); SuspendLayout();
// //
// groupBoxTools // groupBoxTools
@ -68,6 +68,89 @@
groupBoxTools.TabStop = false; groupBoxTools.TabStop = false;
groupBoxTools.Text = "Инструменты"; groupBoxTools.Text = "Инструменты";
// //
// panelCompanyTools
//
panelCompanyTools.Controls.Add(buttonAddDozer);
panelCompanyTools.Controls.Add(buttonAddBulldozer);
panelCompanyTools.Controls.Add(buttonDelBulldozer);
panelCompanyTools.Controls.Add(maskedTextBox);
panelCompanyTools.Controls.Add(buttonGoToCheck);
panelCompanyTools.Controls.Add(buttonRefresh);
panelCompanyTools.Enabled = false;
panelCompanyTools.Location = new Point(3, 624);
panelCompanyTools.Name = "panelCompanyTools";
panelCompanyTools.Size = new Size(400, 449);
panelCompanyTools.TabIndex = 7;
//
// buttonAddDozer
//
buttonAddDozer.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonAddDozer.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonAddDozer.Location = new Point(11, 14);
buttonAddDozer.Name = "buttonAddDozer";
buttonAddDozer.Size = new Size(332, 64);
buttonAddDozer.TabIndex = 2;
buttonAddDozer.Text = "Добавление бульдозера";
buttonAddDozer.UseVisualStyleBackColor = true;
buttonAddDozer.Click += ButtonAddDozer_Click;
//
// buttonAddBulldozer
//
buttonAddBulldozer.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonAddBulldozer.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonAddBulldozer.Location = new Point(11, 84);
buttonAddBulldozer.Name = "buttonAddBulldozer";
buttonAddBulldozer.Size = new Size(332, 79);
buttonAddBulldozer.TabIndex = 3;
buttonAddBulldozer.Text = "Добавление крутого бульдозера";
buttonAddBulldozer.UseVisualStyleBackColor = true;
buttonAddBulldozer.Click += ButtonAddBulldozer_Click;
//
// buttonDelBulldozer
//
buttonDelBulldozer.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonDelBulldozer.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonDelBulldozer.Location = new Point(11, 216);
buttonDelBulldozer.Name = "buttonDelBulldozer";
buttonDelBulldozer.Size = new Size(332, 63);
buttonDelBulldozer.TabIndex = 3;
buttonDelBulldozer.Text = "Удаленить бульдозер";
buttonDelBulldozer.UseVisualStyleBackColor = true;
buttonDelBulldozer.Click += ButtonDelBulldozer_Click;
//
// maskedTextBox
//
maskedTextBox.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
maskedTextBox.Location = new Point(11, 169);
maskedTextBox.Name = "maskedTextBox";
maskedTextBox.Size = new Size(332, 41);
maskedTextBox.TabIndex = 5;
maskedTextBox.ValidatingType = typeof(int);
//
// buttonGoToCheck
//
buttonGoToCheck.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonGoToCheck.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonGoToCheck.Location = new Point(11, 285);
buttonGoToCheck.Name = "buttonGoToCheck";
buttonGoToCheck.Size = new Size(332, 63);
buttonGoToCheck.TabIndex = 3;
buttonGoToCheck.Text = "Передать на тесты";
buttonGoToCheck.UseVisualStyleBackColor = true;
buttonGoToCheck.Click += ButtonGoToCheck_Click;
//
// buttonRefresh
//
buttonRefresh.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonRefresh.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonRefresh.Location = new Point(11, 354);
buttonRefresh.Name = "buttonRefresh";
buttonRefresh.Size = new Size(332, 63);
buttonRefresh.TabIndex = 3;
buttonRefresh.Text = "Обновить";
buttonRefresh.UseVisualStyleBackColor = true;
buttonRefresh.Click += ButtonRefresh_Click;
//
// panelStorage // panelStorage
// //
panelStorage.Controls.Add(listBoxCollection); panelStorage.Controls.Add(listBoxCollection);
@ -140,7 +223,6 @@
textBoxCollectionName.Name = "textBoxCollectionName"; textBoxCollectionName.Name = "textBoxCollectionName";
textBoxCollectionName.Size = new Size(332, 41); textBoxCollectionName.Size = new Size(332, 41);
textBoxCollectionName.TabIndex = 1; textBoxCollectionName.TabIndex = 1;
textBoxCollectionName.Text = " ";
// //
// labelCollectionName // labelCollectionName
// //
@ -161,75 +243,6 @@
buttonCreateCompany.UseVisualStyleBackColor = true; buttonCreateCompany.UseVisualStyleBackColor = true;
buttonCreateCompany.Click += ButtonCreateCompany_Click; buttonCreateCompany.Click += ButtonCreateCompany_Click;
// //
// maskedTextBox
//
maskedTextBox.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
maskedTextBox.Location = new Point(11, 169);
maskedTextBox.Name = "maskedTextBox";
maskedTextBox.Size = new Size(332, 41);
maskedTextBox.TabIndex = 5;
maskedTextBox.ValidatingType = typeof(int);
//
// buttonRefresh
//
buttonRefresh.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonRefresh.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonRefresh.Location = new Point(11, 354);
buttonRefresh.Name = "buttonRefresh";
buttonRefresh.Size = new Size(332, 63);
buttonRefresh.TabIndex = 3;
buttonRefresh.Text = "Обновить";
buttonRefresh.UseVisualStyleBackColor = true;
buttonRefresh.Click += ButtonRefresh_Click;
//
// buttonGoToCheck
//
buttonGoToCheck.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonGoToCheck.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonGoToCheck.Location = new Point(11, 285);
buttonGoToCheck.Name = "buttonGoToCheck";
buttonGoToCheck.Size = new Size(332, 63);
buttonGoToCheck.TabIndex = 3;
buttonGoToCheck.Text = "Передать на тесты";
buttonGoToCheck.UseVisualStyleBackColor = true;
buttonGoToCheck.Click += ButtonGoToCheck_Click;
//
// buttonDelBulldozer
//
buttonDelBulldozer.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonDelBulldozer.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonDelBulldozer.Location = new Point(11, 216);
buttonDelBulldozer.Name = "buttonDelBulldozer";
buttonDelBulldozer.Size = new Size(332, 63);
buttonDelBulldozer.TabIndex = 3;
buttonDelBulldozer.Text = "Удаленить бульдозер";
buttonDelBulldozer.UseVisualStyleBackColor = true;
buttonDelBulldozer.Click += ButtonDelBulldozer_Click;
//
// buttonAddBulldozer
//
buttonAddBulldozer.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonAddBulldozer.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonAddBulldozer.Location = new Point(11, 84);
buttonAddBulldozer.Name = "buttonAddBulldozer";
buttonAddBulldozer.Size = new Size(332, 79);
buttonAddBulldozer.TabIndex = 3;
buttonAddBulldozer.Text = "Добавление крутого бульдозера";
buttonAddBulldozer.UseVisualStyleBackColor = true;
buttonAddBulldozer.Click += ButtonAddBulldozer_Click;
//
// buttonAddDozer
//
buttonAddDozer.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
buttonAddDozer.Font = new Font("Comic Sans MS", 9F, FontStyle.Regular, GraphicsUnit.Point);
buttonAddDozer.Location = new Point(11, 14);
buttonAddDozer.Name = "buttonAddDozer";
buttonAddDozer.Size = new Size(332, 64);
buttonAddDozer.TabIndex = 2;
buttonAddDozer.Text = "Добавление бульдозера";
buttonAddDozer.UseVisualStyleBackColor = true;
buttonAddDozer.Click += ButtonAddDozer_Click;
//
// comboBoxSelectorCompany // comboBoxSelectorCompany
// //
comboBoxSelectorCompany.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right; comboBoxSelectorCompany.Anchor = AnchorStyles.Bottom | AnchorStyles.Left | AnchorStyles.Right;
@ -241,7 +254,7 @@
comboBoxSelectorCompany.Name = "comboBoxSelectorCompany"; comboBoxSelectorCompany.Name = "comboBoxSelectorCompany";
comboBoxSelectorCompany.Size = new Size(332, 41); comboBoxSelectorCompany.Size = new Size(332, 41);
comboBoxSelectorCompany.TabIndex = 1; comboBoxSelectorCompany.TabIndex = 1;
comboBoxSelectorCompany.SelectedIndexChanged += comboBoxSelectorCompany_SelectedIndexChanged; comboBoxSelectorCompany.SelectedIndexChanged += ComboBoxSelectorCompany_SelectedIndexChanged;
// //
// pictureBox // pictureBox
// //
@ -252,20 +265,6 @@
pictureBox.TabIndex = 4; pictureBox.TabIndex = 4;
pictureBox.TabStop = false; pictureBox.TabStop = false;
// //
// panelCompanyTools
//
panelCompanyTools.Controls.Add(buttonAddDozer);
panelCompanyTools.Controls.Add(buttonAddBulldozer);
panelCompanyTools.Controls.Add(buttonDelBulldozer);
panelCompanyTools.Controls.Add(maskedTextBox);
panelCompanyTools.Controls.Add(buttonGoToCheck);
panelCompanyTools.Controls.Add(buttonRefresh);
panelCompanyTools.Enabled = false;
panelCompanyTools.Location = new Point(3, 624);
panelCompanyTools.Name = "panelCompanyTools";
panelCompanyTools.Size = new Size(400, 449);
panelCompanyTools.TabIndex = 7;
//
// FormBulldozerCollection // FormBulldozerCollection
// //
AutoScaleDimensions = new SizeF(13F, 32F); AutoScaleDimensions = new SizeF(13F, 32F);
@ -276,11 +275,11 @@
Name = "FormBulldozerCollection"; Name = "FormBulldozerCollection";
Text = "Коллекция бульдозеров"; Text = "Коллекция бульдозеров";
groupBoxTools.ResumeLayout(false); groupBoxTools.ResumeLayout(false);
panelCompanyTools.ResumeLayout(false);
panelCompanyTools.PerformLayout();
panelStorage.ResumeLayout(false); panelStorage.ResumeLayout(false);
panelStorage.PerformLayout(); panelStorage.PerformLayout();
((System.ComponentModel.ISupportInitialize)pictureBox).EndInit(); ((System.ComponentModel.ISupportInitialize)pictureBox).EndInit();
panelCompanyTools.ResumeLayout(false);
panelCompanyTools.PerformLayout();
ResumeLayout(false); ResumeLayout(false);
} }

View File

@ -18,7 +18,9 @@ namespace ProjectBulldozer;
/// </summary> /// </summary>
public partial class FormBulldozerCollection : Form public partial class FormBulldozerCollection : Form
{ {
/// <summary>
/// Хранилище коллекций
/// </summary>
private readonly StorageCollection<DrawningDozer> _storageCollection; private readonly StorageCollection<DrawningDozer> _storageCollection;
/// <summary> /// <summary>
@ -40,7 +42,7 @@ public partial class FormBulldozerCollection : Form
/// </summary> /// </summary>
/// <param name="sender"></param> /// <param name="sender"></param>
/// <param name="e"></param> /// <param name="e"></param>
private void comboBoxSelectorCompany_SelectedIndexChanged(object sender, EventArgs e) private void ComboBoxSelectorCompany_SelectedIndexChanged(object sender, EventArgs e)
{ {
panelCompanyTools.Enabled = false; panelCompanyTools.Enabled = false;
@ -91,7 +93,7 @@ public partial class FormBulldozerCollection : Form
return; return;
} }
if (_company + drawningDozer) if (_company + drawningDozer != -1)
{ {
MessageBox.Show("Объект добавлен."); MessageBox.Show("Объект добавлен.");
pictureBox.Image = _company.Show(); pictureBox.Image = _company.Show();
@ -152,7 +154,7 @@ public partial class FormBulldozerCollection : Form
} }
int pos = Convert.ToInt32(maskedTextBox.Text); int pos = Convert.ToInt32(maskedTextBox.Text);
if (_company - pos) if (_company - pos != null)
{ {
MessageBox.Show("Объект удалён."); MessageBox.Show("Объект удалён.");
pictureBox.Image = _company.Show(); pictureBox.Image = _company.Show();
@ -241,6 +243,11 @@ public partial class FormBulldozerCollection : Form
RefreshListBoxItems(); RefreshListBoxItems();
} }
/*private ListBox GetListBoxCollection()
{
return listBoxCollection;
}*/
/// <summary> /// <summary>
/// Удаление коллекции /// Удаление коллекции
/// </summary> /// </summary>
@ -250,20 +257,30 @@ public partial class FormBulldozerCollection : Form
{ {
// Прописать логику удаления элемента из коллекции. // Прописать логику удаления элемента из коллекции.
// Нужно убедиться, что есть выбранная коллекция // Нужно убедиться, что есть выбранная коллекция
if (listBoxCollection.SelectedIndex < 0 || listBoxCollection.SelectedItem == null) if (listBoxCollection.SelectedItem == null || listBoxCollection.SelectedIndex < 0)
{ {
MessageBox.Show("Коллекция не выбрана!"); MessageBox.Show("Коллекция не выбрана!");
return; return;
} }
else
// Спросить у пользователя через MessageBox, что он подтверждает, что хочет удалить запись
if (MessageBox.Show("Удалить коллекцию?", "Удаление...", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No)
{ {
MessageBox.Show("Коллукция не выбрана!"); // Спросить у пользователя через MessageBox, что он подтверждает, что хочет удалить запись
return; if (MessageBox.Show("Удалить коллекцию?", "Удаление...", MessageBoxButtons.YesNo, MessageBoxIcon.Question) == DialogResult.No)
{
MessageBox.Show("Коллекция не выбрана!");
return;
}
else
{
// Удалить и обновить ListBox
_storageCollection.DelCollection(listBoxCollection.SelectedItem.ToString());
RefreshListBoxItems();
}
} }
// Удалить и обновить ListBox
}
}
/// <summary> /// <summary>
/// Обновление списка в ListBoxCollection /// Обновление списка в ListBoxCollection
@ -271,7 +288,7 @@ public partial class FormBulldozerCollection : Form
private void RefreshListBoxItems() private void RefreshListBoxItems()
{ {
listBoxCollection.Items.Clear(); listBoxCollection.Items.Clear();
for (int i = 0; i < _storageCollection.Keys?.Count; i++) for (int i = 0; i < _storageCollection.Keys?.Count; ++i)
{ {
string? colName = _storageCollection.Keys?[i]; string? colName = _storageCollection.Keys?[i];
if (!string.IsNullOrEmpty(colName)) if (!string.IsNullOrEmpty(colName))
@ -288,14 +305,14 @@ public partial class FormBulldozerCollection : Form
/// <param name="e"></param> /// <param name="e"></param>
private void ButtonCreateCompany_Click(object sender, EventArgs e) private void ButtonCreateCompany_Click(object sender, EventArgs e)
{ {
if (listBoxCollection.SelectedIndex < 0) if (listBoxCollection.SelectedIndex < 0 || listBoxCollection.SelectedItem == null)
{ {
MessageBox.Show("Коллекция не выбрана!"); MessageBox.Show("Коллекция не выбрана!");
return; return;
} }
ICollectoinGenericObjects<DrawningDozer>? collectoin = _storageCollection[listBoxCollection.SelectedItem.ToString() ?? string.Empty]; ICollectoinGenericObjects<DrawningDozer>? collection = _storageCollection[listBoxCollection.SelectedItem.ToString() ?? string.Empty];
if (collectoin == null) if (collection == null)
{ {
MessageBox.Show("Коллекция не проинициализирована!"); MessageBox.Show("Коллекция не проинициализирована!");
return; return;
@ -304,10 +321,11 @@ public partial class FormBulldozerCollection : Form
switch (comboBoxSelectorCompany.Text) switch (comboBoxSelectorCompany.Text)
{ {
case "Хранилище": case "Хранилище":
_company = new Garage(pictureBox.Width, pictureBox.Height, new MassiveGenericObject<DrawningDozer>()); _company = new Garage(pictureBox.Width, pictureBox.Height, collection);
break; break;
} }
panelCompanyTools.Enabled = true; panelCompanyTools.Enabled = true;
RefreshListBoxItems();
} }
} }