Выполнение TODO, исправление ошибок

This commit is contained in:
malimova 2023-10-29 22:25:43 +04:00
parent 829029a6dc
commit dfa874b91f
5 changed files with 38 additions and 53 deletions

View File

@ -274,6 +274,5 @@ namespace AirBomber
/// </summary> /// </summary>
public IMoveableObject GetMoveableObject => new public IMoveableObject GetMoveableObject => new
DrawningObjectAirPlane(this); DrawningObjectAirPlane(this);
} }
} }

View File

@ -45,10 +45,9 @@ namespace AirBomber
/// </summary> /// </summary>
/// <param name="sender"></param> /// <param name="sender"></param>
/// <param name="e"></param> /// <param name="e"></param>
private void ListBoxObjects_SelectedIndexChanged(object sender, EventArgs e) private void listBoxObjects_SelectedIndexChanged(object sender, EventArgs e)
{ {
pictureBoxCollection.Image = pictureBoxCollection.Image = _storage[listBoxStorages.SelectedItem?.ToString()?? string.Empty]?.ShowPlanes();
_storage[listBoxStorages.SelectedItem?.ToString()?? string.Empty]?.ShowPlanes();
} }
/// <summary> /// <summary>
@ -70,7 +69,7 @@ namespace AirBomber
FormAirBomber form = new(); FormAirBomber form = new();
if (form.ShowDialog() == DialogResult.OK) if (form.ShowDialog() == DialogResult.OK)
{ {
if (obj + form.SelectedPlane != -1) if (obj + form.SelectedPlane > -1)
{ {
MessageBox.Show("Объект добавлен"); MessageBox.Show("Объект добавлен");
pictureBoxCollection.Image = obj.ShowPlanes(); pictureBoxCollection.Image = obj.ShowPlanes();

View File

@ -103,15 +103,13 @@ namespace AirBomber
Pen pen = new(Color.Black, 3); Pen pen = new(Color.Black, 3);
for (int i = 0; i < _pictureWidth / _placeSizeWidth; i++) for (int i = 0; i < _pictureWidth / _placeSizeWidth; i++)
{ {
for (int j = 0; j < _pictureHeight / _placeSizeHeight + for (int j = 0; j < _pictureHeight / _placeSizeHeight + 1; ++j)
1; ++j) {
{//линия рамзетки места //линия рамзетки места
g.DrawLine(pen, i * _placeSizeWidth, j * g.DrawLine(pen, i * _placeSizeWidth, j *
_placeSizeHeight, i * _placeSizeWidth + _placeSizeWidth / 2, j * _placeSizeHeight, i * _placeSizeWidth + _placeSizeWidth / 2, j * _placeSizeHeight);
_placeSizeHeight);
} }
g.DrawLine(pen, i * _placeSizeWidth, 0, i * g.DrawLine(pen, i * _placeSizeWidth, 0, i * _placeSizeWidth, _pictureHeight / _placeSizeHeight * _placeSizeHeight);
_placeSizeWidth, _pictureHeight / _placeSizeHeight * _placeSizeHeight);
} }
} }
/// <summary> /// <summary>
@ -121,18 +119,16 @@ namespace AirBomber
private void DrawObjects(Graphics g) private void DrawObjects(Graphics g)
{ {
int widthObjCount = _pictureWidth / _placeSizeWidth; int widthObjCount = _pictureWidth / _placeSizeWidth;
int i = 0; for (int i = 0; i < _collection.Count; i++)
foreach (var plane in _collection.GetPlanes())
{ {
T? type = _collection[i];
if (type != null)
{ {
if (plane != null) int row = i / widthObjCount;
{ int col = widthObjCount - 1 - (i % widthObjCount);
int row = i / widthObjCount;
int col = widthObjCount - 1 - (i % widthObjCount);
plane.SetPosition(col * _placeSizeWidth, row * _placeSizeHeight); type.SetPosition(col * _placeSizeWidth, row * _placeSizeHeight);
plane?.DrawPlane(g); type?.DrawPlane(g);
}
} }
} }
} }

View File

@ -41,7 +41,11 @@ namespace AirBomber
/// <param name="name">Название набора</param> /// <param name="name">Название набора</param>
public void AddSet(string name) public void AddSet(string name)
{ {
// TODO Прописать логику для добавления // TODO Прописать логику для добавления DONE
if (!_planeStorages.ContainsKey(name))
{
_planeStorages.Add(name, new PlanesGenericCollection<DrawningAirPlane, DrawningObjectAirPlane>(_pictureWidth, _pictureHeight));
}
} }
/// <summary> /// <summary>
/// Удаление набора /// Удаление набора
@ -49,7 +53,11 @@ namespace AirBomber
/// <param name="name">Название набора</param> /// <param name="name">Название набора</param>
public void DelSet(string name) public void DelSet(string name)
{ {
// TODO Прописать логику для удаления // TODO Прописать логику для удаления DONE
if (_planeStorages.ContainsKey(name))
{
_planeStorages.Remove(name);
}
} }
/// <summary> /// <summary>
/// Доступ к набору /// Доступ к набору
@ -61,7 +69,11 @@ namespace AirBomber
{ {
get get
{ {
// TODO Продумать логику получения набора // TODO Продумать логику получения набора DONE
if (_planeStorages.ContainsKey(ind))
{
return _planeStorages[ind];
}
return null; return null;
} }
} }

View File

@ -53,32 +53,9 @@ namespace AirBomber
// проверка, что после вставляемого элемента в массиве есть пустой элемент // проверка, что после вставляемого элемента в массиве есть пустой элемент
// сдвиг всех объектов, находящихся справа от позиции до первого пустого элемента // сдвиг всех объектов, находящихся справа от позиции до первого пустого элемента
// TODO вставка по позиции // TODO вставка по позиции
int NoEmpty = 0, temp = 0; if (position < 0 || position >= _maxCount) return -1;
for (int i = position; i < Count; i++) _places.Insert(position, plane);
{ return position;
if (_places[i] != null) NoEmpty++;
}
if (NoEmpty == Count - position) return -1;
if (position < Count && position >= 0)
{
for (int j = position; j < Count; j++)
{
if (_places[j] == null)
{
temp = j;
break;
}
}
for (int i = temp; i > position; i--)
{
_places[i] = _places[i - 1];
}
_places[position] = plane;
return position;
}
return -1;
} }
/// <summary> /// <summary>
/// Удаление объекта из набора с конкретной позиции /// Удаление объекта из набора с конкретной позиции
@ -114,9 +91,11 @@ namespace AirBomber
} }
set set
{ {
// TODO проверка позиции // TODO проверка позиции DONE
// TODO проверка свободных мест в списке // TODO проверка свободных мест в списке DONE
// TODO вставка в список по позиции // TODO вставка в список по позиции DONE
if (position < 0 || position >= Count || Count == _maxCount) return;
_places.Insert(position, value);
} }
} }
/// <summary> /// <summary>