Готовая 8 лабораторная
This commit is contained in:
parent
bcc99e559f
commit
3957e5ba4f
59
RoadTrain/DrawiningTrainEqutables.cs
Normal file
59
RoadTrain/DrawiningTrainEqutables.cs
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using RoadTrain.DrawningObjects;
|
||||||
|
using RoadTrain.Entities;
|
||||||
|
using System.Diagnostics.CodeAnalysis;
|
||||||
|
|
||||||
|
namespace RoadTrain.Generics
|
||||||
|
{
|
||||||
|
internal class DrawiningTrainEqutables : IEqualityComparer<DrawningRoadTrain?>
|
||||||
|
{
|
||||||
|
public bool Equals(DrawningRoadTrain? x, DrawningRoadTrain? y)
|
||||||
|
{
|
||||||
|
if (x == null || x.EntityRoadTrain == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(nameof(x));
|
||||||
|
}
|
||||||
|
if (y == null || y.EntityRoadTrain == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(nameof(y));
|
||||||
|
}
|
||||||
|
if (x.GetType().Name != y.GetType().Name)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (x.EntityRoadTrain.Speed != y.EntityRoadTrain.Speed)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (x.EntityRoadTrain.Weight != y.EntityRoadTrain.Weight)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (x.EntityRoadTrain.BodyColor != y.EntityRoadTrain.BodyColor)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (x is DrawningTrain && y is DrawningTrain)
|
||||||
|
{
|
||||||
|
EntityTrain EntityX = x.EntityRoadTrain as EntityTrain;
|
||||||
|
EntityTrain EntityY = y.EntityRoadTrain as EntityTrain;
|
||||||
|
if (EntityX.WaterContainer != EntityY.WaterContainer)
|
||||||
|
return false;
|
||||||
|
if (EntityX.SweepingBrush != EntityY.SweepingBrush)
|
||||||
|
return false;
|
||||||
|
if (EntityX.AdditionalColor != EntityY.AdditionalColor)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
public int GetHashCode([DisallowNull] DrawningRoadTrain obj)
|
||||||
|
{
|
||||||
|
return obj.GetHashCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
46
RoadTrain/FormTrainCollection.Designer.cs
generated
46
RoadTrain/FormTrainCollection.Designer.cs
generated
@ -29,6 +29,8 @@
|
|||||||
private void InitializeComponent()
|
private void InitializeComponent()
|
||||||
{
|
{
|
||||||
panel1 = new Panel();
|
panel1 = new Panel();
|
||||||
|
ButtonSortByColor = new Button();
|
||||||
|
ButtonSortByType = new Button();
|
||||||
label2 = new Label();
|
label2 = new Label();
|
||||||
panel2 = new Panel();
|
panel2 = new Panel();
|
||||||
textBoxStorageName = new TextBox();
|
textBoxStorageName = new TextBox();
|
||||||
@ -56,6 +58,8 @@
|
|||||||
//
|
//
|
||||||
// panel1
|
// panel1
|
||||||
//
|
//
|
||||||
|
panel1.Controls.Add(ButtonSortByColor);
|
||||||
|
panel1.Controls.Add(ButtonSortByType);
|
||||||
panel1.Controls.Add(label2);
|
panel1.Controls.Add(label2);
|
||||||
panel1.Controls.Add(panel2);
|
panel1.Controls.Add(panel2);
|
||||||
panel1.Controls.Add(InputTextBox);
|
panel1.Controls.Add(InputTextBox);
|
||||||
@ -69,6 +73,26 @@
|
|||||||
panel1.Size = new Size(236, 572);
|
panel1.Size = new Size(236, 572);
|
||||||
panel1.TabIndex = 0;
|
panel1.TabIndex = 0;
|
||||||
//
|
//
|
||||||
|
// ButtonSortByColor
|
||||||
|
//
|
||||||
|
ButtonSortByColor.Location = new Point(32, 305);
|
||||||
|
ButtonSortByColor.Name = "ButtonSortByColor";
|
||||||
|
ButtonSortByColor.Size = new Size(169, 32);
|
||||||
|
ButtonSortByColor.TabIndex = 7;
|
||||||
|
ButtonSortByColor.Text = "Сортировка по цвету";
|
||||||
|
ButtonSortByColor.UseVisualStyleBackColor = true;
|
||||||
|
ButtonSortByColor.Click += ButtonSortByColor_Click;
|
||||||
|
//
|
||||||
|
// ButtonSortByType
|
||||||
|
//
|
||||||
|
ButtonSortByType.Location = new Point(35, 257);
|
||||||
|
ButtonSortByType.Name = "ButtonSortByType";
|
||||||
|
ButtonSortByType.Size = new Size(163, 31);
|
||||||
|
ButtonSortByType.TabIndex = 6;
|
||||||
|
ButtonSortByType.Text = "Сортировка по типу";
|
||||||
|
ButtonSortByType.UseVisualStyleBackColor = true;
|
||||||
|
ButtonSortByType.Click += ButtonSortByType_Click;
|
||||||
|
//
|
||||||
// label2
|
// label2
|
||||||
//
|
//
|
||||||
label2.AutoSize = true;
|
label2.AutoSize = true;
|
||||||
@ -86,19 +110,19 @@
|
|||||||
panel2.Controls.Add(listBoxStorages);
|
panel2.Controls.Add(listBoxStorages);
|
||||||
panel2.Location = new Point(24, 29);
|
panel2.Location = new Point(24, 29);
|
||||||
panel2.Name = "panel2";
|
panel2.Name = "panel2";
|
||||||
panel2.Size = new Size(190, 278);
|
panel2.Size = new Size(190, 212);
|
||||||
panel2.TabIndex = 5;
|
panel2.TabIndex = 5;
|
||||||
//
|
//
|
||||||
// textBoxStorageName
|
// textBoxStorageName
|
||||||
//
|
//
|
||||||
textBoxStorageName.Location = new Point(21, 30);
|
textBoxStorageName.Location = new Point(21, 21);
|
||||||
textBoxStorageName.Name = "textBoxStorageName";
|
textBoxStorageName.Name = "textBoxStorageName";
|
||||||
textBoxStorageName.Size = new Size(150, 27);
|
textBoxStorageName.Size = new Size(150, 27);
|
||||||
textBoxStorageName.TabIndex = 3;
|
textBoxStorageName.TabIndex = 3;
|
||||||
//
|
//
|
||||||
// ButtonDelObject
|
// ButtonDelObject
|
||||||
//
|
//
|
||||||
ButtonDelObject.Location = new Point(21, 179);
|
ButtonDelObject.Location = new Point(21, 170);
|
||||||
ButtonDelObject.Name = "ButtonDelObject";
|
ButtonDelObject.Name = "ButtonDelObject";
|
||||||
ButtonDelObject.Size = new Size(150, 29);
|
ButtonDelObject.Size = new Size(150, 29);
|
||||||
ButtonDelObject.TabIndex = 2;
|
ButtonDelObject.TabIndex = 2;
|
||||||
@ -108,7 +132,7 @@
|
|||||||
//
|
//
|
||||||
// ButtonAddObject
|
// ButtonAddObject
|
||||||
//
|
//
|
||||||
ButtonAddObject.Location = new Point(21, 77);
|
ButtonAddObject.Location = new Point(21, 66);
|
||||||
ButtonAddObject.Name = "ButtonAddObject";
|
ButtonAddObject.Name = "ButtonAddObject";
|
||||||
ButtonAddObject.Size = new Size(150, 29);
|
ButtonAddObject.Size = new Size(150, 29);
|
||||||
ButtonAddObject.TabIndex = 1;
|
ButtonAddObject.TabIndex = 1;
|
||||||
@ -120,7 +144,7 @@
|
|||||||
//
|
//
|
||||||
listBoxStorages.FormattingEnabled = true;
|
listBoxStorages.FormattingEnabled = true;
|
||||||
listBoxStorages.ItemHeight = 20;
|
listBoxStorages.ItemHeight = 20;
|
||||||
listBoxStorages.Location = new Point(21, 121);
|
listBoxStorages.Location = new Point(21, 110);
|
||||||
listBoxStorages.Name = "listBoxStorages";
|
listBoxStorages.Name = "listBoxStorages";
|
||||||
listBoxStorages.Size = new Size(150, 44);
|
listBoxStorages.Size = new Size(150, 44);
|
||||||
listBoxStorages.TabIndex = 0;
|
listBoxStorages.TabIndex = 0;
|
||||||
@ -128,7 +152,7 @@
|
|||||||
//
|
//
|
||||||
// InputTextBox
|
// InputTextBox
|
||||||
//
|
//
|
||||||
InputTextBox.Location = new Point(59, 384);
|
InputTextBox.Location = new Point(58, 407);
|
||||||
InputTextBox.Margin = new Padding(3, 4, 3, 4);
|
InputTextBox.Margin = new Padding(3, 4, 3, 4);
|
||||||
InputTextBox.Name = "InputTextBox";
|
InputTextBox.Name = "InputTextBox";
|
||||||
InputTextBox.Size = new Size(114, 27);
|
InputTextBox.Size = new Size(114, 27);
|
||||||
@ -136,7 +160,7 @@
|
|||||||
//
|
//
|
||||||
// ButtonRefreshCollection
|
// ButtonRefreshCollection
|
||||||
//
|
//
|
||||||
ButtonRefreshCollection.Location = new Point(45, 485);
|
ButtonRefreshCollection.Location = new Point(43, 499);
|
||||||
ButtonRefreshCollection.Margin = new Padding(3, 4, 3, 4);
|
ButtonRefreshCollection.Margin = new Padding(3, 4, 3, 4);
|
||||||
ButtonRefreshCollection.Name = "ButtonRefreshCollection";
|
ButtonRefreshCollection.Name = "ButtonRefreshCollection";
|
||||||
ButtonRefreshCollection.Size = new Size(144, 59);
|
ButtonRefreshCollection.Size = new Size(144, 59);
|
||||||
@ -147,7 +171,7 @@
|
|||||||
//
|
//
|
||||||
// ButtonRemoveTrain
|
// ButtonRemoveTrain
|
||||||
//
|
//
|
||||||
ButtonRemoveTrain.Location = new Point(45, 428);
|
ButtonRemoveTrain.Location = new Point(43, 442);
|
||||||
ButtonRemoveTrain.Margin = new Padding(3, 4, 3, 4);
|
ButtonRemoveTrain.Margin = new Padding(3, 4, 3, 4);
|
||||||
ButtonRemoveTrain.Name = "ButtonRemoveTrain";
|
ButtonRemoveTrain.Name = "ButtonRemoveTrain";
|
||||||
ButtonRemoveTrain.Size = new Size(144, 40);
|
ButtonRemoveTrain.Size = new Size(144, 40);
|
||||||
@ -158,10 +182,10 @@
|
|||||||
//
|
//
|
||||||
// ButtonAddTrain
|
// ButtonAddTrain
|
||||||
//
|
//
|
||||||
ButtonAddTrain.Location = new Point(45, 322);
|
ButtonAddTrain.Location = new Point(44, 355);
|
||||||
ButtonAddTrain.Margin = new Padding(3, 4, 3, 4);
|
ButtonAddTrain.Margin = new Padding(3, 4, 3, 4);
|
||||||
ButtonAddTrain.Name = "ButtonAddTrain";
|
ButtonAddTrain.Name = "ButtonAddTrain";
|
||||||
ButtonAddTrain.Size = new Size(144, 44);
|
ButtonAddTrain.Size = new Size(142, 44);
|
||||||
ButtonAddTrain.TabIndex = 1;
|
ButtonAddTrain.TabIndex = 1;
|
||||||
ButtonAddTrain.Text = "Добавить поезд";
|
ButtonAddTrain.Text = "Добавить поезд";
|
||||||
ButtonAddTrain.UseVisualStyleBackColor = true;
|
ButtonAddTrain.UseVisualStyleBackColor = true;
|
||||||
@ -279,5 +303,7 @@
|
|||||||
private ToolStripMenuItem SaveToolStripMenuItem;
|
private ToolStripMenuItem SaveToolStripMenuItem;
|
||||||
private OpenFileDialog openFileDialog;
|
private OpenFileDialog openFileDialog;
|
||||||
private SaveFileDialog saveFileDialog;
|
private SaveFileDialog saveFileDialog;
|
||||||
|
private Button ButtonSortByColor;
|
||||||
|
private Button ButtonSortByType;
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -35,7 +35,7 @@ pictureBoxCollection.Height);
|
|||||||
listBoxStorages.Items.Clear();
|
listBoxStorages.Items.Clear();
|
||||||
for (int i = 0; i < _storage.Keys.Count; i++)
|
for (int i = 0; i < _storage.Keys.Count; i++)
|
||||||
{
|
{
|
||||||
listBoxStorages.Items.Add(_storage.Keys[i]);
|
listBoxStorages.Items.Add(_storage.Keys[i].Name);
|
||||||
}
|
}
|
||||||
if (listBoxStorages.Items.Count > 0 && (index == -1 || index
|
if (listBoxStorages.Items.Count > 0 && (index == -1 || index
|
||||||
>= listBoxStorages.Items.Count))
|
>= listBoxStorages.Items.Count))
|
||||||
@ -73,6 +73,11 @@ pictureBoxCollection.Height);
|
|||||||
MessageBox.Show(ex.Message);
|
MessageBox.Show(ex.Message);
|
||||||
_logger.LogWarning($"Обьект не добавлен в набор {listBoxStorages.SelectedItem.ToString()}");
|
_logger.LogWarning($"Обьект не добавлен в набор {listBoxStorages.SelectedItem.ToString()}");
|
||||||
}
|
}
|
||||||
|
catch (ArgumentException ex)
|
||||||
|
{
|
||||||
|
MessageBox.Show(ex.Message);
|
||||||
|
_logger.LogWarning($"Обьект не добавлен в набор {listBoxStorages.SelectedItem.ToString()}");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
private void ButtonAddTrain_Click(object sender, EventArgs e)
|
private void ButtonAddTrain_Click(object sender, EventArgs e)
|
||||||
{
|
{
|
||||||
@ -210,5 +215,32 @@ _storage[listBoxStorages.SelectedItem?.ToString() ?? string.Empty]?.ShowTrains()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void ButtonSortByType_Click(object sender, EventArgs e) =>
|
||||||
|
CompareTrains(new TrainCompareByType());
|
||||||
|
|
||||||
|
private void ButtonSortByColor_Click(object sender, EventArgs e) =>
|
||||||
|
CompareTrains(new TrainCompareByColor());
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Сортировка по сравнителю
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="comparer"></param>
|
||||||
|
private void CompareTrains(IComparer<DrawningRoadTrain?> comparer)
|
||||||
|
{
|
||||||
|
if (listBoxStorages.SelectedIndex == -1)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var obj = _storage[listBoxStorages.SelectedItem.ToString() ??
|
||||||
|
string.Empty];
|
||||||
|
if (obj == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
obj.Sort(comparer);
|
||||||
|
pictureBoxCollection.Image = obj.ShowTrains();
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -47,6 +47,12 @@ namespace RoadTrain.Generics
|
|||||||
_collection = new SetGeneric<T>(width * height);
|
_collection = new SetGeneric<T>(width * height);
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
|
/// Сортировка
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="comparer"></param>
|
||||||
|
public void Sort(IComparer<T?> comparer) =>
|
||||||
|
_collection.SortSet(comparer);
|
||||||
|
/// <summary>
|
||||||
/// Получение объектов коллекции
|
/// Получение объектов коллекции
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public IEnumerable<T?> GetTrains => _collection.GetTrains();
|
public IEnumerable<T?> GetTrains => _collection.GetTrains();
|
||||||
@ -63,7 +69,7 @@ namespace RoadTrain.Generics
|
|||||||
{
|
{
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
return collect._collection.Insert(obj);
|
return collect._collection.Insert(obj, new DrawiningTrainEqutables());
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Перегрузка оператора вычитания
|
/// Перегрузка оператора вычитания
|
||||||
|
@ -18,12 +18,12 @@ namespace RoadTrain.Generics
|
|||||||
/// <summary>
|
/// <summary>
|
||||||
/// Словарь (хранилище)
|
/// Словарь (хранилище)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
readonly Dictionary<string, RoadTrainGenericCollection<DrawningRoadTrain,
|
readonly Dictionary<TrainsCollectionInfo, RoadTrainGenericCollection<DrawningRoadTrain,
|
||||||
DrawningObjectTrain>> _trainStorages;
|
DrawningObjectTrain>> _trainStorages;
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Возвращение списка названий наборов
|
/// Возвращение списка названий наборов
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public List<string> Keys => _trainStorages.Keys.ToList();
|
public List<TrainsCollectionInfo> Keys => _trainStorages.Keys.ToList();
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Ширина окна отрисовки
|
/// Ширина окна отрисовки
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -52,7 +52,7 @@ namespace RoadTrain.Generics
|
|||||||
/// <param name="pictureHeight"></param>
|
/// <param name="pictureHeight"></param>
|
||||||
public RoadTrainGenericStorage(int pictureWidth, int pictureHeight)
|
public RoadTrainGenericStorage(int pictureWidth, int pictureHeight)
|
||||||
{
|
{
|
||||||
_trainStorages = new Dictionary<string,
|
_trainStorages = new Dictionary<TrainsCollectionInfo,
|
||||||
RoadTrainGenericCollection<DrawningRoadTrain, DrawningObjectTrain>>();
|
RoadTrainGenericCollection<DrawningRoadTrain, DrawningObjectTrain>>();
|
||||||
_pictureWidth = pictureWidth;
|
_pictureWidth = pictureWidth;
|
||||||
_pictureHeight = pictureHeight;
|
_pictureHeight = pictureHeight;
|
||||||
@ -63,8 +63,8 @@ namespace RoadTrain.Generics
|
|||||||
/// <param name="name">Название набора</param>
|
/// <param name="name">Название набора</param>
|
||||||
public void AddSet(string name)
|
public void AddSet(string name)
|
||||||
{
|
{
|
||||||
if (_trainStorages.ContainsKey(name)) return;
|
if (_trainStorages.ContainsKey(new TrainsCollectionInfo(name, string.Empty))) return;
|
||||||
_trainStorages[name] = new RoadTrainGenericCollection<DrawningRoadTrain, DrawningObjectTrain>(_pictureWidth, _pictureHeight);
|
_trainStorages.Add(new TrainsCollectionInfo(name, string.Empty), new RoadTrainGenericCollection<DrawningRoadTrain, DrawningObjectTrain>(_pictureWidth, _pictureHeight));
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Удаление набора
|
/// Удаление набора
|
||||||
@ -72,7 +72,7 @@ namespace RoadTrain.Generics
|
|||||||
/// <param name="name">Название набора</param>
|
/// <param name="name">Название набора</param>
|
||||||
public void DelSet(string name)
|
public void DelSet(string name)
|
||||||
{
|
{
|
||||||
if (_trainStorages.ContainsKey(name)) _trainStorages.Remove(name);
|
if (_trainStorages.ContainsKey(new TrainsCollectionInfo(name, string.Empty))) _trainStorages.Remove(new TrainsCollectionInfo(name, string.Empty));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
@ -85,7 +85,9 @@ namespace RoadTrain.Generics
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
if (_trainStorages.ContainsKey(ind)) return _trainStorages[ind];
|
TrainsCollectionInfo indObj = new TrainsCollectionInfo(ind, string.Empty);
|
||||||
|
if (_trainStorages.ContainsKey(indObj))
|
||||||
|
return _trainStorages[indObj];
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -101,7 +103,7 @@ namespace RoadTrain.Generics
|
|||||||
File.Delete(filename);
|
File.Delete(filename);
|
||||||
}
|
}
|
||||||
StringBuilder data = new();
|
StringBuilder data = new();
|
||||||
foreach (KeyValuePair<string,
|
foreach (KeyValuePair<TrainsCollectionInfo,
|
||||||
RoadTrainGenericCollection<DrawningRoadTrain, DrawningObjectTrain>> record in _trainStorages)
|
RoadTrainGenericCollection<DrawningRoadTrain, DrawningObjectTrain>> record in _trainStorages)
|
||||||
{
|
{
|
||||||
StringBuilder records = new();
|
StringBuilder records = new();
|
||||||
@ -182,7 +184,7 @@ namespace RoadTrain.Generics
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
_trainStorages.Add(name, collection);
|
_trainStorages.Add(new TrainsCollectionInfo(name, string.Empty), collection);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -28,13 +28,19 @@ namespace RoadTrain.Generics
|
|||||||
_maxCount = count;
|
_maxCount = count;
|
||||||
_places = new List<T?> (count);
|
_places = new List<T?> (count);
|
||||||
}
|
}
|
||||||
|
/// <summary>
|
||||||
|
/// Сортировка набора объектов
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="comparer"></param>
|
||||||
|
public void SortSet(IComparer<T?> comparer) =>
|
||||||
|
_places.Sort(comparer);
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Добавление объекта в набор
|
/// Добавление объекта в набор
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public int Insert(T train)
|
public int Insert(T train, IEqualityComparer<T?>? equal = null)
|
||||||
{
|
{
|
||||||
return Insert(train, 0);
|
return Insert(train, 0, equal);
|
||||||
}
|
}
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Добавление объекта в набор на конкретную позицию
|
/// Добавление объекта в набор на конкретную позицию
|
||||||
@ -42,13 +48,16 @@ namespace RoadTrain.Generics
|
|||||||
/// <param name="car">Добавляемый автомобиль</param>
|
/// <param name="car">Добавляемый автомобиль</param>
|
||||||
/// <param name="position">Позиция</param>
|
/// <param name="position">Позиция</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public int Insert(T train, int position)
|
public int Insert(T train, int position, IEqualityComparer<T?>? equal = null)
|
||||||
{
|
{
|
||||||
if (position < 0 || position >= _maxCount)
|
if (position < 0 || position >= _maxCount)
|
||||||
throw new StorageOverflowException("Невалидная операция");
|
throw new StorageOverflowException("Невалидная операция");
|
||||||
|
|
||||||
if (Count >= _maxCount)
|
if (Count >= _maxCount)
|
||||||
throw new StorageOverflowException(_maxCount);
|
throw new StorageOverflowException(_maxCount);
|
||||||
|
|
||||||
|
if (equal != null && _places.Contains(train, equal))
|
||||||
|
throw new ArgumentException("Обьект уже есть в коллекции");
|
||||||
_places.Insert(position, train);
|
_places.Insert(position, train);
|
||||||
return position;
|
return position;
|
||||||
}
|
}
|
||||||
|
45
RoadTrain/TrainCompareByColor.cs
Normal file
45
RoadTrain/TrainCompareByColor.cs
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
using RoadTrain.DrawningObjects;
|
||||||
|
using RoadTrain.Entities;
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace RoadTrain
|
||||||
|
{
|
||||||
|
internal class TrainCompareByColor : IComparer<DrawningRoadTrain?>
|
||||||
|
{
|
||||||
|
public int Compare(DrawningRoadTrain? x, DrawningRoadTrain? y)
|
||||||
|
{
|
||||||
|
if (x == null || x.EntityRoadTrain == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(nameof(x));
|
||||||
|
}
|
||||||
|
if (y == null || y.EntityRoadTrain == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(nameof(y));
|
||||||
|
}
|
||||||
|
if (x.EntityRoadTrain.BodyColor.Name != y.EntityRoadTrain.BodyColor.Name)
|
||||||
|
{
|
||||||
|
return x.EntityRoadTrain.BodyColor.Name.CompareTo(y.EntityRoadTrain.BodyColor.Name);
|
||||||
|
}
|
||||||
|
if (x.GetType().Name == y.GetType().Name && x is DrawningTrain)
|
||||||
|
{
|
||||||
|
EntityTrain EntityX = x.EntityRoadTrain as EntityTrain;
|
||||||
|
EntityTrain EntityY = y.EntityRoadTrain as EntityTrain;
|
||||||
|
if (EntityX.AdditionalColor.Name != EntityY.AdditionalColor.Name)
|
||||||
|
{
|
||||||
|
return EntityX.AdditionalColor.Name.CompareTo(EntityY.AdditionalColor.Name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var speedCompare =
|
||||||
|
x.EntityRoadTrain.Speed.CompareTo(y.EntityRoadTrain.Speed);
|
||||||
|
if (speedCompare != 0)
|
||||||
|
{
|
||||||
|
return speedCompare;
|
||||||
|
}
|
||||||
|
return x.EntityRoadTrain.Weight.CompareTo(y.EntityRoadTrain.Weight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
35
RoadTrain/TrainCompareByType.cs
Normal file
35
RoadTrain/TrainCompareByType.cs
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
using RoadTrain.DrawningObjects;
|
||||||
|
|
||||||
|
namespace RoadTrain.Generics
|
||||||
|
{
|
||||||
|
internal class TrainCompareByType : IComparer<DrawningRoadTrain?>
|
||||||
|
{
|
||||||
|
public int Compare(DrawningRoadTrain? x, DrawningRoadTrain? y)
|
||||||
|
{
|
||||||
|
if (x == null || x.EntityRoadTrain == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(nameof(x));
|
||||||
|
}
|
||||||
|
if (y == null || y.EntityRoadTrain == null)
|
||||||
|
{
|
||||||
|
throw new ArgumentNullException(nameof(y));
|
||||||
|
}
|
||||||
|
if (x.GetType().Name != y.GetType().Name)
|
||||||
|
{
|
||||||
|
return x.GetType().Name.CompareTo(y.GetType().Name);
|
||||||
|
}
|
||||||
|
var speedCompare =
|
||||||
|
x.EntityRoadTrain.Speed.CompareTo(y.EntityRoadTrain.Speed);
|
||||||
|
if (speedCompare != 0)
|
||||||
|
{
|
||||||
|
return speedCompare;
|
||||||
|
}
|
||||||
|
return x.EntityRoadTrain.Weight.CompareTo(y.EntityRoadTrain.Weight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
29
RoadTrain/TrainsCollectionInfo.cs
Normal file
29
RoadTrain/TrainsCollectionInfo.cs
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace RoadTrain
|
||||||
|
{
|
||||||
|
internal class TrainsCollectionInfo : IEquatable<TrainsCollectionInfo>
|
||||||
|
{
|
||||||
|
public string Name { get; private set; }
|
||||||
|
public string Description { get; private set; }
|
||||||
|
public TrainsCollectionInfo(string name, string description)
|
||||||
|
{
|
||||||
|
Name = name;
|
||||||
|
Description = description;
|
||||||
|
}
|
||||||
|
public bool Equals(TrainsCollectionInfo? other)
|
||||||
|
{
|
||||||
|
if (other == null)
|
||||||
|
return false;
|
||||||
|
return other.Name == Name;
|
||||||
|
}
|
||||||
|
public override int GetHashCode()
|
||||||
|
{
|
||||||
|
return Name.GetHashCode();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user