Сделана проверка при движении объекта и его создании.
This commit is contained in:
parent
d0c4dedf44
commit
cf067f83de
@ -32,20 +32,80 @@ namespace WarmlyLocomotive
|
|||||||
public Bitmap MoveObject(Direction direction)
|
public Bitmap MoveObject(Direction direction)
|
||||||
{
|
{
|
||||||
// TODO проверка, что объект может переместится в требуемом направлении
|
// TODO проверка, что объект может переместится в требуемом направлении
|
||||||
if (true)
|
(float leftX, float topY, float rightX, float bottomY) = _drawningObject.GetCurrentPosition();
|
||||||
|
for (int i = 0; i < _map.GetLength(0); ++i)
|
||||||
{
|
{
|
||||||
_drawningObject.MoveObject(direction);
|
for (int j = 0; j < _map.GetLength(1); ++j)
|
||||||
|
{
|
||||||
|
if (_map[i,j] == _barrier)
|
||||||
|
{
|
||||||
|
switch (direction)
|
||||||
|
{
|
||||||
|
case Direction.Up:
|
||||||
|
if(_size_y * (j+1) >= topY - _drawningObject.Step && _size_y * (j+1) < topY && _size_x * (i + 1) > leftX
|
||||||
|
&& _size_x * (i + 1) <= rightX)
|
||||||
|
{
|
||||||
|
return DrawMapWithObject();
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
case Direction.Down:
|
||||||
|
if (_size_y * j <= bottomY + _drawningObject.Step && _size_y * j > bottomY && _size_x * (i+1) > leftX
|
||||||
|
&& _size_x * (i+1) <= rightX)
|
||||||
|
{
|
||||||
|
return DrawMapWithObject();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case Direction.Left:
|
||||||
|
if (_size_x * (i+1) >= leftX - _drawningObject.Step && _size_x * (i + 1) < leftX && _size_y * (j + 1) < bottomY
|
||||||
|
&& _size_y * (j + 1) >= topY)
|
||||||
|
{
|
||||||
|
return DrawMapWithObject();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case Direction.Right:
|
||||||
|
if (_size_x * i <= rightX + _drawningObject.Step && _size_x * i > leftX && _size_y * (j + 1) < bottomY
|
||||||
|
&& _size_y * (j + 1) >= topY)
|
||||||
|
{
|
||||||
|
return DrawMapWithObject();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
_drawningObject.MoveObject(direction);
|
||||||
return DrawMapWithObject();
|
return DrawMapWithObject();
|
||||||
}
|
}
|
||||||
private bool SetObjectOnMap()
|
private bool SetObjectOnMap()
|
||||||
{
|
{
|
||||||
|
(float currentX, float currentY, float locomotiveWidth, float locomotiveHeight) = _drawningObject.GetCurrentPosition();
|
||||||
if (_drawningObject == null || _map == null)
|
if (_drawningObject == null || _map == null)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
if(currentX != 0)
|
||||||
|
{
|
||||||
|
locomotiveWidth -= currentX;
|
||||||
|
}
|
||||||
|
if (currentY != 0)
|
||||||
|
{
|
||||||
|
locomotiveHeight -= currentY;
|
||||||
|
}
|
||||||
int x = _random.Next(0, 10);
|
int x = _random.Next(0, 10);
|
||||||
int y = _random.Next(0, 10);
|
int y = _random.Next(0, 10);
|
||||||
|
for (int i = 0; i < _map.GetLength(0); ++i)
|
||||||
|
{
|
||||||
|
for (int j = 0; j < _map.GetLength(1); ++j)
|
||||||
|
{
|
||||||
|
if (_map[i,j] == _barrier)
|
||||||
|
{
|
||||||
|
if(x + locomotiveWidth >= _size_x * i && x <= _size_x * i && y + locomotiveHeight > _size_y * j && y <= _size_y * j)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
_drawningObject.SetObject(x, y, _width, _height);
|
_drawningObject.SetObject(x, y, _width, _height);
|
||||||
// TODO првоерка, что объект не "накладывается" на закрытые участки
|
// TODO првоерка, что объект не "накладывается" на закрытые участки
|
||||||
return true;
|
return true;
|
||||||
|
@ -127,13 +127,13 @@ namespace WarmlyLocomotive
|
|||||||
Pen pen = new(Color.Black);
|
Pen pen = new(Color.Black);
|
||||||
Brush br = new SolidBrush(Locomotive?.BodyColor ?? Color.Black);
|
Brush br = new SolidBrush(Locomotive?.BodyColor ?? Color.Black);
|
||||||
//кузов
|
//кузов
|
||||||
PointF[] polygon_points = new PointF[4];
|
PointF[] polygonPoints = new PointF[4];
|
||||||
polygon_points[0] = new PointF(_startPosX + 10, _startPosY);
|
polygonPoints[0] = new PointF(_startPosX + 10, _startPosY);
|
||||||
polygon_points[1] = new PointF(_startPosX + 190, _startPosY);
|
polygonPoints[1] = new PointF(_startPosX + 190, _startPosY);
|
||||||
polygon_points[2] = new PointF(_startPosX + 210, _startPosY + 40);
|
polygonPoints[2] = new PointF(_startPosX + 210, _startPosY + 40);
|
||||||
polygon_points[3] = new PointF(_startPosX + 10, _startPosY + 40);
|
polygonPoints[3] = new PointF(_startPosX + 10, _startPosY + 40);
|
||||||
g.FillPolygon(br, polygon_points);
|
g.FillPolygon(br, polygonPoints);
|
||||||
g.DrawPolygon(pen, polygon_points);
|
g.DrawPolygon(pen, polygonPoints);
|
||||||
g.FillRectangle(br, _startPosX + 10, _startPosY + 40, 200, 40);
|
g.FillRectangle(br, _startPosX + 10, _startPosY + 40, 200, 40);
|
||||||
g.DrawRectangle(pen, _startPosX + 10, _startPosY + 40, 200, 40);
|
g.DrawRectangle(pen, _startPosX + 10, _startPosY + 40, 200, 40);
|
||||||
//колеса
|
//колеса
|
||||||
@ -142,6 +142,11 @@ namespace WarmlyLocomotive
|
|||||||
g.FillEllipse(brGray, _startPosX + 70, _startPosY + 80, 30, 25);
|
g.FillEllipse(brGray, _startPosX + 70, _startPosY + 80, 30, 25);
|
||||||
g.FillEllipse(brGray, _startPosX + 130, _startPosY + 80, 30, 25);
|
g.FillEllipse(brGray, _startPosX + 130, _startPosY + 80, 30, 25);
|
||||||
g.FillEllipse(brGray, _startPosX + 170, _startPosY + 80, 30, 25);
|
g.FillEllipse(brGray, _startPosX + 170, _startPosY + 80, 30, 25);
|
||||||
|
Pen dopPen = new(Color.Black, 2);
|
||||||
|
g.DrawEllipse(dopPen, _startPosX + 30, _startPosY + 80, 30, 25);
|
||||||
|
g.DrawEllipse(dopPen, _startPosX + 70, _startPosY + 80, 30, 25);
|
||||||
|
g.DrawEllipse(dopPen, _startPosX + 130, _startPosY + 80, 30, 25);
|
||||||
|
g.DrawEllipse(dopPen, _startPosX + 170, _startPosY + 80, 30, 25);
|
||||||
//стекла и дверь
|
//стекла и дверь
|
||||||
Brush brBrown = new SolidBrush(Color.Brown);
|
Brush brBrown = new SolidBrush(Color.Brown);
|
||||||
g.FillRectangle(brBrown, _startPosX + 100, _startPosY + 20, 25, 45);
|
g.FillRectangle(brBrown, _startPosX + 100, _startPosY + 20, 25, 45);
|
||||||
|
Loading…
Reference in New Issue
Block a user