Условия

This commit is contained in:
Владимир Данилов 2023-11-01 00:29:15 +04:00
parent 7c1c04dc31
commit e85221a51b
4 changed files with 77 additions and 24 deletions

View File

@ -49,8 +49,13 @@ namespace Project_DumpTruck
private void buttonCreateTruck_Click(object sender, EventArgs e) private void buttonCreateTruck_Click(object sender, EventArgs e)
{ {
Random random = new(); Random random = new();
_drawningTruck = new DrawningTruck(random.Next(100, 300), random.Next(1000, 3000), Color color = Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256));
Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256)), ColorDialog dialog = new();
if (dialog.ShowDialog() == DialogResult.OK)
{
color = dialog.Color;
}
_drawningTruck = new DrawningTruck(random.Next(100, 300), random.Next(1000, 3000), color,
pictureBoxDumpTruck.Width, pictureBoxDumpTruck.Height); pictureBoxDumpTruck.Width, pictureBoxDumpTruck.Height);
_drawningTruck.SetPosition(random.Next(10, 100), random.Next(10, 100)); _drawningTruck.SetPosition(random.Next(10, 100), random.Next(10, 100));
@ -90,9 +95,20 @@ namespace Project_DumpTruck
private void buttonCreateDumpTruck_Click(object sender, EventArgs e) private void buttonCreateDumpTruck_Click(object sender, EventArgs e)
{ {
Random random = new(); Random random = new();
Color color = Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256));
ColorDialog dialog = new();
if (dialog.ShowDialog() == DialogResult.OK)
{
color = dialog.Color;
}
Color dopColor = Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256));
dialog = new();
if (dialog.ShowDialog() == DialogResult.OK)
{
dopColor = dialog.Color;
}
_drawningTruck = new DrawningDumpTruck(random.Next(100, 300), random.Next(1000, 3000), _drawningTruck = new DrawningDumpTruck(random.Next(100, 300), random.Next(1000, 3000),
Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256)), color, dopColor,
Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256)),
Convert.ToBoolean(random.Next(0, 2)), Convert.ToBoolean(random.Next(0, 2)), Convert.ToBoolean(random.Next(0, 2)), Convert.ToBoolean(random.Next(0, 2)),
pictureBoxDumpTruck.Width, pictureBoxDumpTruck.Height); pictureBoxDumpTruck.Width, pictureBoxDumpTruck.Height);
_drawningTruck.SetPosition(random.Next(10, 100), random.Next(10, 100)); _drawningTruck.SetPosition(random.Next(10, 100), random.Next(10, 100));

View File

@ -32,7 +32,7 @@ namespace Project_DumpTruck
FormDumpTruck form = new(); FormDumpTruck form = new();
if (form.ShowDialog() == DialogResult.OK) if (form.ShowDialog() == DialogResult.OK)
{ {
if (_trucks + form.selectedTruck) if (_trucks + form.selectedTruck != -1)
{ {
MessageBox.Show("Объект добавлен"); MessageBox.Show("Объект добавлен");
pictureBoxCollection.Image = _trucks.ShowTrucks(); pictureBoxCollection.Image = _trucks.ShowTrucks();

View File

@ -1,6 +1,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Linq; using System.Linq;
using System.Numerics;
using System.Text; using System.Text;
using System.Threading.Tasks; using System.Threading.Tasks;
@ -32,28 +33,54 @@ namespace Project_DumpTruck.Generics
/// <summary> /// <summary>
/// Добавление объекта в набор /// Добавление объекта в набор
/// </summary> /// </summary>
/// <param name="car">Добавляемый автомобиль</param> /// <param name="truck">Добавляемый автомобиль</param>
/// <returns></returns> /// <returns></returns>
public bool Insert(T car) public int Insert(T truck)
{ {
// TODO вставка в начало набора return Insert(truck, 0);
return true;
} }
/// <summary> /// <summary>
/// Добавление объекта в набор на конкретную позицию /// Добавление объекта в набор на конкретную позицию
/// </summary> /// </summary>
/// <param name="car">Добавляемый автомобиль</param> /// <param name="truck">Добавляемый автомобиль</param>
/// <param name="position">Позиция</param> /// <param name="position">Позиция</param>
/// <returns></returns> /// <returns></returns>
public bool Insert(T car, int position) public int Insert(T truck, int position)
{ {
// TODO проверка позиции // TODO проверка позиции
if (position < 0 || position > Count)
{
return -1;
}
// TODO проверка, что элемент массива по этой позиции пустой, если нет, то // TODO проверка, что элемент массива по этой позиции пустой, если нет, то
// проверка, что после вставляемого элемента в массиве есть пустой элемент if (_places[position] != null)
// сдвиг всех объектов, находящихся справа от позиции до первого пустого элемента {
// TODO вставка по позиции // проверка, что после вставляемого элемента в массиве есть пустой элемент
_places[position] = car; int nullIndex = -1;
return true; for (int i = position + 1; i < Count; i++)
{
if (_places[i] == null)
{
nullIndex = i;
break;
}
}
// Если пустого элемента нет, то выходим
if (nullIndex < 0)
{
return -1;
}
// сдвиг всех объектов, находящихся справа от позиции до первого пустого элемента
int j = nullIndex - 1;
while (j >= position)
{
_places[j + 1] = _places[j];
j--;
}
}
// TODO вставка по позиции
_places[position] = truck;
return position;
} }
/// <summary> /// <summary>
/// Удаление объекта из набора с конкретной позиции /// Удаление объекта из набора с конкретной позиции
@ -63,8 +90,10 @@ namespace Project_DumpTruck.Generics
public bool Remove(int position) public bool Remove(int position)
{ {
// TODO проверка позиции // TODO проверка позиции
if ((position < 0) || (position > Count)) return false;
// TODO удаление объекта из массива, присвоив элементу массива значение null // TODO удаление объекта из массива, присвоив элементу массива значение null
return true; _places[position] = null;
return true;
} }
/// <summary> /// <summary>
/// Получение объекта из набора по позиции /// Получение объекта из набора по позиции
@ -74,6 +103,7 @@ namespace Project_DumpTruck.Generics
public T? Get(int position) public T? Get(int position)
{ {
// TODO проверка позиции // TODO проверка позиции
if ((position < 0) || (position > Count)) return null;
return _places[position]; return _places[position];
} }
} }

View File

@ -23,11 +23,11 @@ namespace Project_DumpTruck.Generics
/// <summary> /// <summary>
/// Размер занимаемого объектом места (ширина) /// Размер занимаемого объектом места (ширина)
/// </summary> /// </summary>
private readonly int _placeSizeWidth = 210; private readonly int _placeSizeWidth = 110;
/// <summary> /// <summary>
/// Размер занимаемого объектом места (высота) /// Размер занимаемого объектом места (высота)
/// </summary> /// </summary>
private readonly int _placeSizeHeight = 90; private readonly int _placeSizeHeight = 70;
/// <summary> /// <summary>
/// Набор объектов /// Набор объектов
/// </summary> /// </summary>
@ -51,14 +51,14 @@ namespace Project_DumpTruck.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 +(TrucksGenericCollection<T, U> collect, T? public static int operator +(TrucksGenericCollection<T, U> collect, T?
obj) obj)
{ {
if (obj == null) if (obj == null)
{ {
return false; return -1;
} }
return collect?._collection.Insert(obj) ?? false; return collect._collection.Insert(obj);
} }
/// <summary> /// <summary>
/// Перегрузка оператора вычитания /// Перегрузка оператора вычитания
@ -66,8 +66,7 @@ namespace Project_DumpTruck.Generics
/// <param name="collect"></param> /// <param name="collect"></param>
/// <param name="pos"></param> /// <param name="pos"></param>
/// <returns></returns> /// <returns></returns>
public static T? operator -(TrucksGenericCollection<T, U> collect, int public static T? operator -(TrucksGenericCollection<T, U> collect, int pos)
pos)
{ {
T? obj = collect._collection.Get(pos); T? obj = collect._collection.Get(pos);
if (obj != null) if (obj != null)
@ -123,11 +122,19 @@ namespace Project_DumpTruck.Generics
/// <param name="g"></param> /// <param name="g"></param>
private void DrawObjects(Graphics g) private void DrawObjects(Graphics g)
{ {
int width = _pictureWidth / _placeSizeWidth;
int height = _pictureHeight / _placeSizeHeight;
for (int i = 0; i < _collection.Count; i++) for (int i = 0; i < _collection.Count; i++)
{ {
// TODO получение объекта // TODO получение объекта
// TODO установка позиции // TODO установка позиции
// TODO прорисовка объекта // TODO прорисовка объекта
DrawningTruck? truck = _collection.Get(i);
if (truck == null)
continue;
truck.SetPosition(i % width * _placeSizeWidth, i / height * _placeSizeHeight);
truck.DrawTransport(g);
} }
} }
} }