4 лаба без допов.
This commit is contained in:
parent
c9ce2eac8c
commit
dbcbcb24ea
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
/// Получение объекта по позиции
|
/// Получение объекта по позиции
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user