Исправил с учетом прошлых изменений

This commit is contained in:
Алексей Тихоненков 2023-10-30 16:39:27 +04:00
commit 7b693f5fd7
2 changed files with 23 additions and 16 deletions

View File

@ -51,31 +51,26 @@ namespace AntiAircraftGun.Generics
/// <param name="collect"></param> /// <param name="collect"></param>
/// <param name="obj"></param> /// <param name="obj"></param>
/// <returns></returns> /// <returns></returns>
public static bool operator +(AntiAirCraftGunGenericCollection<T, U> collect, T? obj) public static int operator +(AntiAirCraftGunGenericCollection<T,U> collect, T? obj)
{ {
if (obj == null) if (obj == null)
{ return -1;
MessageBox.Show("Объект пустой. Невозможно добавить."); return collect?._collection.Insert(obj) ?? -1;
return false;
} }
return collect?._collection.Insert(obj) ?? false;
}
/// <summary> /// <summary>
/// Перегрузка оператора вычитания /// Перегрузка оператора вычитания
/// </summary> /// </summary>
/// <param name="collect"></param> /// <param name="collect"></param>
/// <param name="pos"></param> /// <param name="pos"></param>
/// <returns></returns> /// <returns></returns>
public static T? operator -(AntiAirCraftGunGenericCollection<T, U> collect, int pos) public static bool operator -(AntiAirCraftGunGenericCollection<T, U> collect, int pos)
{ {
T? obj = collect._collection[pos]; T? obj = collect._collection.Get(pos);
if (obj != null) if (obj != null)
{ return collect._collection.Remove(pos);
collect._collection.Remove(pos); return false;
}
return obj;
} }
/// <summary> /// <summary>
/// Получение объекта IMoveableObject /// Получение объекта IMoveableObject
/// </summary> /// </summary>
@ -156,9 +151,21 @@ namespace AntiAircraftGun.Generics
if (y + distance_between_objects >= maxY) if (y + distance_between_objects >= maxY)
{ {
y = 0; y = 0;
x += obj.GetWidth + 10 + _placeSizeWidth; x += _placeSizeWidth;
} }
} }
if (obj == null)
{
// Увеличиваем координату Y для следующего объекта
y += distance_between_objects;
// Проверяем, если Y достигло максимума, изменяем X и сбрасываем Y
if (y+distance_between_objects >= maxY)
{
y = 0;
x += _placeSizeWidth;
}
};
} }
} }
} }

View File

@ -35,7 +35,7 @@ namespace AntiAircraftGun.Generics
/// </summary> /// </summary>
/// <param name="car">Добавляемый автомобиль</param> /// <param name="car">Добавляемый автомобиль</param>
/// <returns></returns> /// <returns></returns>
public bool Insert(T car) public int Insert(T car)
{ {
if (_places.Count == _maxCount) if (_places.Count == _maxCount)
return false; return false;