2 реализация абстрактного класса с различной прорисовкой карты.
This commit is contained in:
parent
e33395b57d
commit
4b474bc9fb
@ -32,6 +32,60 @@ namespace AirplaneWithRadar
|
||||
public Bitmap MoveObject(Direction direction)
|
||||
{
|
||||
// TODO проверка, что объект может переместится в требуемом направлении
|
||||
|
||||
if (direction == Direction.Right)
|
||||
{
|
||||
for (int i = (int)(_drawingObject.GetCurrentPosition().Right / _size_x + 1); i < _drawingObject.GetCurrentPosition().Right + _drawingObject.Step / _size_x + 1; i++)
|
||||
{
|
||||
for (int j = (int)(_drawingObject.GetCurrentPosition().Top / _size_y + 1 ); j < _drawingObject.GetCurrentPosition().Bottom / _size_y + 1; j++)
|
||||
{
|
||||
if (_map[i, j] == _barrier)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (direction == Direction.Up)
|
||||
{
|
||||
for (int i = (int)(_drawingObject.GetCurrentPosition().Top - _drawingObject.Step / _size_y); i < _drawingObject.GetCurrentPosition().Top / _size_y; i++)
|
||||
{
|
||||
for (int j = (int)(_drawingObject.GetCurrentPosition().Left / _size_x); j < _drawingObject.GetCurrentPosition().Right / _size_x; j++)
|
||||
{
|
||||
if (_map[i, j] == _barrier)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (direction == Direction.Left)
|
||||
{
|
||||
for (int i = (int)(_drawingObject.GetCurrentPosition().Left - _drawingObject.Step / _size_x); i < _drawingObject.GetCurrentPosition().Left / _size_x; i++)
|
||||
{
|
||||
for (int j = (int)(_drawingObject.GetCurrentPosition().Top / _size_y); j < _drawingObject.GetCurrentPosition().Bottom / _size_y; j++)
|
||||
{
|
||||
if (_map[i, j] == _barrier)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (direction == Direction.Down)
|
||||
{
|
||||
|
||||
for (int i = (int)(_drawingObject.GetCurrentPosition().Bottom / _size_y); i < _drawingObject.GetCurrentPosition().Bottom + _drawingObject.Step / _size_y; i++)
|
||||
{
|
||||
for (int j = (int)(_drawingObject.GetCurrentPosition().Left / _size_x); j < _drawingObject.GetCurrentPosition().Right / _size_x; j++)
|
||||
{
|
||||
if (_map[i, j] == _barrier)
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
if (true)
|
||||
{
|
||||
_drawingObject.MoveObject(direction);
|
||||
@ -47,6 +101,16 @@ namespace AirplaneWithRadar
|
||||
int x = _random.Next(0, 10);
|
||||
int y = _random.Next(0, 10);
|
||||
_drawingObject.SetObject(x, y, _width, _height);
|
||||
for (int i = (int)(_drawingObject.GetCurrentPosition().Left/_size_x); i < _drawingObject.GetCurrentPosition().Right/_size_x; i++)
|
||||
{
|
||||
for (int j = (int)(_drawingObject.GetCurrentPosition().Top/_size_y); j < _drawingObject.GetCurrentPosition().Bottom/_size_y; j++)
|
||||
{
|
||||
if (_map[i,j] == _barrier)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
// TODO проверка, что объект не "накладывается" на закрытые участки
|
||||
return true;
|
||||
}
|
||||
|
@ -14,13 +14,13 @@ namespace AirplaneWithRadar
|
||||
/// <summary>
|
||||
/// Класс-сущность
|
||||
/// </summary>
|
||||
public EntityAirplane Airplane { protected set; get; }
|
||||
public EntityAirplane Airplane { get; protected set; }
|
||||
/// <summary>
|
||||
/// Левая координата отрисовки самолета
|
||||
/// Левая координата отрисовки автомобиля
|
||||
/// </summary>
|
||||
protected float _startPosX;
|
||||
/// <summary>
|
||||
/// Верхняя кооридната отрисовки самолета
|
||||
/// Верхняя кооридната отрисовки автомобиля
|
||||
/// </summary>
|
||||
protected float _startPosY;
|
||||
/// <summary>
|
||||
@ -32,18 +32,18 @@ namespace AirplaneWithRadar
|
||||
/// </summary>
|
||||
private int? _pictureHeight = null;
|
||||
/// <summary>
|
||||
/// Ширина отрисовки самолета
|
||||
/// Ширина отрисовки автомобиля
|
||||
/// </summary>
|
||||
private readonly int _airplaneWidth = 303;
|
||||
/// <summary>
|
||||
/// Высота отрисовки самолета
|
||||
/// Высота отрисовки автомобиля
|
||||
/// </summary>
|
||||
private readonly int _airplaneHeight = 102;
|
||||
private readonly int _airplaneHeight = 107;
|
||||
/// <summary>
|
||||
/// Инициализация свойств
|
||||
/// </summary>
|
||||
/// <param name="speed">Скорость</param>
|
||||
/// <param name="weight">Вес самолета</param>
|
||||
/// <param name="weight">Вес автомобиля</param>
|
||||
/// <param name="bodyColor">Цвет кузова</param>
|
||||
public DrawingAirplane(int speed, float weight, Color bodyColor)
|
||||
{
|
||||
@ -55,16 +55,16 @@ namespace AirplaneWithRadar
|
||||
/// <param name="speed">Скорость</param>
|
||||
/// <param name="weight">Вес автомобиля</param>
|
||||
/// <param name="bodyColor">Цвет кузова</param>
|
||||
/// <param name="carWidth">Ширина отрисовки автомобиля</param>
|
||||
/// <param name="carHeight">Высота отрисовки автомобиля</param>
|
||||
protected DrawingAirplane(int speed, float weight, Color bodyColor, int airplaneWidth, int airplaneHeight) : this(speed, weight, bodyColor)
|
||||
/// <param name="airplaneWidth">Ширина отрисовки автомобиля</param>
|
||||
/// <param name="airplaneHeight">Высота отрисовки автомобиля</param>
|
||||
protected DrawingAirplane(int speed, float weight, Color bodyColor, int airplaneWidth, int airplaneHeight) :
|
||||
this(speed, weight, bodyColor)
|
||||
{
|
||||
_airplaneWidth = airplaneWidth;
|
||||
_airplaneHeight = airplaneHeight;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Установка позиции самолета
|
||||
/// Установка позиции автомобиля
|
||||
/// </summary>
|
||||
/// <param name="x">Координата X</param>
|
||||
/// <param name="y">Координата Y</param>
|
||||
@ -72,7 +72,7 @@ namespace AirplaneWithRadar
|
||||
/// <param name="height">Высота картинки</param>
|
||||
public void SetPosition(int x, int y, int width, int height)
|
||||
{
|
||||
// TODO проверки
|
||||
// TODO checks
|
||||
if (x > 0 && x < width)
|
||||
{
|
||||
_startPosX = x;
|
||||
@ -91,9 +91,13 @@ namespace AirplaneWithRadar
|
||||
}
|
||||
|
||||
|
||||
//_startPosX = x;
|
||||
//_startPosY = y;
|
||||
//_pictureWidth = width;
|
||||
//_pictureHeight = height;
|
||||
}
|
||||
/// <summary>
|
||||
/// Изменение направления перемещения
|
||||
/// Изменение направления пермещения
|
||||
/// </summary>
|
||||
/// <param name="direction">Направление</param>
|
||||
public void MoveTransport(Direction direction)
|
||||
@ -181,7 +185,6 @@ namespace AirplaneWithRadar
|
||||
g.FillRectangle(brBlack, _startPosX + 90, _startPosY + 67, 90, 8);
|
||||
g.FillEllipse(brBlack, _startPosX + 83, _startPosY + 66, 9, 9);
|
||||
g.FillEllipse(brBlack, _startPosX + 175, _startPosY + 66, 9, 9);
|
||||
|
||||
}
|
||||
/// <summary>
|
||||
/// Смена границ формы отрисовки
|
||||
@ -213,7 +216,7 @@ namespace AirplaneWithRadar
|
||||
/// <returns></returns>
|
||||
public (float Left, float Right, float Top, float Bottom) GetCurrentPosition()
|
||||
{
|
||||
return (_startPosX, _startPosY, _startPosX + _airplaneWidth, _startPosY + _airplaneHeight);
|
||||
return (_startPosX, _startPosX + _airplaneWidth, _startPosY, _startPosY + _airplaneHeight);
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -12,15 +12,16 @@ namespace AirplaneWithRadar
|
||||
/// Инициализация свойств
|
||||
/// </summary>
|
||||
/// <param name="speed">Скорость</param>
|
||||
/// <param name="weight">Вес самолета</param>
|
||||
/// <param name="bodyColor">Цвет самолета</param>
|
||||
/// <param name="weight">Вес автомобиля</param>
|
||||
/// <param name="bodyColor">Цвет кузова</param>
|
||||
/// <param name="dopColor">Дополнительный цвет</param>
|
||||
/// <param name="radar">Признак наличия радара</param>
|
||||
/// <param name="extraFuelTank">Признак наличия дополнительных топливных баков</param>
|
||||
public DrawingAirplaneWithRadar(int speed, float weight, Color bodyColor, Color dopColor, bool radar, bool extraFuelTank) : base(speed, weight, bodyColor, 110, 60)
|
||||
/// <param name="radar">Признак наличия обвеса</param>
|
||||
/// <param name="extraFuelTank">Признак наличия антикрыла</param>
|
||||
public DrawingAirplaneWithRadar(int speed, float weight, Color bodyColor, Color dopColor, bool radar, bool extraFuelTank) : base(speed, weight, bodyColor, 303, 102)
|
||||
{
|
||||
Airplane = new EntityAirplaneWithRadar(speed, weight, bodyColor, dopColor, radar, extraFuelTank);
|
||||
}
|
||||
|
||||
public override void DrawTransport(Graphics g)
|
||||
{
|
||||
if (Airplane is not EntityAirplaneWithRadar airplaneWithRadar)
|
||||
|
@ -28,7 +28,7 @@ namespace AirplaneWithRadar
|
||||
}
|
||||
public void DrawingObject(Graphics g)
|
||||
{
|
||||
// TODO
|
||||
_airplane.DrawTransport(g);
|
||||
}
|
||||
|
||||
}
|
||||
|
@ -43,5 +43,7 @@ namespace AirplaneWithRadar
|
||||
BodyColor = bodyColor;
|
||||
}
|
||||
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -13,11 +13,11 @@ namespace AirplaneWithRadar
|
||||
/// </summary>
|
||||
public Color DopColor { get; private set; }
|
||||
/// <summary>
|
||||
/// Признак наличия радара
|
||||
/// Признак наличия обвеса
|
||||
/// </summary>
|
||||
public bool Radar { get; private set; }
|
||||
/// <summary>
|
||||
/// Признак наличия дополнительных топливных баков
|
||||
/// Признак наличия антикрыла
|
||||
/// </summary>
|
||||
public bool ExtraFuelTank { get; private set; }
|
||||
/// <summary>
|
||||
@ -27,8 +27,8 @@ namespace AirplaneWithRadar
|
||||
/// <param name="weight">Вес автомобиля</param>
|
||||
/// <param name="bodyColor">Цвет кузова</param>
|
||||
/// <param name="dopColor">Дополнительный цвет</param>
|
||||
/// <param name="radar">Признак наличия радара</param>
|
||||
/// <param name="extraFuelTank">Признак наличия дополнительных топливных баков</param>
|
||||
/// <param name="radar">Признак наличия обвеса</param>
|
||||
/// <param name="extraFuelTank">Признак наличия антикрыла</param>
|
||||
public EntityAirplaneWithRadar(int speed, float weight, Color bodyColor, Color dopColor, bool radar, bool extraFuelTank) : base(speed, weight, bodyColor)
|
||||
{
|
||||
DopColor = dopColor;
|
||||
@ -36,5 +36,6 @@ namespace AirplaneWithRadar
|
||||
ExtraFuelTank = extraFuelTank;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -25,6 +25,7 @@ namespace AirplaneWithRadar
|
||||
private void SetData()
|
||||
{
|
||||
Random rnd = new();
|
||||
|
||||
_airplane.SetPosition(rnd.Next(10, 100), rnd.Next(10, 100), pictureBoxAirplane.Width, pictureBoxAirplane.Height);
|
||||
toolStripStatusLabelSpeed.Text = $"Ñêîðîñòü: {_airplane.Airplane.Speed}";
|
||||
toolStripStatusLabelWeight.Text = $"Âåñ: {_airplane.Airplane.Weight}";
|
||||
@ -37,6 +38,7 @@ namespace AirplaneWithRadar
|
||||
/// <param name="e"></param>
|
||||
private void ButtonCreate_Click(object sender, EventArgs e)
|
||||
{
|
||||
|
||||
Random rnd = new();
|
||||
_airplane = new DrawingAirplane(rnd.Next(100, 300), rnd.Next(1000, 2000), Color.FromArgb(rnd.Next(0, 256), rnd.Next(0, 256), rnd.Next(0, 256)));
|
||||
SetData();
|
||||
|
@ -158,7 +158,8 @@
|
||||
this.comboBoxSelectorMap.DropDownStyle = System.Windows.Forms.ComboBoxStyle.DropDownList;
|
||||
this.comboBoxSelectorMap.FormattingEnabled = true;
|
||||
this.comboBoxSelectorMap.Items.AddRange(new object[] {
|
||||
"Простая карта"});
|
||||
"Простая карта",
|
||||
"Собственная карта"});
|
||||
this.comboBoxSelectorMap.Location = new System.Drawing.Point(12, 12);
|
||||
this.comboBoxSelectorMap.Name = "comboBoxSelectorMap";
|
||||
this.comboBoxSelectorMap.Size = new System.Drawing.Size(182, 33);
|
||||
|
@ -74,8 +74,8 @@ namespace AirplaneWithRadar
|
||||
private void ButtonCreateModif_Click(object sender, EventArgs e)
|
||||
{
|
||||
Random rnd = new();
|
||||
var airplane = new DrawingAirplaneWithRadar(rnd.Next(100, 300), rnd.Next(1000, 2000), Color.FromArgb(rnd.Next(0, 256), rnd.Next(0, 256), rnd.Next(0,256)),
|
||||
Color.FromArgb(rnd.Next(0, 256), rnd.Next(0, 256), rnd.Next(0, 256)),Convert.ToBoolean(rnd.Next(0, 2)), Convert.ToBoolean(rnd.Next(0,2)));
|
||||
var airplane = new DrawingAirplaneWithRadar(rnd.Next(100, 300), rnd.Next(1000, 2000), Color.FromArgb(rnd.Next(0, 256), rnd.Next(0, 256), rnd.Next(0, 256)),
|
||||
Color.FromArgb(rnd.Next(0, 256), rnd.Next(0, 256), rnd.Next(0, 256)), Convert.ToBoolean(rnd.Next(0, 2)), Convert.ToBoolean(rnd.Next(0, 2)));
|
||||
SetData(airplane);
|
||||
|
||||
}
|
||||
@ -93,6 +93,9 @@ namespace AirplaneWithRadar
|
||||
case "Простая карта":
|
||||
_abstractMap = new SimpleMap();
|
||||
break;
|
||||
case "Собственная карта":
|
||||
_abstractMap = new MyMap();
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
91
AirplaneWithRadar/AirplaneWithRadar/MyMap.cs
Normal file
91
AirplaneWithRadar/AirplaneWithRadar/MyMap.cs
Normal file
@ -0,0 +1,91 @@
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AirplaneWithRadar
|
||||
{
|
||||
/// <summary>
|
||||
/// Собственная реализация абсрактного класса AbstractMap
|
||||
/// </summary>
|
||||
internal class MyMap : AbstractMap
|
||||
{
|
||||
/// <summary>
|
||||
/// Цвет участка закрытого
|
||||
/// </summary>
|
||||
private readonly Brush barrierColor = new SolidBrush(Color.White);
|
||||
/// <summary>
|
||||
/// Цвет участка открытого
|
||||
/// </summary>
|
||||
private readonly Brush roadColor = new SolidBrush(Color.Blue);
|
||||
protected override void DrawBarrierPart(Graphics g, int i, int j)
|
||||
{
|
||||
g.FillRectangle(barrierColor, i * _size_x, j * _size_y, i * (_size_x + 1), j * (_size_y + 1));
|
||||
}
|
||||
protected override void DrawRoadPart(Graphics g, int i, int j)
|
||||
{
|
||||
g.FillRectangle(roadColor, i * _size_x, j * _size_y, i * (_size_x + 1), j * (_size_y + 1));
|
||||
}
|
||||
protected override void GenerateMap()
|
||||
{
|
||||
_map = new int[100, 100];
|
||||
_size_x = (float)_width / _map.GetLength(0);
|
||||
_size_y = (float)_height / _map.GetLength(1);
|
||||
//int counter = 0;
|
||||
for (int i = 0; i < _map.GetLength(0); ++i)
|
||||
{
|
||||
for (int j = 0; j < _map.GetLength(1); ++j)
|
||||
{
|
||||
_map[i, j] = _freeRoad;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
int counter = 0;
|
||||
|
||||
for (int j = 0; j < _map.GetLength(1); j++)
|
||||
{
|
||||
int startX = _random.Next(0, 80);
|
||||
int x = _random.Next(0, 20);
|
||||
counter = 0;
|
||||
while (counter < x)
|
||||
{
|
||||
for (int i = startX; i < startX + x; i++)
|
||||
{
|
||||
_map[i, j] = _barrier;
|
||||
counter++;
|
||||
}
|
||||
}
|
||||
j++;
|
||||
}
|
||||
//for (int i = 0; i < _map.GetLength(0); ++i)
|
||||
//{
|
||||
// int startX = _random.Next(0, 90);
|
||||
// int x = _random.Next(0, 100 - startX - 10);
|
||||
// counter = x;
|
||||
// while (counter > 0)
|
||||
// {
|
||||
// for (int j = 0; j < _map.GetLength(1); ++j)
|
||||
// {
|
||||
// _map[i, j] = _barrier;
|
||||
// counter--;
|
||||
// }
|
||||
// }
|
||||
|
||||
//}
|
||||
//while (counter < 50)
|
||||
//{
|
||||
// int x = _random.Next(0, 100);
|
||||
// int y = _random.Next(0, 100);
|
||||
// if (_map[x, y] == _freeRoad)
|
||||
// {
|
||||
// _map[x, y] = _barrier;
|
||||
// counter++;
|
||||
// }
|
||||
//}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -21,13 +21,11 @@ namespace AirplaneWithRadar
|
||||
private readonly Brush roadColor = new SolidBrush(Color.Gray);
|
||||
protected override void DrawBarrierPart(Graphics g, int i, int j)
|
||||
{
|
||||
g.FillRectangle(barrierColor, i * _size_x, j * _size_y, i * (_size_x +
|
||||
1), j * (_size_y + 1));
|
||||
g.FillRectangle(barrierColor, i * _size_x, j * _size_y, i * (_size_x + 1), j * (_size_y + 1));
|
||||
}
|
||||
protected override void DrawRoadPart(Graphics g, int i, int j)
|
||||
{
|
||||
g.FillRectangle(roadColor, i * _size_x, j * _size_y, i * (_size_x +
|
||||
1), j * (_size_y + 1));
|
||||
g.FillRectangle(roadColor, i * _size_x, j * _size_y, i * (_size_x + 1), j * (_size_y + 1));
|
||||
}
|
||||
protected override void GenerateMap()
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user