LabWork04 #5

Merged
ShuryginDima merged 9 commits from LabWork04 into LabWork05 2024-04-21 15:58:46 +04:00
Showing only changes of commit 8b930c99d4 - Show all commits

View File

@ -66,10 +66,19 @@ public class DrawningSeaplane
/// <returns>true - границы заданы, false - проверка не пройдена, нельзя разместить объект в этих размерах</returns>
public bool SetPictureSize(int width, int height)
{
// TODO проверка, что объект "влезает" в размеры поля
// если влезает, сохраняем границы и корректируем позицию объекта, если она была уже установлена
if (height < _drawningSeaplaneHeight || width < _drawningSeaplaneWidth)
{
return false;
}
_pictureWidth = width;
_pictureHeight = height;
if (_startPosX.HasValue && _drawningSeaplaneWidth + _startPosX > width) _startPosX = _pictureWidth - _drawningSeaplaneWidth;
if (_startPosY.HasValue && _drawningSeaplaneHeight + _startPosY > height) _startPosY = _pictureHeight - _drawningSeaplaneHeight;
return true;
}
@ -84,8 +93,22 @@ public class DrawningSeaplane
{
return;
}
// TODO если при установке объекта в эти координаты, он будет "выходить" за границы формы
// то надо изменить координаты, чтобы он оставался в этих границах
if (x < 0)
{
x = 0;
}
if (x + _drawningSeaplaneWidth > _pictureWidth.Value)
{
x = _pictureWidth.Value - _drawningSeaplaneWidth;
}
if (y < 0)
{
y = 0;
}
if (y + _drawningSeaplaneHeight > _pictureHeight.Value)
{
y = _pictureHeight.Value - _drawningSeaplaneHeight;
}
_startPosX = x;
_startPosY = y;