Лабораторная работа №2
This commit is contained in:
parent
b3f02eed27
commit
6a3d5b7234
29
ProjectAirbus/ProjectAirbus/Drawnings/DirectionType.cs
Normal file
29
ProjectAirbus/ProjectAirbus/Drawnings/DirectionType.cs
Normal file
@ -0,0 +1,29 @@
|
||||
namespace ProjectAirbus.Drawnings;
|
||||
|
||||
public enum DirectionType
|
||||
{
|
||||
/// <summary>
|
||||
/// Неизвестное направление
|
||||
/// </summary>
|
||||
Unknow = -1,
|
||||
|
||||
/// <summary>
|
||||
/// Вверх
|
||||
/// </summary>
|
||||
Up = 1,
|
||||
|
||||
/// <summary>
|
||||
/// Вниз
|
||||
/// </summary>
|
||||
Down = 2,
|
||||
|
||||
/// <summary>
|
||||
/// Влево
|
||||
/// </summary>
|
||||
Left = 3,
|
||||
|
||||
/// <summary>
|
||||
/// Вправо
|
||||
/// </summary>
|
||||
Right = 4
|
||||
}
|
@ -1,16 +1,16 @@
|
||||
using System.Drawing;
|
||||
using ProjectAirbus.Entities;
|
||||
|
||||
namespace ProjectAirbus;
|
||||
namespace ProjectAirbus.Drawnings;
|
||||
|
||||
/// <summary>
|
||||
/// Класс отрисовки и перемещения объекта-сущности
|
||||
/// Класс отрисовки и перемещения базового объекта-сущности
|
||||
/// </summary>
|
||||
public class DrawningAirbus
|
||||
{
|
||||
/// <summary>
|
||||
/// Класс-сущность
|
||||
/// </summary>
|
||||
public EntityAirbus? EntityAirbus { get; private set; }
|
||||
public EntityAirbus? EntityAirbus { get; protected set; }
|
||||
|
||||
/// <summary>
|
||||
/// Ширина окна
|
||||
@ -25,38 +25,75 @@ public class DrawningAirbus
|
||||
/// <summary>
|
||||
/// Начальная координата х
|
||||
/// </summary>
|
||||
private int? _startPosX;
|
||||
protected int? _startPosX;
|
||||
|
||||
/// <summary>
|
||||
/// Начальная координата у
|
||||
/// </summary>
|
||||
private int? _startPosY;
|
||||
protected int? _startPosY;
|
||||
|
||||
/// <summary>
|
||||
/// Ширина самолета
|
||||
/// </summary>
|
||||
public readonly int _drawningAirbusWidth = 145;
|
||||
private readonly int _drawningAirbusWidth = 145;
|
||||
|
||||
/// <summary>
|
||||
/// Высота самолета
|
||||
/// </summary>
|
||||
public readonly int _drawningAirbusHeight = 50;
|
||||
private readonly int _drawningAirbusHeight = 50;
|
||||
|
||||
/// <summary>
|
||||
/// Инициализация свойств
|
||||
/// Координата X объекта
|
||||
/// </summary>
|
||||
public int? GetPosX => _startPosX;
|
||||
|
||||
/// <summary>
|
||||
/// Координата Y объекта
|
||||
/// </summary>
|
||||
public int? GetPosY => _startPosY;
|
||||
|
||||
/// <summary>
|
||||
/// Ширина объекта
|
||||
/// </summary>
|
||||
public int GetWidth => _drawningAirbusWidth;
|
||||
|
||||
/// <summary>
|
||||
/// Высотаы объекта
|
||||
/// </summary>
|
||||
public int GetHeight => _drawningAirbusHeight;
|
||||
|
||||
/// <summary>
|
||||
/// Пустой конструктор
|
||||
/// </summary>
|
||||
private DrawningAirbus()
|
||||
{
|
||||
_pictureWidth = null;
|
||||
_pictureHeight = null;
|
||||
_startPosX = 0;
|
||||
_startPosY = 0;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор
|
||||
/// </summary>
|
||||
/// <param name="speed">Скорость</param>
|
||||
/// <param name="weight">Вес</param>
|
||||
/// <param name="bodyColor">Основной цвет</param>
|
||||
/// <param name="additionalColor">Дополнительный цвет</param>
|
||||
public void Init(int speed, double weight, Color bodyColor, Color additionalColor, bool additionalEngine, bool passengerCompartment)
|
||||
public DrawningAirbus(int speed, double weight, Color bodyColor) : this()
|
||||
{
|
||||
EntityAirbus = new EntityAirbus();
|
||||
EntityAirbus.Init(speed, weight, bodyColor, additionalColor, additionalEngine, passengerCompartment);
|
||||
_pictureWidth = null;
|
||||
_pictureHeight = null;
|
||||
_startPosX = null;
|
||||
_startPosY = null;
|
||||
EntityAirbus = new EntityAirbus(speed, weight, bodyColor);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор для наследников
|
||||
/// </summary>
|
||||
/// <param name="drawningCarWidth">Ширина прорисовки аэробуса</param>
|
||||
/// <param name="drawningCarHeight">Высота прорисовки аэробуса</param>
|
||||
protected DrawningAirbus(int drawningCarWidth, int drawningCarHeight) : this()
|
||||
{
|
||||
_drawningAirbusWidth = drawningCarWidth;
|
||||
_pictureHeight = drawningCarHeight;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -64,7 +101,7 @@ public class DrawningAirbus
|
||||
/// </summary>
|
||||
/// <param name="width">Ширина поля</param>
|
||||
/// <param name="height">Высота поля</param>
|
||||
/// <returns></returns>
|
||||
/// <returns>true - границы заданы, false - границы не заданы, проверка не пройдена</returns>
|
||||
public bool SetPictureSize(int width, int height)
|
||||
{
|
||||
if (width > _drawningAirbusWidth && height > _drawningAirbusHeight)
|
||||
@ -119,7 +156,7 @@ public class DrawningAirbus
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Выбор направления перемещения
|
||||
/// Изменение направления перемещения
|
||||
/// </summary>
|
||||
/// <param name="direction">Направлениие</param>
|
||||
/// <returns>true - перемещение возможно и выполнено, false - перемещение невозможно и не выполнено</returns>
|
||||
@ -165,7 +202,7 @@ public class DrawningAirbus
|
||||
/// Отрисовка самолёта
|
||||
/// </summary>
|
||||
/// <param name="g"></param>
|
||||
public void DrawTransport(Graphics g)
|
||||
public virtual void DrawTransport(Graphics g)
|
||||
{
|
||||
if (EntityAirbus == null || !_startPosX.HasValue || !_startPosY.HasValue)
|
||||
{
|
||||
@ -174,7 +211,6 @@ public class DrawningAirbus
|
||||
|
||||
Pen pen = new(Color.Black);
|
||||
Brush brushBodyColor = new SolidBrush(EntityAirbus.BodyColor);
|
||||
Brush brushAdditionalColor = new SolidBrush(EntityAirbus.AdditionalColor);
|
||||
Brush brushBlack = new SolidBrush(Color.Black);
|
||||
|
||||
//границы самолёта
|
||||
@ -187,18 +223,6 @@ public class DrawningAirbus
|
||||
g.DrawLine(pen, _startPosX.Value + 120, _startPosY.Value + 40, _startPosX.Value + 145, _startPosY.Value + 30);
|
||||
g.DrawLine(pen, _startPosX.Value + 120, _startPosY.Value + 30, _startPosX.Value + 145, _startPosY.Value + 30);
|
||||
|
||||
//дополнительный отсек для пассажиров
|
||||
if (EntityAirbus.PassengerCompartment)
|
||||
{
|
||||
g.DrawRectangle(pen, _startPosX.Value + 60, _startPosY.Value + 10, 40, 10);
|
||||
g.DrawEllipse(pen, _startPosX.Value + 50, _startPosY.Value + 10, 20, 20);
|
||||
g.DrawEllipse(pen, _startPosX.Value + 90, _startPosY.Value + 10, 20, 20);
|
||||
|
||||
g.FillRectangle(brushAdditionalColor, _startPosX.Value + 60, _startPosY.Value + 11, 40, 10);
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 50, _startPosY.Value + 10, 20, 20);
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 90, _startPosY.Value + 10, 20, 20);
|
||||
}
|
||||
|
||||
//шасси
|
||||
g.DrawLine(pen, _startPosX.Value + 40, _startPosY.Value + 40, _startPosX.Value + 40, _startPosY.Value + 44);
|
||||
g.DrawEllipse(pen, _startPosX.Value + 34, _startPosY.Value + 44, 6, 6);
|
||||
@ -216,14 +240,6 @@ public class DrawningAirbus
|
||||
g.FillEllipse(brushBlack, _startPosX.Value + 12, _startPosY.Value + 15, 8, 8);
|
||||
g.FillRectangle(brushBlack, _startPosX.Value + 4, _startPosY.Value + 15, 12, 8);
|
||||
|
||||
//дополнительный двигатель на крыле
|
||||
if (EntityAirbus.AdditionalEngine)
|
||||
{
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 48, _startPosY.Value + 30, 8, 8);
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 60, _startPosY.Value + 30, 8, 8);
|
||||
g.FillRectangle(brushAdditionalColor, _startPosX.Value + 52, _startPosY.Value + 30, 12, 8);
|
||||
}
|
||||
|
||||
//крыло
|
||||
g.FillRectangle(brushBlack, _startPosX.Value + 40, _startPosY.Value + 28, 40, 4);
|
||||
g.FillEllipse(brushBlack, _startPosX.Value + 38, _startPosY.Value + 28, 4, 4);
|
46
ProjectAirbus/ProjectAirbus/Drawnings/DrawningBigAirbus.cs
Normal file
46
ProjectAirbus/ProjectAirbus/Drawnings/DrawningBigAirbus.cs
Normal file
@ -0,0 +1,46 @@
|
||||
using ProjectAirbus.Entities;
|
||||
|
||||
namespace ProjectAirbus.Drawnings;
|
||||
|
||||
public class DrawningBigAirbus : DrawningAirbus
|
||||
{
|
||||
public DrawningBigAirbus(int speed, double weight, Color bodyColor, Color additionalColor, bool additionalEngine, bool passengerCompartment) : base(145, 50)
|
||||
{
|
||||
EntityAirbus = new EntityBigAirbus(speed, weight, bodyColor, additionalColor, additionalEngine, passengerCompartment);
|
||||
}
|
||||
|
||||
public override void DrawTransport(Graphics g)
|
||||
{
|
||||
if (EntityAirbus == null || EntityAirbus is not EntityBigAirbus bigAirbus || !_startPosX.HasValue || !_startPosY.HasValue)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
Pen pen = new(Color.Black);
|
||||
Brush brushBodyColor = new SolidBrush(EntityAirbus.BodyColor);
|
||||
Brush brushAdditionalColor = new SolidBrush(bigAirbus.AdditionalColor);
|
||||
Brush brushBlack = new SolidBrush(Color.Black);
|
||||
|
||||
//дополнительный отсек для пассажиров
|
||||
if (bigAirbus.PassengerCompartment)
|
||||
{
|
||||
g.DrawRectangle(pen, _startPosX.Value + 60, _startPosY.Value + 10, 40, 10);
|
||||
g.DrawEllipse(pen, _startPosX.Value + 50, _startPosY.Value + 10, 20, 20);
|
||||
g.DrawEllipse(pen, _startPosX.Value + 90, _startPosY.Value + 10, 20, 20);
|
||||
|
||||
g.FillRectangle(brushAdditionalColor, _startPosX.Value + 60, _startPosY.Value + 11, 40, 10);
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 50, _startPosY.Value + 10, 20, 20);
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 90, _startPosY.Value + 10, 20, 20);
|
||||
}
|
||||
|
||||
base.DrawTransport(g);
|
||||
|
||||
//дополнительный двигатель на крыле
|
||||
if (bigAirbus.AdditionalEngine)
|
||||
{
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 48, _startPosY.Value + 30, 8, 8);
|
||||
g.FillEllipse(brushAdditionalColor, _startPosX.Value + 60, _startPosY.Value + 30, 8, 8);
|
||||
g.FillRectangle(brushAdditionalColor, _startPosX.Value + 52, _startPosY.Value + 30, 12, 8);
|
||||
}
|
||||
}
|
||||
}
|
40
ProjectAirbus/ProjectAirbus/Entities/EntityAirbus.cs
Normal file
40
ProjectAirbus/ProjectAirbus/Entities/EntityAirbus.cs
Normal file
@ -0,0 +1,40 @@
|
||||
namespace ProjectAirbus.Entities;
|
||||
|
||||
/// <summary>
|
||||
/// Класс-сущность "Аэробус"
|
||||
/// </summary>
|
||||
public class EntityAirbus
|
||||
{
|
||||
/// <summary>
|
||||
/// Скорость
|
||||
/// </summary>
|
||||
public int Speed { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Вес
|
||||
/// </summary>
|
||||
public double Weight { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Основной цвет
|
||||
/// </summary>
|
||||
public Color BodyColor { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Шаг перемещения автомобиля
|
||||
/// </summary>
|
||||
public double Step => Speed * 100 / Weight;
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор сущности
|
||||
/// </summary>
|
||||
/// <param name="speed">Скорость</param>
|
||||
/// <param name="weight">Вес</param>
|
||||
/// <param name="bodyColor">Основной цвет</param>
|
||||
public EntityAirbus(int speed, double weight, Color bodyColor)
|
||||
{
|
||||
Speed = speed;
|
||||
Weight = weight;
|
||||
BodyColor = bodyColor;
|
||||
}
|
||||
}
|
26
ProjectAirbus/ProjectAirbus/Entities/EntityBIgAirbus.cs
Normal file
26
ProjectAirbus/ProjectAirbus/Entities/EntityBIgAirbus.cs
Normal file
@ -0,0 +1,26 @@
|
||||
namespace ProjectAirbus.Entities;
|
||||
|
||||
public class EntityBigAirbus : EntityAirbus
|
||||
{
|
||||
/// <summary>
|
||||
/// Дополнительный цвет
|
||||
/// </summary>
|
||||
public Color AdditionalColor { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Опция наличия дополнительного двигателя
|
||||
/// </summary>
|
||||
public bool AdditionalEngine { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Опция наличия дополнительного отсека для пассажиров
|
||||
/// </summary>
|
||||
public bool PassengerCompartment { get; private set; }
|
||||
|
||||
public EntityBigAirbus(int speed, double weight, Color bodyColor, Color additionalColor, bool additionalEngine, bool passengerCompartment) : base(0, 0, Color.Black)
|
||||
{
|
||||
AdditionalColor = additionalColor;
|
||||
AdditionalEngine = additionalEngine;
|
||||
PassengerCompartment = passengerCompartment;
|
||||
}
|
||||
}
|
@ -1,62 +0,0 @@
|
||||
namespace ProjectAirbus;
|
||||
|
||||
/// <summary>
|
||||
/// Класс-сущность "Аэробус"
|
||||
/// </summary>
|
||||
public class EntityAirbus
|
||||
{
|
||||
/// <summary>
|
||||
/// Скорость
|
||||
/// </summary>
|
||||
public int Speed { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Вес
|
||||
/// </summary>
|
||||
public double Weight { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Основной цвет
|
||||
/// </summary>
|
||||
public Color BodyColor { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Дополнительный цвет
|
||||
/// </summary>
|
||||
public Color AdditionalColor { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Опция наличия дополнительного двигателя
|
||||
/// </summary>
|
||||
public bool AdditionalEngine { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Опция наличия дополнительного отсека для пассажиров
|
||||
/// </summary>
|
||||
public bool PassengerCompartment { get; private set; }
|
||||
|
||||
/// <summary>
|
||||
/// Шаг перемещения автомобиля
|
||||
/// </summary>
|
||||
public double Step => Speed * 100 / Weight;
|
||||
|
||||
/// <summary>
|
||||
/// Инициализация полей объекта-класса аэробуса
|
||||
/// </summary>
|
||||
/// <param name="speed">Скорость</param>
|
||||
/// <param name="weight">Вес</param>
|
||||
/// <param name="bodyColor">Основной цвет</param>
|
||||
/// <param name="additionalColor">Дополнительный цвет</param>
|
||||
/// <param name="additionalEngine">Опция наличия дополнительного двигателя</param>
|
||||
/// <param name="passengerCompartment">Опция наличия дополнительного отсека для пассажиров</param>
|
||||
public void Init(int speed, double weight, Color bodyColor, Color additionalColor, bool additionalEngine,
|
||||
bool passengerCompartment)
|
||||
{
|
||||
Speed = speed;
|
||||
Weight = weight;
|
||||
BodyColor = bodyColor;
|
||||
AdditionalColor = additionalColor;
|
||||
AdditionalEngine = additionalEngine;
|
||||
PassengerCompartment = passengerCompartment;
|
||||
}
|
||||
}
|
64
ProjectAirbus/ProjectAirbus/FormAirbus.Designer.cs
generated
64
ProjectAirbus/ProjectAirbus/FormAirbus.Designer.cs
generated
@ -29,11 +29,14 @@
|
||||
private void InitializeComponent()
|
||||
{
|
||||
pictureBoxAirbus = new PictureBox();
|
||||
buttonCreateAirBus = new Button();
|
||||
buttonCreateAirbus = new Button();
|
||||
buttonLeft = new Button();
|
||||
buttonUp = new Button();
|
||||
buttonRight = new Button();
|
||||
buttonDown = new Button();
|
||||
buttonCreateBigAirbus = new Button();
|
||||
comboBoxStrategy = new ComboBox();
|
||||
buttonStrategyStep = new Button();
|
||||
((System.ComponentModel.ISupportInitialize)pictureBoxAirbus).BeginInit();
|
||||
SuspendLayout();
|
||||
//
|
||||
@ -47,16 +50,16 @@
|
||||
pictureBoxAirbus.TabIndex = 0;
|
||||
pictureBoxAirbus.TabStop = false;
|
||||
//
|
||||
// buttonCreateAirBus
|
||||
// buttonCreateAirbus
|
||||
//
|
||||
buttonCreateAirBus.Anchor = AnchorStyles.Bottom | AnchorStyles.Left;
|
||||
buttonCreateAirBus.Location = new Point(12, 529);
|
||||
buttonCreateAirBus.Name = "buttonCreateAirBus";
|
||||
buttonCreateAirBus.Size = new Size(75, 23);
|
||||
buttonCreateAirBus.TabIndex = 1;
|
||||
buttonCreateAirBus.Text = "Создать";
|
||||
buttonCreateAirBus.UseVisualStyleBackColor = true;
|
||||
buttonCreateAirBus.Click += ButtonCreateAirbus_Click;
|
||||
buttonCreateAirbus.Anchor = AnchorStyles.Bottom | AnchorStyles.Left;
|
||||
buttonCreateAirbus.Location = new Point(182, 529);
|
||||
buttonCreateAirbus.Name = "buttonCreateAirbus";
|
||||
buttonCreateAirbus.Size = new Size(164, 23);
|
||||
buttonCreateAirbus.TabIndex = 1;
|
||||
buttonCreateAirbus.Text = "Создать аэробус";
|
||||
buttonCreateAirbus.UseVisualStyleBackColor = true;
|
||||
buttonCreateAirbus.Click += ButtonCreateAirbus_Click;
|
||||
//
|
||||
// buttonLeft
|
||||
//
|
||||
@ -106,16 +109,50 @@
|
||||
buttonDown.UseVisualStyleBackColor = true;
|
||||
buttonDown.Click += ButtonMove_Click;
|
||||
//
|
||||
// buttonCreateBigAirbus
|
||||
//
|
||||
buttonCreateBigAirbus.Anchor = AnchorStyles.Bottom | AnchorStyles.Left;
|
||||
buttonCreateBigAirbus.Location = new Point(12, 529);
|
||||
buttonCreateBigAirbus.Name = "buttonCreateBigAirbus";
|
||||
buttonCreateBigAirbus.Size = new Size(164, 23);
|
||||
buttonCreateBigAirbus.TabIndex = 6;
|
||||
buttonCreateBigAirbus.Text = "Создать большой аэробус";
|
||||
buttonCreateBigAirbus.UseVisualStyleBackColor = true;
|
||||
buttonCreateBigAirbus.Click += buttonCreateBigAirbus_Click;
|
||||
//
|
||||
// comboBoxStrategy
|
||||
//
|
||||
comboBoxStrategy.DropDownStyle = ComboBoxStyle.DropDownList;
|
||||
comboBoxStrategy.FormattingEnabled = true;
|
||||
comboBoxStrategy.Items.AddRange(new object[] { "К центру", "К краю" });
|
||||
comboBoxStrategy.Location = new Point(909, 12);
|
||||
comboBoxStrategy.Name = "comboBoxStrategy";
|
||||
comboBoxStrategy.Size = new Size(121, 23);
|
||||
comboBoxStrategy.TabIndex = 7;
|
||||
//
|
||||
// buttonStrategyStep
|
||||
//
|
||||
buttonStrategyStep.Location = new Point(909, 41);
|
||||
buttonStrategyStep.Name = "buttonStrategyStep";
|
||||
buttonStrategyStep.Size = new Size(121, 23);
|
||||
buttonStrategyStep.TabIndex = 8;
|
||||
buttonStrategyStep.Text = "Шаг";
|
||||
buttonStrategyStep.UseVisualStyleBackColor = true;
|
||||
buttonStrategyStep.Click += buttonStrategyStep_Click;
|
||||
//
|
||||
// FormAirbus
|
||||
//
|
||||
AutoScaleDimensions = new SizeF(7F, 15F);
|
||||
AutoScaleMode = AutoScaleMode.Font;
|
||||
ClientSize = new Size(1042, 564);
|
||||
Controls.Add(buttonStrategyStep);
|
||||
Controls.Add(comboBoxStrategy);
|
||||
Controls.Add(buttonCreateBigAirbus);
|
||||
Controls.Add(buttonDown);
|
||||
Controls.Add(buttonRight);
|
||||
Controls.Add(buttonUp);
|
||||
Controls.Add(buttonLeft);
|
||||
Controls.Add(buttonCreateAirBus);
|
||||
Controls.Add(buttonCreateAirbus);
|
||||
Controls.Add(pictureBoxAirbus);
|
||||
Margin = new Padding(3, 2, 3, 2);
|
||||
Name = "FormAirbus";
|
||||
@ -128,10 +165,13 @@
|
||||
#endregion
|
||||
|
||||
private PictureBox pictureBoxAirbus;
|
||||
private Button buttonCreateAirBus;
|
||||
private Button buttonCreateAirbus;
|
||||
private Button buttonLeft;
|
||||
private Button buttonUp;
|
||||
private Button buttonRight;
|
||||
private Button buttonDown;
|
||||
private Button buttonCreateBigAirbus;
|
||||
private ComboBox comboBoxStrategy;
|
||||
private Button buttonStrategyStep;
|
||||
}
|
||||
}
|
@ -1,4 +1,6 @@
|
||||
using System.Diagnostics;
|
||||
using ProjectAirbus.Drawnings;
|
||||
using ProjectAirbus.MovementStrategy;
|
||||
|
||||
namespace ProjectAirbus
|
||||
|
||||
@ -13,12 +15,15 @@ namespace ProjectAirbus
|
||||
/// </summary>
|
||||
private DrawningAirbus? _drawningAirbus;
|
||||
|
||||
private AbstractStrategy? _strategy;
|
||||
|
||||
/// <summary>
|
||||
/// Конструктор формы
|
||||
/// </summary>
|
||||
public FormAirbus()
|
||||
{
|
||||
InitializeComponent();
|
||||
_strategy = null;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
@ -37,25 +42,40 @@ namespace ProjectAirbus
|
||||
pictureBoxAirbus.Image = bmp;
|
||||
}
|
||||
|
||||
private void CreateObject(string type)
|
||||
{
|
||||
Random random = new();
|
||||
switch (type)
|
||||
{
|
||||
case nameof(DrawningAirbus):
|
||||
_drawningAirbus = new DrawningAirbus(random.Next(100, 300), random.Next(1000, 3000),
|
||||
Color.FromArgb(random.Next(0, 256), random.Next(0, 256), random.Next(0, 256)));
|
||||
break;
|
||||
case nameof(DrawningBigAirbus):
|
||||
_drawningAirbus = new DrawningBigAirbus(random.Next(100, 300), random.Next(1000, 3000),
|
||||
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)),
|
||||
Convert.ToBoolean(random.Next(0, 2)), Convert.ToBoolean(random.Next(0, 2)));
|
||||
break;
|
||||
default:
|
||||
return;
|
||||
}
|
||||
|
||||
_drawningAirbus.SetPictureSize(pictureBoxAirbus.Width, pictureBoxAirbus.Height);
|
||||
_drawningAirbus.SetPosition(random.Next(10, 100), random.Next(10, 100));
|
||||
_strategy = null;
|
||||
//comboBoxStrategy.Enabled = true;
|
||||
Draw();
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Обработка кнопки "создать"
|
||||
/// </summary>
|
||||
/// <param name="sender"></param>
|
||||
/// <param name="e"></param>
|
||||
private void ButtonCreateAirbus_Click(object sender, EventArgs e)
|
||||
{
|
||||
Random random = new();
|
||||
_drawningAirbus = new DrawningAirbus();
|
||||
_drawningAirbus.Init(random.Next(100, 300), random.Next(1000, 3000),
|
||||
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)),
|
||||
Convert.ToBoolean(random.Next(0, 2)), Convert.ToBoolean(random.Next(0, 2)));
|
||||
private void ButtonCreateAirbus_Click(object sender, EventArgs e) => CreateObject(nameof(DrawningAirbus));
|
||||
|
||||
_drawningAirbus.SetPictureSize(pictureBoxAirbus.Width, pictureBoxAirbus.Height);
|
||||
_drawningAirbus.SetPosition(random.Next(10, 100), random.Next(10, 100));
|
||||
|
||||
Draw();
|
||||
}
|
||||
private void buttonCreateBigAirbus_Click(object sender, EventArgs e) => CreateObject(nameof(DrawningBigAirbus));
|
||||
|
||||
/// <summary>
|
||||
/// Обработка кнопок перемещения объекта
|
||||
@ -71,7 +91,8 @@ namespace ProjectAirbus
|
||||
|
||||
String name = ((Button)sender)?.Name ?? String.Empty;
|
||||
bool result = false;
|
||||
switch (name) {
|
||||
switch (name)
|
||||
{
|
||||
case "buttonUp":
|
||||
result = _drawningAirbus.MoveTransport(DirectionType.Up);
|
||||
break;
|
||||
@ -91,5 +112,45 @@ namespace ProjectAirbus
|
||||
Draw();
|
||||
}
|
||||
}
|
||||
|
||||
private void buttonStrategyStep_Click(object sender, EventArgs e)
|
||||
{
|
||||
if (_drawningAirbus == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if (comboBoxStrategy.Enabled)
|
||||
{
|
||||
_strategy = comboBoxStrategy.SelectedIndex switch
|
||||
{
|
||||
0 => new MoveToCenter(),
|
||||
1 => new MoveToBorder(),
|
||||
_ => null,
|
||||
};
|
||||
|
||||
if (_strategy == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
_strategy.SetData(new MoveableAirbus(_drawningAirbus), pictureBoxAirbus.Width, pictureBoxAirbus.Height);
|
||||
}
|
||||
|
||||
if (_strategy == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
comboBoxStrategy.Enabled = false;
|
||||
_strategy.MakeStep();
|
||||
Draw();
|
||||
|
||||
if (_strategy.GetStatus() == StrategyStatus.Finish)
|
||||
{
|
||||
comboBoxStrategy.Enabled = true;
|
||||
_strategy = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,78 @@
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
|
||||
public abstract class AbstractStrategy
|
||||
{
|
||||
private IMoveableObject? _moveableObject;
|
||||
|
||||
private StrategyStatus _state = StrategyStatus.NotInit;
|
||||
|
||||
protected int FieldWidth { get; private set; }
|
||||
|
||||
protected int FieldHeight { get; private set; }
|
||||
|
||||
public StrategyStatus GetStatus() { return _state; }
|
||||
|
||||
public void SetData(IMoveableObject moveableObject, int width, int height)
|
||||
{
|
||||
if (moveableObject == null)
|
||||
{
|
||||
_state = StrategyStatus.NotInit;
|
||||
return;
|
||||
}
|
||||
|
||||
_state = StrategyStatus.InProgress;
|
||||
_moveableObject = moveableObject;
|
||||
FieldWidth = width;
|
||||
FieldHeight = height;
|
||||
}
|
||||
|
||||
public void MakeStep()
|
||||
{
|
||||
if (_state != StrategyStatus.InProgress)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
if (IsTargetDestination())
|
||||
{
|
||||
_state = StrategyStatus.Finish;
|
||||
return;
|
||||
}
|
||||
|
||||
MoveToTarget();
|
||||
}
|
||||
|
||||
protected bool MoveLeft() => MoveTo(MovementDirection.Left);
|
||||
|
||||
protected bool MoveRight() => MoveTo(MovementDirection.Right);
|
||||
|
||||
protected bool MoveUp() => MoveTo(MovementDirection.Up);
|
||||
|
||||
protected bool MoveDown() => MoveTo(MovementDirection.Down);
|
||||
|
||||
protected ObjectParameters? GetObjectParameters => _moveableObject?.GetObjectPosition;
|
||||
|
||||
protected int? GetStep()
|
||||
{
|
||||
if (_state != StrategyStatus.InProgress)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
return _moveableObject.GetStep;
|
||||
}
|
||||
|
||||
protected abstract void MoveToTarget();
|
||||
|
||||
protected abstract bool IsTargetDestination();
|
||||
|
||||
private bool MoveTo(MovementDirection movementDirection)
|
||||
{
|
||||
if (_state != StrategyStatus.InProgress)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return _moveableObject?.TryMoveObject(movementDirection) ?? false;
|
||||
}
|
||||
}
|
@ -0,0 +1,9 @@
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
public interface IMoveableObject
|
||||
{
|
||||
ObjectParameters? GetObjectPosition { get; }
|
||||
|
||||
int GetStep { get; }
|
||||
|
||||
bool TryMoveObject(MovementDirection direction);
|
||||
}
|
37
ProjectAirbus/ProjectAirbus/MovementStrategy/MoveToBorder.cs
Normal file
37
ProjectAirbus/ProjectAirbus/MovementStrategy/MoveToBorder.cs
Normal file
@ -0,0 +1,37 @@
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
|
||||
public class MoveToBorder : AbstractStrategy
|
||||
{
|
||||
protected override bool IsTargetDestination()
|
||||
{
|
||||
ObjectParameters? objParams = GetObjectParameters;
|
||||
if (objParams == null)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return objParams.LeftBorder - GetStep() <= 0 || objParams.RightBorder + GetStep() >= FieldWidth ||
|
||||
objParams.TopBorder - GetStep() <= 0 || objParams.ObjectMiddleVertical + GetStep() >= FieldHeight;
|
||||
}
|
||||
|
||||
protected override void MoveToTarget()
|
||||
{
|
||||
ObjectParameters? objParams = GetObjectParameters;
|
||||
if (objParams == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
int diffX = objParams.RightBorder - FieldWidth;
|
||||
if (Math.Abs(diffX) > GetStep())
|
||||
{
|
||||
MoveRight();
|
||||
}
|
||||
|
||||
int diffY = objParams.BottomBorder - FieldHeight;
|
||||
if (Math.Abs(diffY) > GetStep())
|
||||
{
|
||||
MoveDown();
|
||||
}
|
||||
}
|
||||
}
|
52
ProjectAirbus/ProjectAirbus/MovementStrategy/MoveToCenter.cs
Normal file
52
ProjectAirbus/ProjectAirbus/MovementStrategy/MoveToCenter.cs
Normal file
@ -0,0 +1,52 @@
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
|
||||
public class MoveToCenter : AbstractStrategy
|
||||
{
|
||||
protected override bool IsTargetDestination()
|
||||
{
|
||||
ObjectParameters? objParams = GetObjectParameters;
|
||||
if(objParams == null)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return objParams.ObjectMiddleHorizontal - GetStep() <= FieldWidth / 2 && objParams.ObjectMiddleHorizontal + GetStep() >= FieldWidth / 2
|
||||
&&
|
||||
objParams.ObjectMiddleVertical - GetStep() <= FieldHeight / 2 && objParams.ObjectMiddleVertical + GetStep() >= FieldHeight / 2;
|
||||
}
|
||||
|
||||
protected override void MoveToTarget()
|
||||
{
|
||||
ObjectParameters? objParams = GetObjectParameters;
|
||||
if(objParams == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
||||
int diffX = objParams.ObjectMiddleHorizontal - FieldWidth / 2;
|
||||
if (Math.Abs(diffX) > GetStep())
|
||||
{
|
||||
if (diffX > 0)
|
||||
{
|
||||
MoveLeft();
|
||||
}
|
||||
else
|
||||
{
|
||||
MoveRight();
|
||||
}
|
||||
}
|
||||
|
||||
int diffY = objParams.ObjectMiddleVertical - FieldHeight / 2;
|
||||
if (Math.Abs(diffY) > GetStep())
|
||||
{
|
||||
if (diffY > 0)
|
||||
{
|
||||
MoveUp();
|
||||
}
|
||||
else
|
||||
{
|
||||
MoveDown();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
@ -0,0 +1,50 @@
|
||||
using ProjectAirbus.Drawnings;
|
||||
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
|
||||
internal class MoveableAirbus : IMoveableObject
|
||||
{
|
||||
private readonly DrawningAirbus? _airbus = null;
|
||||
|
||||
public MoveableAirbus(DrawningAirbus airbus)
|
||||
{
|
||||
_airbus = airbus;
|
||||
}
|
||||
|
||||
public ObjectParameters? GetObjectPosition
|
||||
{
|
||||
get
|
||||
{
|
||||
if (_airbus == null || _airbus.EntityAirbus == null || !_airbus.GetPosX.HasValue || !_airbus.GetPosY.HasValue)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
return new ObjectParameters(_airbus.GetPosX.Value, _airbus.GetPosY.Value, _airbus.GetWidth, _airbus.GetHeight);
|
||||
}
|
||||
}
|
||||
|
||||
public int GetStep => (int)(_airbus?.EntityAirbus?.Step ?? 0);
|
||||
|
||||
public bool TryMoveObject(MovementDirection direction)
|
||||
{
|
||||
if(_airbus == null || _airbus.EntityAirbus == null)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return _airbus.MoveTransport(GetDirectionType(direction));
|
||||
}
|
||||
|
||||
private static DirectionType GetDirectionType(MovementDirection direction)
|
||||
{
|
||||
return direction switch
|
||||
{
|
||||
MovementDirection.Left => DirectionType.Left,
|
||||
MovementDirection.Right => DirectionType.Right,
|
||||
MovementDirection.Up => DirectionType.Up,
|
||||
MovementDirection.Down => DirectionType.Down,
|
||||
_ => DirectionType.Unknow,
|
||||
};
|
||||
}
|
||||
}
|
@ -1,9 +1,9 @@
|
||||
namespace ProjectAirbus;
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
|
||||
/// <summary>
|
||||
/// Направление перемещения
|
||||
/// </summary>
|
||||
public enum DirectionType
|
||||
public enum MovementDirection
|
||||
{
|
||||
/// <summary>
|
||||
/// Вверх
|
@ -0,0 +1,36 @@
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
|
||||
/// <summary>
|
||||
/// Параметры-координаты Объекта
|
||||
/// </summary>
|
||||
public class ObjectParameters
|
||||
{
|
||||
private readonly int _x;
|
||||
|
||||
private readonly int _y;
|
||||
|
||||
private readonly int _width;
|
||||
|
||||
private readonly int _height;
|
||||
|
||||
public int LeftBorder => _x;
|
||||
|
||||
public int TopBorder => _y;
|
||||
|
||||
public int RightBorder => _x + _width;
|
||||
|
||||
public int BottomBorder => _y + _height;
|
||||
|
||||
public int ObjectMiddleHorizontal => _x + _width / 2;
|
||||
|
||||
public int ObjectMiddleVertical => _y + _height / 2;
|
||||
|
||||
public ObjectParameters(int x , int y, int width, int height)
|
||||
{
|
||||
_x = x;
|
||||
_y = y;
|
||||
_width = width;
|
||||
_height = height;
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,13 @@
|
||||
namespace ProjectAirbus.MovementStrategy;
|
||||
|
||||
/// <summary>
|
||||
/// Статус выполнения перемещения
|
||||
/// </summary>
|
||||
public enum StrategyStatus
|
||||
{
|
||||
NotInit,
|
||||
|
||||
InProgress,
|
||||
|
||||
Finish
|
||||
}
|
@ -8,6 +8,12 @@
|
||||
<ImplicitUsings>enable</ImplicitUsings>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<Compile Remove="MovementStrategy\Entities\**" />
|
||||
<EmbeddedResource Remove="MovementStrategy\Entities\**" />
|
||||
<None Remove="MovementStrategy\Entities\**" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<Compile Update="Properties\Resources.Designer.cs">
|
||||
<DesignTime>True</DesignTime>
|
||||
|
Loading…
x
Reference in New Issue
Block a user