файлы лабораторной
This commit is contained in:
parent
1047be1e08
commit
cfa3253cf1
69
lainer/Lainer1/AbstractStrategy.cs
Normal file
69
lainer/Lainer1/AbstractStrategy.cs
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
using ProjectLainer;
|
||||||
|
using ProjectLainer.MovementStrategy;
|
||||||
|
|
||||||
|
namespace ProjectLainer.MovementStrategy
|
||||||
|
{
|
||||||
|
public abstract class AbstractStrategy
|
||||||
|
{
|
||||||
|
private IMoveableObject? _moveableObject;
|
||||||
|
private Status _state = Status.NotInit;
|
||||||
|
protected int FieldWidth { get; private set; }
|
||||||
|
protected int FieldHeight { get; private set; }
|
||||||
|
public Status GetStatus() { return _state; }
|
||||||
|
public void SetData(IMoveableObject moveableObject, int width, int
|
||||||
|
height)
|
||||||
|
{
|
||||||
|
if (moveableObject == null)
|
||||||
|
{
|
||||||
|
_state = Status.NotInit;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
_state = Status.InProgress;
|
||||||
|
_moveableObject = moveableObject;
|
||||||
|
FieldWidth = width;
|
||||||
|
FieldHeight = height;
|
||||||
|
}
|
||||||
|
public void MakeStep()
|
||||||
|
{
|
||||||
|
if (_state != Status.InProgress)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (IsTargetDestinaion())
|
||||||
|
{
|
||||||
|
_state = Status.Finish;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
MoveToTarget();
|
||||||
|
}
|
||||||
|
protected bool MoveLeft() => MoveTo(DirectionType.Left);
|
||||||
|
protected bool MoveRight() => MoveTo(DirectionType.Right);
|
||||||
|
protected bool MoveUp() => MoveTo(DirectionType.Up);
|
||||||
|
protected bool MoveDown() => MoveTo(DirectionType.Down);
|
||||||
|
protected ObjectParameters? GetObjectParameters =>
|
||||||
|
_moveableObject?.GetObjectPosition;
|
||||||
|
protected int? GetStep()
|
||||||
|
{
|
||||||
|
if (_state != Status.InProgress)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return _moveableObject?.GetStep;
|
||||||
|
}
|
||||||
|
protected abstract void MoveToTarget();
|
||||||
|
protected abstract bool IsTargetDestinaion();
|
||||||
|
private bool MoveTo(DirectionType directionType)
|
||||||
|
{
|
||||||
|
if (_state != Status.InProgress)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (_moveableObject?.CheckCanMove(directionType) ?? false)
|
||||||
|
{
|
||||||
|
_moveableObject.MoveObject(directionType);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
159
lainer/Lainer1/DrawingLainer.cs
Normal file
159
lainer/Lainer1/DrawingLainer.cs
Normal file
@ -0,0 +1,159 @@
|
|||||||
|
using ProjectLainer.Entities;
|
||||||
|
using System.Drawing;
|
||||||
|
|
||||||
|
namespace ProjectLainer.DrawningObjects
|
||||||
|
{
|
||||||
|
public class DrawingLainer
|
||||||
|
{
|
||||||
|
public EntityLainer? EntityLainer { get; protected set; }
|
||||||
|
private int _pictureWidth;
|
||||||
|
private int _pictureHeight;
|
||||||
|
protected int _startPosX;
|
||||||
|
protected int _startPosY;
|
||||||
|
public DrawingLainer(int speed, double weight, Color bodyColor, int
|
||||||
|
width, int height)
|
||||||
|
{
|
||||||
|
if (width < _LainerWidth || height < _LainerHeight)
|
||||||
|
return;
|
||||||
|
_pictureWidth = width;
|
||||||
|
_pictureHeight = height;
|
||||||
|
EntityLainer = new EntityLainer(speed, weight, bodyColor);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected DrawingLainer(int speed, double weight, Color bodyColor, int
|
||||||
|
width, int height, int carWidth, int carHeight)
|
||||||
|
{
|
||||||
|
if (width < _LainerWidth || height < _LainerHeight)
|
||||||
|
return;
|
||||||
|
_pictureWidth = width;
|
||||||
|
_pictureHeight = height;
|
||||||
|
_LainerWidth = carWidth;
|
||||||
|
_LainerHeight = carHeight;
|
||||||
|
EntityLainer = new EntityLainer(speed, weight, bodyColor);
|
||||||
|
}
|
||||||
|
public void SetPosition(int x, int y)
|
||||||
|
{
|
||||||
|
if (x + _LainerWidth < _pictureWidth && x + _LainerWidth > 0)
|
||||||
|
{
|
||||||
|
_startPosX = x;
|
||||||
|
}
|
||||||
|
if (y + _LainerHeight < _pictureHeight && y + _LainerHeight > 0)
|
||||||
|
{
|
||||||
|
_startPosY = y;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public virtual void DrawTransport(Graphics g)
|
||||||
|
{
|
||||||
|
if (EntityLainer == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Brush brBlue = new SolidBrush(Color.LightBlue);
|
||||||
|
//îòðèñîâêà òðóá
|
||||||
|
Brush brush = new SolidBrush(Color.Black);
|
||||||
|
Rectangle smokestack1 = new Rectangle(_startPosX + 20, _startPosY, 20, 50);
|
||||||
|
Rectangle smokestack2 = new Rectangle(_startPosX + 60, _startPosY, 20, 50);
|
||||||
|
g.FillRectangle(brush, smokestack1);
|
||||||
|
g.FillRectangle(brush, smokestack2);
|
||||||
|
//ãðàíèöû ëàéíåðà
|
||||||
|
Pen pen = new(Color.Red);
|
||||||
|
brush = new SolidBrush(Color.Red);
|
||||||
|
Point point1 = new Point(_startPosX, _startPosY + 50);
|
||||||
|
Point point2 = new Point(_startPosX + _LainerWidth, _startPosY + 50);
|
||||||
|
Point point3 = new Point(_startPosX + 20, _startPosY + 80);
|
||||||
|
Point point4 = new Point(_startPosX + 80, _startPosY + 80);
|
||||||
|
Point[] points = { point1, point2, point4, point3 };
|
||||||
|
g.DrawPolygon(pen, points);
|
||||||
|
g.FillPolygon(brush, points);
|
||||||
|
//1 ïàëóáà
|
||||||
|
brush = new SolidBrush(EntityLainer.BodyColor);
|
||||||
|
Rectangle deck = new Rectangle(_startPosX + 5, _startPosY + 30, _LainerWidth - 10, 20);
|
||||||
|
g.FillRectangle(brush, deck);
|
||||||
|
//ñòåêëà
|
||||||
|
for (int i = 1; i < 5; i++)
|
||||||
|
{
|
||||||
|
g.FillEllipse(brBlue, _startPosX + i * 16, _startPosY + 33, 14, 14);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public int GetPosX => _startPosX;
|
||||||
|
public int GetPosY => _startPosY;
|
||||||
|
private readonly int _LainerWidth = 150;
|
||||||
|
private readonly int _LainerHeight = 80;
|
||||||
|
public int GetWidth => _LainerWidth;
|
||||||
|
public int GetHeight => _LainerHeight;
|
||||||
|
public bool CanMove(DirectionType direction)
|
||||||
|
{
|
||||||
|
if (EntityLainer == null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return direction switch
|
||||||
|
{
|
||||||
|
//âëåâî
|
||||||
|
DirectionType.Left => _startPosX - EntityLainer.Step > 0,
|
||||||
|
//ââåðõ
|
||||||
|
DirectionType.Up => _startPosY - EntityLainer.Step > 0,
|
||||||
|
// âïðàâî
|
||||||
|
DirectionType.Right => _startPosX + _LainerWidth + EntityLainer.Step < _pictureWidth,
|
||||||
|
//âíèç
|
||||||
|
DirectionType.Down => _startPosY + _LainerHeight + EntityLainer.Step < _pictureHeight,
|
||||||
|
_ => false,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
public void MoveTransport(DirectionType direction)
|
||||||
|
{
|
||||||
|
if (!CanMove(direction) || EntityLainer == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (direction)
|
||||||
|
{
|
||||||
|
//âëåâî
|
||||||
|
case DirectionType.Left:
|
||||||
|
if (_startPosX - EntityLainer.Step > 0)
|
||||||
|
{
|
||||||
|
_startPosX -= (int)EntityLainer.Step;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_startPosX = 1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
//ââåðõ
|
||||||
|
case DirectionType.Up:
|
||||||
|
if (_startPosY - EntityLainer.Step > 0)
|
||||||
|
{
|
||||||
|
_startPosY -= (int)EntityLainer.Step;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_startPosY = 1;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
// âïðàâî
|
||||||
|
case DirectionType.Right:
|
||||||
|
if (_startPosX + EntityLainer.Step <= _pictureWidth - _LainerWidth)
|
||||||
|
{
|
||||||
|
_startPosX += (int)EntityLainer.Step;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_startPosX = _pictureWidth - _LainerWidth;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
//âíèç
|
||||||
|
case DirectionType.Down:
|
||||||
|
if (_startPosY + EntityLainer.Step < _pictureHeight - _LainerHeight)
|
||||||
|
{
|
||||||
|
_startPosY += (int)EntityLainer.Step;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
_startPosY = _pictureHeight - _LainerHeight;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
32
lainer/Lainer1/DrawingObjectLainer.cs
Normal file
32
lainer/Lainer1/DrawingObjectLainer.cs
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
using ProjectLainer.MovementStrategy;
|
||||||
|
using ProjectLainer.DrawningObjects;
|
||||||
|
using ProjectLainer.DrawningObjects;
|
||||||
|
namespace ProjectLainer.MovementStrategy
|
||||||
|
{
|
||||||
|
public class DrawningObjectLainer : IMoveableObject
|
||||||
|
{
|
||||||
|
private readonly DrawingLainer? _drawningLainer = null;
|
||||||
|
public DrawningObjectLainer(DrawingLainer drawningLainer)
|
||||||
|
{
|
||||||
|
_drawningLainer = drawningLainer;
|
||||||
|
}
|
||||||
|
public ObjectParameters? GetObjectPosition
|
||||||
|
{
|
||||||
|
get
|
||||||
|
{
|
||||||
|
if (_drawningLainer == null || _drawningLainer.EntityLainer == null)
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return new ObjectParameters(_drawningLainer.GetPosX,
|
||||||
|
_drawningLainer.GetPosY, _drawningLainer.GetWidth, _drawningLainer.GetHeight);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public int GetStep => (int)(_drawningLainer?.EntityLainer?.Step ?? 0);
|
||||||
|
public bool CheckCanMove(DirectionType direction) =>
|
||||||
|
_drawningLainer?.CanMove(direction) ?? false;
|
||||||
|
public void MoveObject(DirectionType direction) =>
|
||||||
|
_drawningLainer?.MoveTransport(direction);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
52
lainer/Lainer1/DrawingSuperLainer.cs
Normal file
52
lainer/Lainer1/DrawingSuperLainer.cs
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
using ProjectLainer.Entities;
|
||||||
|
namespace ProjectLainer.DrawningObjects
|
||||||
|
{
|
||||||
|
public class DrawningSuperLainer : DrawingLainer
|
||||||
|
{
|
||||||
|
public DrawningSuperLainer(int speed, double weight, Color bodyColor, Color
|
||||||
|
additionalColor, bool pools, bool decks, int width, int height) : base(speed, weight, bodyColor, width, height, 110, 60)
|
||||||
|
{
|
||||||
|
if (EntityLainer != null)
|
||||||
|
{
|
||||||
|
EntityLainer = new EntitySuperLainer(speed, weight, bodyColor,
|
||||||
|
additionalColor, pools, decks);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public override void DrawTransport(Graphics g)
|
||||||
|
{
|
||||||
|
if (EntityLainer is not EntitySuperLainer superlainer)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
base.DrawTransport(g);
|
||||||
|
Brush brBlue = new SolidBrush(Color.LightBlue);
|
||||||
|
Pen pen = new(Color.Black);
|
||||||
|
Brush additionalBrush = new SolidBrush(superlainer.AdditionalColor);
|
||||||
|
if (superlainer.Decks)
|
||||||
|
{
|
||||||
|
Point point1 = new Point(_startPosX, _startPosY + 10);
|
||||||
|
Point point2 = new Point(_startPosX + GetWidth, _startPosY + 10);
|
||||||
|
Point point3 = new Point(_startPosX + 20, _startPosY + 30);
|
||||||
|
Point point4 = new Point(_startPosX + 80, _startPosY + 30);
|
||||||
|
Point[] points = { point1, point2, point4, point3 };
|
||||||
|
g.DrawPolygon(pen, points);
|
||||||
|
g.FillPolygon(additionalBrush, points);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Point point3 = new Point(_startPosX, _startPosY + 30);
|
||||||
|
Point point4 = new Point(_startPosX + GetWidth, _startPosY + 30);
|
||||||
|
Point point1 = new Point(_startPosX + 20, _startPosY + 10);
|
||||||
|
Point point2 = new Point(_startPosX + 80, _startPosY + 10);
|
||||||
|
Point[] points = { point1, point2, point4, point3 };
|
||||||
|
g.DrawPolygon(pen, points);
|
||||||
|
g.FillPolygon(additionalBrush, points);
|
||||||
|
}
|
||||||
|
for (int i = 2; i < 5; i++)
|
||||||
|
{
|
||||||
|
g.FillEllipse(brBlue, _startPosX + i * 16, _startPosY + 15, 12, 12);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,23 +1,16 @@
|
|||||||
namespace ProjectLainer
|
namespace ProjectLainer.Entities
|
||||||
{
|
{
|
||||||
public class EntityLainer
|
public class EntityLainer
|
||||||
{
|
{
|
||||||
public int Speed { get; private set; }
|
public int Speed { get; private set; }
|
||||||
public double Weight { get; private set; }
|
public double Weight { get; private set; }
|
||||||
public Color BodyColor { get; private set; }
|
public Color BodyColor { get; private set; }
|
||||||
public Color AdditionalColor { get; private set; }
|
|
||||||
public bool Pool { get; private set; }
|
|
||||||
public bool Decks { get; private set; }
|
|
||||||
public double Step => (double)Speed * 100 / Weight;
|
public double Step => (double)Speed * 100 / Weight;
|
||||||
public void Init(int speed, double weight, Color bodyColor, Color
|
public EntityLainer(int speed, double weight, Color bodyColor)
|
||||||
additionalColor, bool ispool, bool addDecks)
|
|
||||||
{
|
{
|
||||||
Speed = speed;
|
Speed = speed;
|
||||||
Weight = weight;
|
Weight = weight;
|
||||||
BodyColor = bodyColor;
|
BodyColor = bodyColor;
|
||||||
AdditionalColor = additionalColor;
|
|
||||||
Pool = ispool;
|
|
||||||
Decks = addDecks;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user