Выполнение TODO, исправление ошибок
This commit is contained in:
parent
829029a6dc
commit
dfa874b91f
@ -274,6 +274,5 @@ namespace AirBomber
|
|||||||
/// </summary>
|
/// </summary>
|
||||||
public IMoveableObject GetMoveableObject => new
|
public IMoveableObject GetMoveableObject => new
|
||||||
DrawningObjectAirPlane(this);
|
DrawningObjectAirPlane(this);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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();
|
||||||
|
@ -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 (plane != null)
|
if (type != null)
|
||||||
{
|
{
|
||||||
int row = i / widthObjCount;
|
int row = i / widthObjCount;
|
||||||
int col = widthObjCount - 1 - (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);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -53,33 +53,10 @@ 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);
|
||||||
{
|
|
||||||
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 position;
|
||||||
}
|
}
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Удаление объекта из набора с конкретной позиции
|
/// Удаление объекта из набора с конкретной позиции
|
||||||
/// </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>
|
||||||
|
Loading…
Reference in New Issue
Block a user