diff --git a/AirPlaneWithRadar/AirPlaneWithRadar/AbstractMap.cs b/AirPlaneWithRadar/AirPlaneWithRadar/AbstractMap.cs index 1e193f7..1e39948 100644 --- a/AirPlaneWithRadar/AirPlaneWithRadar/AbstractMap.cs +++ b/AirPlaneWithRadar/AirPlaneWithRadar/AbstractMap.cs @@ -6,7 +6,7 @@ using System.Threading.Tasks; namespace AirPlaneWithRadar { - internal abstract class AbstractMap + internal abstract class AbstractMap : IEquatable { private IDrawingObject _drawningObject = null; protected int[,] _map = null; @@ -145,5 +145,37 @@ namespace AirPlaneWithRadar protected abstract void GenerateMap(); protected abstract void DrawRoadPart(Graphics g, int i, int j); protected abstract void DrawBarrierPart(Graphics g, int i, int j); + + public string ArrToStr(int[,] arr) + { + string res = ""; + foreach (int i in arr) + { + res += i; + } + return res; + } + public bool Equals(AbstractMap? other) + { + if (other == null) + { + return false; + } + var curMap = this; + var otherMap = other; + if (curMap._height != otherMap._height) + return false; + if (curMap._width != otherMap._width) + return false; + if (curMap._size_x != otherMap._size_x) + return false; + if (curMap._size_y != otherMap._size_y) + return false; + string arr1 = ArrToStr(curMap._map); + string arr2 = ArrToStr(curMap._map); + if (!arr1.Equals(arr2)) + return false; + return true; + } } } diff --git a/AirPlaneWithRadar/AirPlaneWithRadar/DrawingObjectPlane.cs b/AirPlaneWithRadar/AirPlaneWithRadar/DrawingObjectPlane.cs index dee3243..b5bc709 100644 --- a/AirPlaneWithRadar/AirPlaneWithRadar/DrawingObjectPlane.cs +++ b/AirPlaneWithRadar/AirPlaneWithRadar/DrawingObjectPlane.cs @@ -66,7 +66,19 @@ namespace AirPlaneWithRadar { return false; } - + var RadPlain = plain as RadioPlane; + var otherRadPlain = otherPlainPlain as RadioPlane; + if (RadPlain == null && otherRadPlain == null) + return true; + if (RadPlain == null || otherRadPlain == null) + return false; + if (!(RadPlain.DopColor.Equals(otherRadPlain.DopColor))) + return false; + if (!(RadPlain.Radar.Equals(otherRadPlain.Radar))) + return false; + if (!(RadPlain.OilBox.Equals(otherRadPlain.OilBox))) + return false; + return true; } } diff --git a/AirPlaneWithRadar/AirPlaneWithRadar/FormMapWithSetPlains.cs b/AirPlaneWithRadar/AirPlaneWithRadar/FormMapWithSetPlains.cs index 8aa96ba..e31acf1 100644 --- a/AirPlaneWithRadar/AirPlaneWithRadar/FormMapWithSetPlains.cs +++ b/AirPlaneWithRadar/AirPlaneWithRadar/FormMapWithSetPlains.cs @@ -287,7 +287,12 @@ namespace AirPlaneWithRadar private void ButtonSortByColor_Click(object sender, EventArgs e) { - + if (listBoxMaps.SelectedIndex == -1) + { + return; + } + _mapsCollection[listBoxMaps.SelectedItem?.ToString() ?? string.Empty].Sort(new PlaneCompareByColor()); + pictureBox.Image = _mapsCollection[listBoxMaps.SelectedItem?.ToString() ?? string.Empty].ShowSet(); } } diff --git a/AirPlaneWithRadar/AirPlaneWithRadar/Log.txt b/AirPlaneWithRadar/AirPlaneWithRadar/Log.txt index 0274be1..c7bbdf4 100644 --- a/AirPlaneWithRadar/AirPlaneWithRadar/Log.txt +++ b/AirPlaneWithRadar/AirPlaneWithRadar/Log.txt @@ -37,3 +37,61 @@ 2022-12-02 19:35:15.398 +03:00 [WRN] Неизвестная ошибка при удалении самолета на карту 1234 : Index was out of range. Must be non-negative and less than the size of the collection. (Parameter 'index') 2022-12-02 19:35:20.416 +03:00 [INF] С карты 1234 был удален самолет 2022-12-02 19:35:24.176 +03:00 [WRN] Неизвестная ошибка при удалении самолета на карту 1234 : Index was out of range. Must be non-negative and less than the size of the collection. (Parameter 'index') +2022-12-02 20:58:51.450 +03:00 [INF] Переключение на карту 0 +2022-12-02 20:58:51.469 +03:00 [INF] Была проведена загрузка из файла C:\Users\Вова\Documents\test2.txt +2022-12-02 20:58:52.939 +03:00 [INF] Переключение на карту 2 +2022-12-02 20:58:53.435 +03:00 [INF] Переключение на карту 123 +2022-12-02 20:58:53.906 +03:00 [INF] Переключение на карту 2 +2022-12-02 20:59:11.008 +03:00 [INF] На карту 2 добавлен новый самолет +2022-12-02 20:59:17.699 +03:00 [INF] На карту 2 добавлен новый самолет +2022-12-02 21:02:18.006 +03:00 [INF] Переключение на карту 1 +2022-12-02 21:02:18.017 +03:00 [INF] Добавлена карта: 1 +2022-12-02 21:02:23.228 +03:00 [INF] На карту 1 добавлен новый самолет +2022-12-02 21:02:29.188 +03:00 [INF] На карту 1 добавлен новый самолет +2022-12-02 21:02:41.779 +03:00 [INF] На карту 1 добавлен новый самолет +2022-12-02 21:04:40.932 +03:00 [INF] Переключение на карту 12 +2022-12-02 21:04:40.942 +03:00 [INF] Добавлена карта: 12 +2022-12-02 21:04:47.181 +03:00 [INF] На карту 12 добавлен новый самолет +2022-12-02 21:04:51.926 +03:00 [INF] На карту 12 добавлен новый самолет +2022-12-02 21:06:03.473 +03:00 [INF] Переключение на карту 12 +2022-12-02 21:06:03.483 +03:00 [INF] Добавлена карта: 12 +2022-12-02 21:06:11.530 +03:00 [INF] На карту 12 добавлен новый самолет +2022-12-02 21:08:09.171 +03:00 [INF] Переключение на карту 12 +2022-12-02 21:08:09.180 +03:00 [INF] Добавлена карта: 12 +2022-12-02 21:09:01.146 +03:00 [INF] На карту 12 добавлен новый самолет +2022-12-02 21:10:09.720 +03:00 [INF] Переключение на карту 12 +2022-12-02 21:10:09.734 +03:00 [INF] Добавлена карта: 12 +2022-12-02 21:10:19.563 +03:00 [INF] На карту 12 добавлен новый самолет +2022-12-02 21:10:27.721 +03:00 [INF] Добавление самолета на карту 12 прошло неудачно +2022-12-02 21:10:36.916 +03:00 [INF] Переключение на карту 0 +2022-12-02 21:10:36.917 +03:00 [INF] Была проведена загрузка из файла C:\Users\Вова\Documents\test.txt +2022-12-02 21:10:37.991 +03:00 [INF] Переключение на карту 123 +2022-12-02 21:10:38.462 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:10:54.307 +03:00 [INF] На карту 2 добавлен новый самолет +2022-12-02 21:11:04.627 +03:00 [INF] На карту 2 добавлен новый самолет +2022-12-02 21:11:11.001 +03:00 [INF] Добавление самолета на карту 2 прошло неудачно +2022-12-02 21:11:30.530 +03:00 [INF] На карту 2 добавлен новый самолет +2022-12-02 21:11:42.503 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:42.503 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:11:43.232 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:43.232 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:11:43.412 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:43.412 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:11:45.214 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:45.214 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:11:47.256 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:47.256 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:11:47.612 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:47.612 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:11:47.780 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:47.780 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:11:47.996 +03:00 [INF] Переключение на карту 2 +2022-12-02 21:11:47.996 +03:00 [INF] Добавлена карта: 2 +2022-12-02 21:22:56.692 +03:00 [INF] Переключение на карту 123 +2022-12-02 21:22:56.708 +03:00 [INF] Добавлена карта: 123 +2022-12-02 21:23:01.316 +03:00 [INF] На карту 123 добавлен новый самолет +2022-12-02 21:23:05.600 +03:00 [INF] Добавление самолета на карту 123 прошло неудачно +2022-12-02 21:23:09.917 +03:00 [INF] На карту 123 добавлен новый самолет +2022-12-02 21:23:19.050 +03:00 [INF] На карту 123 добавлен новый самолет +2022-12-02 21:23:30.002 +03:00 [INF] На карту 123 добавлен новый самолет +2022-12-02 21:23:34.691 +03:00 [INF] На карту 123 добавлен новый самолет diff --git a/AirPlaneWithRadar/AirPlaneWithRadar/PlaneCompareByColor.cs b/AirPlaneWithRadar/AirPlaneWithRadar/PlaneCompareByColor.cs index 218a4a6..d0d885c 100644 --- a/AirPlaneWithRadar/AirPlaneWithRadar/PlaneCompareByColor.cs +++ b/AirPlaneWithRadar/AirPlaneWithRadar/PlaneCompareByColor.cs @@ -10,7 +10,43 @@ namespace AirPlaneWithRadar { public int Compare(IDrawingObject? x, IDrawingObject? y) { - throw new NotImplementedException(); + if (x == null && y == null) + { + return 0; + } + if (x == null && y != null) + { + return 1; + } + if (x != null && y == null) + { + return -1; + } + var xPlain = x as DrawingObjectPlane; + var yPlain = y as DrawingObjectPlane; + if (xPlain == null && yPlain == null) + { + return 0; + } + if (xPlain == null && yPlain != null) + { + return 1; + } + if (xPlain != null && yPlain == null) + { + return -1; + } + int res = string.Compare(xPlain.GetPlane.Plain.BodyColor.Name, yPlain.GetPlane.Plain.BodyColor.Name); + if (res != 0) + { + return res; + } + var speedCompare = xPlain.GetPlane.Plain.Speed.CompareTo(yPlain.GetPlane.Plain.Speed); + if (speedCompare != 0) + { + return speedCompare; + } + return xPlain.GetPlane.Plain.Weight.CompareTo(yPlain.GetPlane.Plain.Weight); } } } diff --git a/AirPlaneWithRadar/AirPlaneWithRadar/SetPlaneGeneric.cs b/AirPlaneWithRadar/AirPlaneWithRadar/SetPlaneGeneric.cs index f96b2b7..7b37d9b 100644 --- a/AirPlaneWithRadar/AirPlaneWithRadar/SetPlaneGeneric.cs +++ b/AirPlaneWithRadar/AirPlaneWithRadar/SetPlaneGeneric.cs @@ -20,13 +20,13 @@ namespace AirPlaneWithRadar } public int Insert(T plain) { - + if (_places.Contains(plain)) { return -1; } Insert(plain, 0); return _places.Count; } public int Insert(T plain, int position) { - ///// + if (_places.Count == _maxCount) { throw new StorageOverFullException(_maxCount);