PIbd-21 Potapov N.S. LabWork02 Hard #2
82
ProjectStormtrooper/AbstractStrategy.java
Normal file
82
ProjectStormtrooper/AbstractStrategy.java
Normal file
@ -0,0 +1,82 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
public abstract class AbstractStrategy {
|
||||
private IMoveableObject _moveableObject;
|
||||
private Status _state = Status.NotInit;
|
||||
protected int FieldWidth;
|
||||
protected int FieldHeight;
|
||||
|
||||
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 (IsTargetDestination()) {
|
||||
_state = Status.Finish;
|
||||
return;
|
||||
}
|
||||
MoveToTarget();
|
||||
}
|
||||
|
||||
protected boolean MoveLeft() {
|
||||
return MoveTo(EnumDirectionType.Left);
|
||||
}
|
||||
|
||||
protected boolean MoveRight() {
|
||||
return MoveTo(EnumDirectionType.Right);
|
||||
}
|
||||
|
||||
protected boolean MoveUp() {
|
||||
return MoveTo(EnumDirectionType.Up);
|
||||
}
|
||||
|
||||
protected boolean MoveDown() {
|
||||
return MoveTo(EnumDirectionType.Down);
|
||||
}
|
||||
|
||||
protected ObjectParameters GetObjectParameters() {
|
||||
if (_moveableObject == null)
|
||||
return null;
|
||||
return _moveableObject.GetObjectPosition();
|
||||
}
|
||||
|
||||
protected Integer GetStep() {
|
||||
if (_state != Status.InProgress) {
|
||||
return null;
|
||||
}
|
||||
if (_moveableObject == null)
|
||||
return null;
|
||||
return _moveableObject.GetStep();
|
||||
}
|
||||
|
||||
protected abstract void MoveToTarget();
|
||||
|
||||
protected abstract boolean IsTargetDestination();
|
||||
|
||||
private boolean MoveTo(EnumDirectionType directionType) {
|
||||
if (_state != Status.InProgress) {
|
||||
return false;
|
||||
}
|
||||
if (_moveableObject == null)
|
||||
return false;
|
||||
if (_moveableObject.CheckCanMove(directionType)) {
|
||||
_moveableObject.MoveObject(directionType);
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
31
ProjectStormtrooper/DrawingEnginesEllipse.java
Normal file
31
ProjectStormtrooper/DrawingEnginesEllipse.java
Normal file
@ -0,0 +1,31 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawingEnginesEllipse implements IDrawingEngines {
|
||||
private EnumEnginesCount _enumEnginesCount;
|
||||
|
||||
@Override
|
||||
public void SetEnumEnginesCount(int enginesCount) {
|
||||
for (EnumEnginesCount val : EnumEnginesCount.values()) {
|
||||
if (val.count == enginesCount) {
|
||||
this._enumEnginesCount = val;
|
||||
return;
|
||||
}
|
||||
}
|
||||
this._enumEnginesCount = EnumEnginesCount.Two;
|
||||
}
|
||||
|
||||
@Override
|
||||
public EnumEnginesCount GetEnumEnginesCount() {
|
||||
return _enumEnginesCount;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void DrawEngine(Graphics2D g2d, Color color, int x, int y, int w, int h) {
|
||||
g2d.setColor(Color.WHITE);
|
||||
g2d.fillOval(x, y, w, h);
|
||||
g2d.setColor(Color.BLACK);
|
||||
g2d.drawOval(x, y, w, h);
|
||||
}
|
||||
}
|
39
ProjectStormtrooper/DrawingEnginesPyramid.java
Normal file
39
ProjectStormtrooper/DrawingEnginesPyramid.java
Normal file
@ -0,0 +1,39 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawingEnginesPyramid implements IDrawingEngines {
|
||||
private EnumEnginesCount _enumEnginesCount;
|
||||
|
||||
@Override
|
||||
public void SetEnumEnginesCount(int enginesCount) {
|
||||
for (EnumEnginesCount val : EnumEnginesCount.values()) {
|
||||
if (val.count == enginesCount) {
|
||||
this._enumEnginesCount = val;
|
||||
return;
|
||||
}
|
||||
}
|
||||
this._enumEnginesCount = EnumEnginesCount.Two;
|
||||
}
|
||||
|
||||
@Override
|
||||
public EnumEnginesCount GetEnumEnginesCount() {
|
||||
return _enumEnginesCount;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void DrawEngine(Graphics2D g2d, Color color, int x, int y, int w, int h) {
|
||||
Polygon enginePolygon = new Polygon();
|
||||
enginePolygon.addPoint(x, y + h / 2);
|
||||
enginePolygon.addPoint(x + w / 10, y);
|
||||
enginePolygon.addPoint(x + w - w / 2, y + h / 2);
|
||||
enginePolygon.addPoint(x + w, y);
|
||||
enginePolygon.addPoint(x + w, y + h);
|
||||
enginePolygon.addPoint(x + w - w / 2, y + h / 2);
|
||||
enginePolygon.addPoint(x + w / 10, y + h);
|
||||
g2d.setColor(Color.WHITE);
|
||||
g2d.fillPolygon(enginePolygon);
|
||||
g2d.setColor(Color.BLACK);
|
||||
g2d.drawPolygon(enginePolygon);
|
||||
}
|
||||
}
|
33
ProjectStormtrooper/DrawingEnginesSimple.java
Normal file
33
ProjectStormtrooper/DrawingEnginesSimple.java
Normal file
@ -0,0 +1,33 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawingEnginesSimple implements IDrawingEngines {
|
||||
private EnumEnginesCount _enumEnginesCount;
|
||||
|
||||
@Override
|
||||
public void SetEnumEnginesCount(int enginesCount) {
|
||||
for (EnumEnginesCount val : EnumEnginesCount.values()) {
|
||||
if (val.count == enginesCount) {
|
||||
this._enumEnginesCount = val;
|
||||
return;
|
||||
}
|
||||
}
|
||||
this._enumEnginesCount = EnumEnginesCount.Two;
|
||||
}
|
||||
|
||||
@Override
|
||||
public EnumEnginesCount GetEnumEnginesCount() {
|
||||
return _enumEnginesCount;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void DrawEngine(Graphics2D g2d, Color color, int x, int y, int w, int h) {
|
||||
g2d.setColor(Color.WHITE);
|
||||
g2d.fillRect(x, y, w, h);
|
||||
g2d.setColor(Color.BLACK);
|
||||
g2d.drawRect(x, y, w, h);
|
||||
g2d.setColor(color);
|
||||
g2d.fillRect(x, y, 6, h);
|
||||
}
|
||||
}
|
43
ProjectStormtrooper/DrawingObjectPlane.java
Normal file
43
ProjectStormtrooper/DrawingObjectPlane.java
Normal file
@ -0,0 +1,43 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
public class DrawingObjectPlane implements IMoveableObject {
|
||||
private DrawingPlane _drawingPlane;
|
||||
|
||||
public DrawingObjectPlane(DrawingPlane drawingPlane) {
|
||||
_drawingPlane = drawingPlane;
|
||||
}
|
||||
|
||||
@Override
|
||||
public ObjectParameters GetObjectPosition() {
|
||||
if (_drawingPlane == null || _drawingPlane.EntityPlane == null) {
|
||||
return null;
|
||||
}
|
||||
return new ObjectParameters(
|
||||
_drawingPlane.GetPosX(),
|
||||
_drawingPlane.GetPosY(),
|
||||
_drawingPlane.GetWidth(),
|
||||
_drawingPlane.GetHeight()
|
||||
);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int GetStep() {
|
||||
if (_drawingPlane != null)
|
||||
if (_drawingPlane.EntityPlane != null)
|
||||
return (int) _drawingPlane.EntityPlane.Step();
|
||||
return 0;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean CheckCanMove(EnumDirectionType direction) {
|
||||
if (_drawingPlane == null)
|
||||
return false;
|
||||
return _drawingPlane.CanMove(direction);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void MoveObject(EnumDirectionType direction) {
|
||||
if (_drawingPlane != null)
|
||||
_drawingPlane.MoveTransport(direction);
|
||||
}
|
||||
}
|
182
ProjectStormtrooper/DrawingPlane.java
Normal file
182
ProjectStormtrooper/DrawingPlane.java
Normal file
@ -0,0 +1,182 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
import java.awt.*;
|
||||
import java.util.Random;
|
||||
|
||||
public class DrawingPlane {
|
||||
public EntityPlane EntityPlane;
|
||||
protected IDrawingEngines _drawingEngines;
|
||||
protected int _pictureWidth;
|
||||
protected int _pictureHeight;
|
||||
protected int _startPosX;
|
||||
protected int _startPosY;
|
||||
protected int _planeWidth = 110;
|
||||
protected int _planeHeight = 110;
|
||||
|
||||
public int GetPosX() {
|
||||
return _startPosX;
|
||||
}
|
||||
|
||||
public int GetPosY() {
|
||||
return _startPosY;
|
||||
}
|
||||
|
||||
public int GetWidth() {
|
||||
return _planeWidth;
|
||||
}
|
||||
|
||||
public int GetHeight() {
|
||||
return _planeHeight;
|
||||
}
|
||||
|
||||
public DrawingPlane(int speed, double weight, Color bodyColor, int width, int height) {
|
||||
if (width < _planeWidth && height < _planeHeight) {
|
||||
return;
|
||||
}
|
||||
_pictureWidth = width;
|
||||
_pictureHeight = height;
|
||||
EntityPlane = new EntityPlane(speed, weight, bodyColor);
|
||||
Random random = new Random();
|
||||
int drawingEnginesType = random.nextInt(0, 3);
|
||||
if (drawingEnginesType == 0)
|
||||
_drawingEngines = new DrawingEnginesSimple();
|
||||
else if (drawingEnginesType == 1)
|
||||
_drawingEngines = new DrawingEnginesPyramid();
|
||||
else if (drawingEnginesType == 2)
|
||||
_drawingEngines = new DrawingEnginesEllipse();
|
||||
}
|
||||
|
||||
protected DrawingPlane(int speed, double weight, Color bodyColor,
|
||||
int width, int height, int planeWidth, int planeHeight) {
|
||||
this(speed, weight, bodyColor, width, height);
|
||||
_planeWidth = planeWidth;
|
||||
_planeHeight = planeHeight;
|
||||
}
|
||||
public void SetEnginesCount(int enginesCount) {
|
||||
_drawingEngines.SetEnumEnginesCount(enginesCount);
|
||||
}
|
||||
|
||||
public boolean CanMove(EnumDirectionType direction) {
|
||||
if (EntityPlane == null) {
|
||||
return false;
|
||||
}
|
||||
boolean result = false;
|
||||
switch (direction) {
|
||||
case Up -> result = _startPosY - EntityPlane.Step() > 0;
|
||||
case Down -> result = _startPosY + _planeHeight + EntityPlane.Step() < _pictureHeight;
|
||||
case Left -> result = _startPosX - EntityPlane.Step() > 0;
|
||||
case Right -> result = _startPosX + _planeWidth + EntityPlane.Step() < _pictureWidth;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
|
||||
public void SetPosition(int x, int y) {
|
||||
if (x < 0) {
|
||||
x = 0;
|
||||
} else if (x > _pictureWidth - _planeWidth) {
|
||||
x = _pictureWidth - _planeWidth;
|
||||
}
|
||||
_startPosX = x;
|
||||
|
||||
if (y < 0) {
|
||||
y = 0;
|
||||
} else if (y > _pictureHeight - _planeHeight) {
|
||||
y = _pictureHeight - _planeHeight;
|
||||
}
|
||||
_startPosY = y;
|
||||
}
|
||||
|
||||
public void MoveTransport(EnumDirectionType direction) {
|
||||
if (EntityPlane == null) {
|
||||
return;
|
||||
}
|
||||
switch (direction) {
|
||||
case Up -> {
|
||||
if (_startPosY - EntityPlane.Step() >= 0) {
|
||||
_startPosY -= (int) EntityPlane.Step();
|
||||
}
|
||||
}
|
||||
case Down -> {
|
||||
if (_startPosY + _planeHeight + EntityPlane.Step() <= _pictureHeight) {
|
||||
_startPosY += (int) EntityPlane.Step();
|
||||
}
|
||||
}
|
||||
case Left -> {
|
||||
if (_startPosX - EntityPlane.Step() >= 0) {
|
||||
_startPosX -= (int) EntityPlane.Step();
|
||||
}
|
||||
}
|
||||
case Right -> {
|
||||
if (_startPosX + _planeWidth + EntityPlane.Step() <= _pictureWidth) {
|
||||
_startPosX += (int) EntityPlane.Step();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void DrawTransport(Graphics g) {
|
||||
if (EntityPlane == null) {
|
||||
return;
|
||||
}
|
||||
Graphics2D g2d = (Graphics2D) g;
|
||||
|
||||
Color bodyColor = EntityPlane.BodyColor;
|
||||
Color blackColor = Color.BLACK;
|
||||
|
||||
// Длина фюзеляжа
|
||||
int bodyHeight = _planeHeight / 9;
|
||||
int bodyWidth = _planeWidth - _planeWidth / 8;
|
||||
|
||||
_drawingEngines.DrawEngines(g, bodyColor, _startPosX, _startPosY, _planeWidth, _planeHeight);
|
||||
|
||||
// Рисуем нос
|
||||
Polygon cockPitPolygon = new Polygon();
|
||||
cockPitPolygon.addPoint(_startPosX, _startPosY + _planeHeight / 2);
|
||||
cockPitPolygon.addPoint(_startPosX + _planeWidth / 8, _startPosY + _planeHeight / 2 - bodyHeight / 2);
|
||||
cockPitPolygon.addPoint(_startPosX + _planeWidth / 8, _startPosY + _planeHeight / 2 + bodyHeight / 2);
|
||||
|
||||
g2d.setColor(blackColor);
|
||||
g2d.fillPolygon(cockPitPolygon);
|
||||
|
||||
// Рисуем крылья
|
||||
Polygon wingsPolygon = new Polygon();
|
||||
wingsPolygon.addPoint(_startPosX + _planeWidth / 2, _startPosY);
|
||||
wingsPolygon.addPoint(_startPosX + _planeWidth / 2 + _planeWidth / 15, _startPosY);
|
||||
wingsPolygon.addPoint(_startPosX + _planeWidth / 2 + _planeWidth / 6, _startPosY + _planeHeight / 2);
|
||||
wingsPolygon.addPoint(_startPosX + _planeWidth / 2 + _planeWidth / 15, _startPosY + _planeHeight);
|
||||
wingsPolygon.addPoint(_startPosX + _planeWidth / 2, _startPosY + _planeHeight);
|
||||
|
||||
g2d.setColor(bodyColor);
|
||||
g.fillPolygon(wingsPolygon);
|
||||
g2d.setColor(blackColor);
|
||||
g.drawPolygon(wingsPolygon);
|
||||
|
||||
// Рисуем хвостовое оперение
|
||||
Polygon tailPolygon = new Polygon();
|
||||
tailPolygon.addPoint(_startPosX + _planeWidth, _startPosY + _planeHeight / 2 - _planeHeight / 3);
|
||||
tailPolygon.addPoint(_startPosX + bodyWidth, _startPosY + _planeHeight / 2 - _planeHeight / 8);
|
||||
tailPolygon.addPoint(_startPosX + bodyWidth, _startPosY + _planeHeight / 2 + _planeHeight / 8);
|
||||
tailPolygon.addPoint(_startPosX + _planeWidth, _startPosY + _planeHeight / 2 + _planeHeight / 3);
|
||||
|
||||
g2d.setColor(bodyColor);
|
||||
g.fillPolygon(tailPolygon);
|
||||
g2d.setColor(blackColor);
|
||||
g.drawPolygon(tailPolygon);
|
||||
|
||||
// Рисуем фюзеляж
|
||||
g2d.setColor(bodyColor);
|
||||
g2d.fillRect(
|
||||
_startPosX + _planeWidth / 8,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2,
|
||||
bodyWidth,
|
||||
bodyHeight
|
||||
);
|
||||
g2d.setColor(blackColor);
|
||||
g2d.drawRect(
|
||||
_startPosX + _planeWidth / 8,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2,
|
||||
bodyWidth,
|
||||
bodyHeight
|
||||
);
|
||||
}
|
||||
}
|
@ -2,113 +2,49 @@ package ProjectStormtrooper;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawingStormtrooper {
|
||||
public EntityStormtrooper EntityStormtrooper;
|
||||
private DrawingEngines _drawingEngines;
|
||||
private int _pictureWidth;
|
||||
private int _pictureHeight;
|
||||
private int _startPosX;
|
||||
private int _startPosY;
|
||||
private final int _stormtrooperWidth = 110;
|
||||
private final int _stormtrooperHeight = 110;
|
||||
|
||||
public boolean Init(int speed, double weight, Color bodyColor,
|
||||
Color additionalColor, boolean rockets, boolean bombs,
|
||||
int width, int height) {
|
||||
if (width < _stormtrooperWidth && height < _stormtrooperHeight) {
|
||||
return false;
|
||||
}
|
||||
_pictureWidth = width;
|
||||
_pictureHeight = height;
|
||||
_drawingEngines = new DrawingEngines();
|
||||
EntityStormtrooper = new EntityStormtrooper();
|
||||
EntityStormtrooper.Init(speed, weight, bodyColor, additionalColor, rockets, bombs);
|
||||
return true;
|
||||
}
|
||||
|
||||
public void SetEnginesCount(int enginesCount) {
|
||||
_drawingEngines.SetEnumEnginesCount(enginesCount);
|
||||
}
|
||||
|
||||
public void SetPosition(int x, int y) {
|
||||
if (x < 0) {
|
||||
x = 0;
|
||||
} else if (x > _pictureWidth - _stormtrooperWidth) {
|
||||
x = _pictureWidth - _stormtrooperWidth;
|
||||
}
|
||||
_startPosX = x;
|
||||
|
||||
if (y < 0) {
|
||||
y = 0;
|
||||
} else if (y > _pictureHeight - _stormtrooperHeight) {
|
||||
y = _pictureHeight - _stormtrooperHeight;
|
||||
}
|
||||
_startPosY = y;
|
||||
}
|
||||
|
||||
public void MoveTransport(EnumDirectionType direction) {
|
||||
if (EntityStormtrooper == null) {
|
||||
return;
|
||||
}
|
||||
switch (direction) {
|
||||
case Up -> {
|
||||
if (_startPosY - EntityStormtrooper.Step() >= 0) {
|
||||
_startPosY -= (int) EntityStormtrooper.Step();
|
||||
}
|
||||
}
|
||||
case Down -> {
|
||||
if (_startPosY + _stormtrooperHeight + EntityStormtrooper.Step() <= _pictureHeight) {
|
||||
_startPosY += (int) EntityStormtrooper.Step();
|
||||
}
|
||||
}
|
||||
case Left -> {
|
||||
if (_startPosX - EntityStormtrooper.Step() >= 0) {
|
||||
_startPosX -= (int) EntityStormtrooper.Step();
|
||||
}
|
||||
}
|
||||
case Right -> {
|
||||
if (_startPosX + _stormtrooperWidth + EntityStormtrooper.Step() <= _pictureWidth) {
|
||||
_startPosX += (int) EntityStormtrooper.Step();
|
||||
}
|
||||
}
|
||||
public class DrawingStormtrooper extends DrawingPlane {
|
||||
public DrawingStormtrooper(int speed, double weight, Color bodyColor,
|
||||
Color additionalColor, boolean rockets, boolean bombs,
|
||||
int width, int height) {
|
||||
super(speed, weight, bodyColor, width, height, 140, 90);
|
||||
if (EntityPlane != null) {
|
||||
EntityPlane = new EntityStormtrooper(speed, weight, bodyColor, additionalColor, rockets, bombs);
|
||||
}
|
||||
}
|
||||
|
||||
public void DrawTransport(Graphics g) {
|
||||
if (EntityStormtrooper == null) {
|
||||
if (EntityPlane == null) {
|
||||
return;
|
||||
}
|
||||
if (!(EntityPlane instanceof EntityStormtrooper entityStormtrooper)) {
|
||||
return;
|
||||
}
|
||||
Graphics2D g2d = (Graphics2D) g;
|
||||
|
||||
Color bodyColor = EntityStormtrooper.BodyColor;
|
||||
Color additionalColor = EntityStormtrooper.AdditionalColor;
|
||||
int bodyHeight = _planeHeight / 9;
|
||||
|
||||
Color blackColor = Color.BLACK;
|
||||
Color redColor = Color.RED;
|
||||
|
||||
_drawingEngines.DrawEngines(g, additionalColor, _startPosX, _startPosY, _stormtrooperWidth, _stormtrooperHeight);
|
||||
|
||||
// Длина фюзеляжа
|
||||
int bodyHeight = _stormtrooperHeight / 9;
|
||||
int bodyWidth = _stormtrooperWidth - _stormtrooperWidth / 8;
|
||||
Color additionalColor = entityStormtrooper.AdditionalColor;
|
||||
|
||||
// Рисуем бомбы
|
||||
if (EntityStormtrooper.Bombs) {
|
||||
if (entityStormtrooper.Bombs) {
|
||||
Polygon bombTailPolygon = new Polygon();
|
||||
bombTailPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8 + bodyHeight * 3 - 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 - _stormtrooperHeight / 3 + bodyHeight / 2);
|
||||
bombTailPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8 + bodyHeight * 3 + 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 - _stormtrooperHeight / 3 + bodyHeight / 2 - 5);
|
||||
bombTailPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8 + bodyHeight * 3 + 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 - _stormtrooperHeight / 3 + bodyHeight / 2 + 5);
|
||||
bombTailPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8 + bodyHeight * 3 - 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 - _stormtrooperHeight / 3 + bodyHeight / 2);
|
||||
bombTailPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 8 + bodyHeight * 3 - 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 - _planeHeight / 3 + bodyHeight / 2);
|
||||
bombTailPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 8 + bodyHeight * 3 + 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 - _planeHeight / 3 + bodyHeight / 2 - 5);
|
||||
bombTailPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 8 + bodyHeight * 3 + 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 - _planeHeight / 3 + bodyHeight / 2 + 5);
|
||||
bombTailPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 8 + bodyHeight * 3 - 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 - _planeHeight / 3 + bodyHeight / 2);
|
||||
|
||||
g2d.setColor(additionalColor);
|
||||
g2d.fillPolygon(bombTailPolygon);
|
||||
g2d.setColor(blackColor);
|
||||
g2d.drawPolygon(bombTailPolygon);
|
||||
|
||||
bombTailPolygon.translate(0, (int) (_stormtrooperHeight - 2 * (_stormtrooperHeight / 2 - bodyHeight / 2 - _stormtrooperHeight / 3 + bodyHeight / 2 - 5) - bombTailPolygon.getBounds2D().getHeight()));
|
||||
bombTailPolygon.translate(0, (int) (_planeHeight - 2 * (_planeHeight / 2 - bodyHeight / 2 - _planeHeight / 3 + bodyHeight / 2 - 5) - bombTailPolygon.getBounds2D().getHeight()));
|
||||
|
||||
g2d.setColor(additionalColor);
|
||||
g2d.fillPolygon(bombTailPolygon);
|
||||
@ -117,50 +53,50 @@ public class DrawingStormtrooper {
|
||||
|
||||
g2d.setColor(additionalColor);
|
||||
g2d.fillOval(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 - _stormtrooperHeight / 3,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 8,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 - _planeHeight / 3,
|
||||
bodyHeight * 3,
|
||||
bodyHeight);
|
||||
|
||||
g2d.fillOval(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 + _stormtrooperHeight / 3,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 8,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 + _planeHeight / 3,
|
||||
bodyHeight * 3,
|
||||
bodyHeight);
|
||||
|
||||
g2d.setColor(blackColor);
|
||||
g2d.drawOval(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 - _stormtrooperHeight / 3,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 8,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 - _planeHeight / 3,
|
||||
bodyHeight * 3,
|
||||
bodyHeight);
|
||||
g2d.drawOval(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 8,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2 + _stormtrooperHeight / 3,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 8,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight / 2 + _planeHeight / 3,
|
||||
bodyHeight * 3,
|
||||
bodyHeight);
|
||||
}
|
||||
|
||||
// Рисуем ракеты
|
||||
if (EntityStormtrooper.Rockets) {
|
||||
if (entityStormtrooper.Rockets) {
|
||||
int rocketWidth = bodyHeight * 4;
|
||||
int rocketHeight = bodyHeight / 2;
|
||||
|
||||
Polygon rocketCockPitPolygon = new Polygon();
|
||||
rocketCockPitPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5 - rocketHeight,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight / 2);
|
||||
rocketCockPitPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2);
|
||||
rocketCockPitPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight);
|
||||
rocketCockPitPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 5 - rocketHeight,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight / 2);
|
||||
rocketCockPitPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight - bodyHeight / 2);
|
||||
rocketCockPitPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight);
|
||||
|
||||
Polygon rocketTailPolygon = new Polygon();
|
||||
rocketTailPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5 - rocketHeight + rocketWidth - 10,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight / 2);
|
||||
rocketTailPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5 + rocketWidth,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight * 2 + rocketHeight / 2);
|
||||
rocketTailPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5 + rocketWidth,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight + bodyHeight / 2 - rocketHeight / 2);
|
||||
rocketTailPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 5 - rocketHeight + rocketWidth - 10,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight / 2);
|
||||
rocketTailPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 5 + rocketWidth,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight * 2 + rocketHeight / 2);
|
||||
rocketTailPolygon.addPoint(_startPosX + _planeWidth / 2 - _planeWidth / 5 + rocketWidth,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight - bodyHeight / 2 + rocketHeight + bodyHeight / 2 - rocketHeight / 2);
|
||||
|
||||
g2d.setColor(redColor);
|
||||
g2d.fillPolygon(rocketCockPitPolygon);
|
||||
@ -170,8 +106,8 @@ public class DrawingStormtrooper {
|
||||
g2d.setColor(blackColor);
|
||||
g2d.fillPolygon(rocketTailPolygon);
|
||||
|
||||
rocketCockPitPolygon.translate(0, (int) (_stormtrooperHeight - 2 * (_stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2) - rocketCockPitPolygon.getBounds2D().getHeight()));
|
||||
rocketTailPolygon.translate(0, (int) (_stormtrooperHeight - 2 * (_stormtrooperHeight / 2 - bodyHeight * 2 + rocketHeight / 2) - rocketTailPolygon.getBounds2D().getHeight()));
|
||||
rocketCockPitPolygon.translate(0, (int) (_planeHeight - 2 * (_planeHeight / 2 - bodyHeight - bodyHeight / 2) - rocketCockPitPolygon.getBounds2D().getHeight()));
|
||||
rocketTailPolygon.translate(0, (int) (_planeHeight - 2 * (_planeHeight / 2 - bodyHeight * 2 + rocketHeight / 2) - rocketTailPolygon.getBounds2D().getHeight()));
|
||||
|
||||
g2d.setColor(redColor);
|
||||
g2d.fillPolygon(rocketCockPitPolygon);
|
||||
@ -183,80 +119,32 @@ public class DrawingStormtrooper {
|
||||
|
||||
g2d.setColor(additionalColor);
|
||||
g2d.fillRect(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight - bodyHeight / 2,
|
||||
rocketWidth,
|
||||
rocketHeight);
|
||||
|
||||
|
||||
g2d.fillRect(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5,
|
||||
_startPosY + _stormtrooperHeight / 2 + bodyHeight / 2 + bodyHeight / 2,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 5,
|
||||
_startPosY + _planeHeight / 2 + bodyHeight / 2 + bodyHeight / 2,
|
||||
rocketWidth,
|
||||
rocketHeight);
|
||||
|
||||
g2d.setColor(blackColor);
|
||||
g2d.drawRect(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight - bodyHeight / 2,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 5,
|
||||
_startPosY + _planeHeight / 2 - bodyHeight - bodyHeight / 2,
|
||||
rocketWidth,
|
||||
rocketHeight);
|
||||
|
||||
g2d.drawRect(
|
||||
_startPosX + _stormtrooperWidth / 2 - _stormtrooperWidth / 5,
|
||||
_startPosY + _stormtrooperHeight / 2 + bodyHeight / 2 + bodyHeight / 2,
|
||||
_startPosX + _planeWidth / 2 - _planeWidth / 5,
|
||||
_startPosY + _planeHeight / 2 + bodyHeight / 2 + bodyHeight / 2,
|
||||
rocketWidth,
|
||||
rocketHeight);
|
||||
}
|
||||
|
||||
// Рисуем нос
|
||||
Polygon cockPitPolygon = new Polygon();
|
||||
cockPitPolygon.addPoint(_startPosX, _startPosY + _stormtrooperHeight / 2);
|
||||
cockPitPolygon.addPoint(_startPosX + _stormtrooperWidth / 8, _startPosY + _stormtrooperHeight / 2 - bodyHeight / 2);
|
||||
cockPitPolygon.addPoint(_startPosX + _stormtrooperWidth / 8, _startPosY + _stormtrooperHeight / 2 + bodyHeight / 2);
|
||||
|
||||
g2d.setColor(blackColor);
|
||||
g2d.fillPolygon(cockPitPolygon);
|
||||
|
||||
// Рисуем крылья
|
||||
Polygon wingsPolygon = new Polygon();
|
||||
wingsPolygon.addPoint(_startPosX + _stormtrooperWidth / 2, _startPosY);
|
||||
wingsPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 + _stormtrooperWidth / 15, _startPosY);
|
||||
wingsPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 + _stormtrooperWidth / 6, _startPosY + _stormtrooperHeight / 2);
|
||||
wingsPolygon.addPoint(_startPosX + _stormtrooperWidth / 2 + _stormtrooperWidth / 15, _startPosY + _stormtrooperHeight);
|
||||
wingsPolygon.addPoint(_startPosX + _stormtrooperWidth / 2, _startPosY + _stormtrooperHeight);
|
||||
|
||||
g2d.setColor(bodyColor);
|
||||
g.fillPolygon(wingsPolygon);
|
||||
g2d.setColor(blackColor);
|
||||
g.drawPolygon(wingsPolygon);
|
||||
|
||||
// Рисуем хвостовое оперение
|
||||
Polygon tailPolygon = new Polygon();
|
||||
tailPolygon.addPoint(_startPosX + _stormtrooperWidth, _startPosY + _stormtrooperHeight / 2 - _stormtrooperHeight / 3);
|
||||
tailPolygon.addPoint(_startPosX + bodyWidth, _startPosY + _stormtrooperHeight / 2 - _stormtrooperHeight / 8);
|
||||
tailPolygon.addPoint(_startPosX + bodyWidth, _startPosY + _stormtrooperHeight / 2 + _stormtrooperHeight / 8);
|
||||
tailPolygon.addPoint(_startPosX + _stormtrooperWidth, _startPosY + _stormtrooperHeight / 2 + _stormtrooperHeight / 3);
|
||||
|
||||
g2d.setColor(bodyColor);
|
||||
g.fillPolygon(tailPolygon);
|
||||
g2d.setColor(blackColor);
|
||||
g.drawPolygon(tailPolygon);
|
||||
|
||||
// Рисуем фюзеляж
|
||||
g2d.setColor(bodyColor);
|
||||
g2d.fillRect(
|
||||
_startPosX + _stormtrooperWidth / 8,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2,
|
||||
bodyWidth,
|
||||
bodyHeight
|
||||
);
|
||||
g2d.setColor(blackColor);
|
||||
g2d.drawRect(
|
||||
_startPosX + _stormtrooperWidth / 8,
|
||||
_startPosY + _stormtrooperHeight / 2 - bodyHeight / 2,
|
||||
bodyWidth,
|
||||
bodyHeight
|
||||
);
|
||||
super.DrawTransport(g);
|
||||
}
|
||||
}
|
||||
|
19
ProjectStormtrooper/EntityPlane.java
Normal file
19
ProjectStormtrooper/EntityPlane.java
Normal file
@ -0,0 +1,19 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class EntityPlane {
|
||||
public int Speed;
|
||||
public double Weight;
|
||||
public Color BodyColor;
|
||||
|
||||
public double Step() {
|
||||
return (double) Speed * 250 / Weight;
|
||||
}
|
||||
|
||||
public EntityPlane(int speed, double weight, Color bodyColor) {
|
||||
Speed = speed;
|
||||
Weight = weight;
|
||||
BodyColor = bodyColor;
|
||||
}
|
||||
}
|
@ -2,22 +2,14 @@ package ProjectStormtrooper;
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class EntityStormtrooper {
|
||||
public int Speed;
|
||||
public double Weight;
|
||||
public Color BodyColor;
|
||||
public class EntityStormtrooper extends EntityPlane {
|
||||
public Color AdditionalColor;
|
||||
public boolean Rockets;
|
||||
public boolean Bombs;
|
||||
|
||||
public double Step() {
|
||||
return (double) Speed * 250 / Weight;
|
||||
}
|
||||
|
||||
public void Init(int speed, double weight, Color bodyColor, Color additionalColor, boolean rockets, boolean bombs) {
|
||||
Speed = speed;
|
||||
Weight = weight;
|
||||
BodyColor = bodyColor;
|
||||
public EntityStormtrooper(int speed, double weight, Color bodyColor,
|
||||
Color additionalColor, boolean rockets, boolean bombs) {
|
||||
super(speed, weight, bodyColor);
|
||||
AdditionalColor = additionalColor;
|
||||
Rockets = rockets;
|
||||
Bombs = bombs;
|
||||
|
@ -1,6 +1,6 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<form xmlns="http://www.intellij.com/uidesigner/form/" version="1" bind-to-class="ProjectStormtrooper.FormStormtrooper">
|
||||
<grid id="27dc6" binding="pictureBox" layout-manager="GridLayoutManager" row-count="3" column-count="5" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
||||
<grid id="27dc6" binding="pictureBox" layout-manager="GridLayoutManager" row-count="5" column-count="6" same-size-horizontally="false" same-size-vertically="false" hgap="-1" vgap="-1">
|
||||
<margin top="0" left="0" bottom="0" right="0"/>
|
||||
<constraints>
|
||||
<xy x="20" y="20" width="900" height="500"/>
|
||||
@ -11,27 +11,27 @@
|
||||
</properties>
|
||||
<border type="none"/>
|
||||
<children>
|
||||
<component id="35f01" class="javax.swing.JButton" binding="buttonCreate">
|
||||
<component id="35f01" class="javax.swing.JButton" binding="buttonCreateStormtrooper">
|
||||
<constraints>
|
||||
<grid row="2" column="0" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||
<grid row="4" column="0" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||
</constraints>
|
||||
<properties>
|
||||
<text value="Создать"/>
|
||||
<text value="Создать штурмовик"/>
|
||||
</properties>
|
||||
</component>
|
||||
<hspacer id="f9ba0">
|
||||
<constraints>
|
||||
<grid row="2" column="1" row-span="1" col-span="1" vsize-policy="1" hsize-policy="6" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||
<grid row="4" column="2" row-span="1" col-span="1" vsize-policy="1" hsize-policy="6" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||
</constraints>
|
||||
</hspacer>
|
||||
<vspacer id="ce5ea">
|
||||
<constraints>
|
||||
<grid row="0" column="0" row-span="1" col-span="1" vsize-policy="6" hsize-policy="1" anchor="0" fill="2" indent="0" use-parent-layout="false"/>
|
||||
<grid row="2" column="0" row-span="1" col-span="1" vsize-policy="6" hsize-policy="1" anchor="0" fill="2" indent="0" use-parent-layout="false"/>
|
||||
</constraints>
|
||||
</vspacer>
|
||||
<component id="ac2ff" class="javax.swing.JButton" binding="buttonDown">
|
||||
<constraints>
|
||||
<grid row="2" column="3" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<grid row="4" column="4" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<minimum-size width="30" height="30"/>
|
||||
<preferred-size width="30" height="30"/>
|
||||
<maximum-size width="30" height="30"/>
|
||||
@ -46,7 +46,7 @@
|
||||
</component>
|
||||
<component id="b1382" class="javax.swing.JButton" binding="buttonUp">
|
||||
<constraints>
|
||||
<grid row="1" column="3" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<grid row="3" column="4" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<minimum-size width="30" height="30"/>
|
||||
<preferred-size width="30" height="30"/>
|
||||
<maximum-size width="30" height="30"/>
|
||||
@ -61,7 +61,7 @@
|
||||
</component>
|
||||
<component id="8b2ff" class="javax.swing.JButton" binding="buttonLeft">
|
||||
<constraints>
|
||||
<grid row="2" column="2" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<grid row="4" column="3" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<minimum-size width="30" height="30"/>
|
||||
<preferred-size width="30" height="30"/>
|
||||
<maximum-size width="30" height="30"/>
|
||||
@ -77,7 +77,7 @@
|
||||
</component>
|
||||
<component id="25771" class="javax.swing.JButton" binding="buttonRight">
|
||||
<constraints>
|
||||
<grid row="2" column="4" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<grid row="4" column="5" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="0" indent="0" use-parent-layout="false">
|
||||
<minimum-size width="30" height="30"/>
|
||||
<preferred-size width="30" height="30"/>
|
||||
<maximum-size width="30" height="30"/>
|
||||
@ -89,6 +89,28 @@
|
||||
<text value=""/>
|
||||
</properties>
|
||||
</component>
|
||||
<component id="d1f31" class="javax.swing.JButton" binding="buttonCreatePlane">
|
||||
<constraints>
|
||||
<grid row="4" column="1" row-span="1" col-span="1" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||
</constraints>
|
||||
<properties>
|
||||
<text value="Создать самолет"/>
|
||||
</properties>
|
||||
</component>
|
||||
<component id="aefae" class="javax.swing.JComboBox" binding="comboBoxStrategy" custom-create="true">
|
||||
<constraints>
|
||||
<grid row="0" column="3" row-span="1" col-span="3" vsize-policy="0" hsize-policy="2" anchor="8" fill="1" indent="0" use-parent-layout="false"/>
|
||||
</constraints>
|
||||
<properties/>
|
||||
</component>
|
||||
<component id="c79a6" class="javax.swing.JButton" binding="buttonStep">
|
||||
<constraints>
|
||||
<grid row="1" column="3" row-span="1" col-span="3" vsize-policy="0" hsize-policy="3" anchor="0" fill="1" indent="0" use-parent-layout="false"/>
|
||||
</constraints>
|
||||
<properties>
|
||||
<text value="Шаг"/>
|
||||
</properties>
|
||||
</component>
|
||||
</children>
|
||||
</grid>
|
||||
</form>
|
||||
|
@ -6,13 +6,17 @@ import java.util.Random;
|
||||
import java.awt.event.ActionListener;
|
||||
|
||||
public class FormStormtrooper {
|
||||
DrawingStormtrooper _drawingStormtrooper = new DrawingStormtrooper();
|
||||
private JButton buttonCreate;
|
||||
DrawingPlane _drawingPlane;
|
||||
AbstractStrategy _abstractStrategy;
|
||||
private JButton buttonCreateStormtrooper;
|
||||
private JPanel pictureBox;
|
||||
private JButton buttonDown;
|
||||
private JButton buttonUp;
|
||||
private JButton buttonLeft;
|
||||
private JButton buttonRight;
|
||||
private JButton buttonCreatePlane;
|
||||
private JComboBox comboBoxStrategy;
|
||||
private JButton buttonStep;
|
||||
|
||||
public JPanel getPictureBox() {
|
||||
return pictureBox;
|
||||
@ -24,11 +28,11 @@ public class FormStormtrooper {
|
||||
buttonLeft.setName("buttonLeft");
|
||||
buttonRight.setName("buttonRight");
|
||||
|
||||
buttonCreate.addActionListener(e -> {
|
||||
_drawingStormtrooper = new DrawingStormtrooper();
|
||||
|
||||
buttonCreateStormtrooper.addActionListener(e -> {
|
||||
Random random = new Random();
|
||||
|
||||
_drawingStormtrooper.Init(
|
||||
_drawingPlane = new DrawingStormtrooper(
|
||||
random.nextInt(100, 300),
|
||||
random.nextInt(1000, 3000),
|
||||
new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256)),
|
||||
@ -39,27 +43,70 @@ public class FormStormtrooper {
|
||||
pictureBox.getHeight()
|
||||
);
|
||||
|
||||
_drawingStormtrooper.SetEnginesCount(random.nextInt(2, 7));
|
||||
_drawingStormtrooper.SetPosition(random.nextInt(10, 100), random.nextInt(10, 100));
|
||||
_drawingPlane.SetEnginesCount(random.nextInt(2, 7));
|
||||
_drawingPlane.SetPosition(random.nextInt(10, 100), random.nextInt(10, 100));
|
||||
|
||||
Draw();
|
||||
});
|
||||
|
||||
buttonCreatePlane.addActionListener(e -> {
|
||||
Random random = new Random();
|
||||
|
||||
_drawingPlane = new DrawingPlane(
|
||||
random.nextInt(100, 300),
|
||||
random.nextInt(1000, 3000),
|
||||
new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256)),
|
||||
pictureBox.getWidth(),
|
||||
pictureBox.getHeight()
|
||||
);
|
||||
|
||||
_drawingPlane.SetEnginesCount(random.nextInt(2, 7));
|
||||
_drawingPlane.SetPosition(random.nextInt(10, 100), random.nextInt(10, 100));
|
||||
|
||||
Draw();
|
||||
});
|
||||
|
||||
buttonStep.addActionListener(e -> {
|
||||
if (_drawingPlane == null)
|
||||
return;
|
||||
if (comboBoxStrategy.isEnabled()) {
|
||||
_abstractStrategy = null;
|
||||
int comboBoxStrategySelectedIndex = comboBoxStrategy.getSelectedIndex();
|
||||
if (comboBoxStrategySelectedIndex == 0) {
|
||||
_abstractStrategy = new MoveToCenter();
|
||||
} else if (comboBoxStrategySelectedIndex == 1) {
|
||||
_abstractStrategy = new MoveToRightBottom();
|
||||
}
|
||||
if (_abstractStrategy == null)
|
||||
return;
|
||||
_abstractStrategy.SetData(new DrawingObjectPlane(_drawingPlane), pictureBox.getWidth(), pictureBox.getHeight());
|
||||
comboBoxStrategy.setEnabled(false);
|
||||
}
|
||||
if (_abstractStrategy == null)
|
||||
return;
|
||||
_abstractStrategy.MakeStep();
|
||||
Draw();
|
||||
if (_abstractStrategy.GetStatus() == Status.Finish) {
|
||||
comboBoxStrategy.setEnabled(true);
|
||||
_abstractStrategy = null;
|
||||
}
|
||||
});
|
||||
|
||||
ActionListener buttonMoveClickedListener = e -> {
|
||||
String buttonName = ((JButton) e.getSource()).getName();
|
||||
|
||||
switch (buttonName) {
|
||||
case ("buttonUp") -> {
|
||||
_drawingStormtrooper.MoveTransport(EnumDirectionType.Up);
|
||||
_drawingPlane.MoveTransport(EnumDirectionType.Up);
|
||||
}
|
||||
case ("buttonDown") -> {
|
||||
_drawingStormtrooper.MoveTransport(EnumDirectionType.Down);
|
||||
_drawingPlane.MoveTransport(EnumDirectionType.Down);
|
||||
}
|
||||
case ("buttonLeft") -> {
|
||||
_drawingStormtrooper.MoveTransport(EnumDirectionType.Left);
|
||||
_drawingPlane.MoveTransport(EnumDirectionType.Left);
|
||||
}
|
||||
case ("buttonRight") -> {
|
||||
_drawingStormtrooper.MoveTransport(EnumDirectionType.Right);
|
||||
_drawingPlane.MoveTransport(EnumDirectionType.Right);
|
||||
}
|
||||
}
|
||||
|
||||
@ -73,12 +120,20 @@ public class FormStormtrooper {
|
||||
}
|
||||
|
||||
public void Draw() {
|
||||
if (_drawingStormtrooper.EntityStormtrooper == null) {
|
||||
if (_drawingPlane == null) {
|
||||
return;
|
||||
}
|
||||
|
||||
Graphics g = pictureBox.getGraphics();
|
||||
pictureBox.paint(g);
|
||||
_drawingStormtrooper.DrawTransport(g);
|
||||
_drawingPlane.DrawTransport(g);
|
||||
}
|
||||
|
||||
private void createUIComponents() {
|
||||
String[] strategiesList = {
|
||||
"MoveToCenter",
|
||||
"MoveToRightBottom"
|
||||
};
|
||||
comboBoxStrategy = new JComboBox(strategiesList);
|
||||
}
|
||||
}
|
||||
|
@ -2,30 +2,16 @@ package ProjectStormtrooper;
|
||||
|
||||
|
||||
import java.awt.*;
|
||||
|
||||
public class DrawingEngines {
|
||||
private EnumEnginesCount _enumEnginesCount;
|
||||
public interface IDrawingEngines {
|
||||
void SetEnumEnginesCount(int enginesCount);
|
||||
|
||||
public void SetEnumEnginesCount(int enginesCount) {
|
||||
for (EnumEnginesCount val : EnumEnginesCount.values()) {
|
||||
if (val.count == enginesCount) {
|
||||
this._enumEnginesCount = val;
|
||||
return;
|
||||
}
|
||||
}
|
||||
this._enumEnginesCount = EnumEnginesCount.Two;
|
||||
}
|
||||
EnumEnginesCount GetEnumEnginesCount();
|
||||
|
||||
private void DrawEngine(Graphics2D g2d, Color color, int x, int y, int w, int h) {
|
||||
g2d.setColor(Color.WHITE);
|
||||
g2d.fillRect(x, y, w, h);
|
||||
g2d.setColor(Color.BLACK);
|
||||
g2d.drawRect(x, y, w, h);
|
||||
g2d.setColor(color);
|
||||
g2d.fillRect(x, y, 6, h);
|
||||
}
|
||||
void DrawEngine(Graphics2D g2d, Color color, int x, int y, int w, int h);
|
||||
|
||||
public void DrawEngines(Graphics g, Color color, int startPosX, int startPosY, int drawingWidth, int drawingHeight) {
|
||||
if (_enumEnginesCount == null) {
|
||||
default void DrawEngines(Graphics g, Color color, int startPosX, int startPosY, int drawingWidth, int drawingHeight) {
|
||||
EnumEnginesCount enginesCount = GetEnumEnginesCount();
|
||||
if (enginesCount == null) {
|
||||
return;
|
||||
}
|
||||
Graphics2D g2d = (Graphics2D) g;
|
||||
@ -33,7 +19,7 @@ public class DrawingEngines {
|
||||
int engineWidth = 20;
|
||||
int engineHeight = 6;
|
||||
|
||||
if (_enumEnginesCount.count >= EnumEnginesCount.Two.count) {
|
||||
if (enginesCount.count >= EnumEnginesCount.Two.count) {
|
||||
DrawEngine(
|
||||
g2d, color,
|
||||
startPosX + drawingWidth - drawingWidth / 5,
|
||||
@ -49,7 +35,7 @@ public class DrawingEngines {
|
||||
engineHeight
|
||||
);
|
||||
}
|
||||
if (_enumEnginesCount.count >= EnumEnginesCount.Four.count) {
|
||||
if (enginesCount.count >= EnumEnginesCount.Four.count) {
|
||||
DrawEngine(
|
||||
g2d, color,
|
||||
startPosX + drawingWidth - drawingWidth / 5 + 5,
|
||||
@ -65,7 +51,7 @@ public class DrawingEngines {
|
||||
engineHeight
|
||||
);
|
||||
}
|
||||
if (_enumEnginesCount.count >= EnumEnginesCount.Six.count) {
|
||||
if (enginesCount.count >= EnumEnginesCount.Six.count) {
|
||||
DrawEngine(
|
||||
g2d, color,
|
||||
startPosX + drawingWidth / 2 - 10,
|
8
ProjectStormtrooper/IMoveableObject.java
Normal file
8
ProjectStormtrooper/IMoveableObject.java
Normal file
@ -0,0 +1,8 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
public interface IMoveableObject {
|
||||
ObjectParameters GetObjectPosition();
|
||||
int GetStep();
|
||||
boolean CheckCanMove(EnumDirectionType direction);
|
||||
void MoveObject(EnumDirectionType direction);
|
||||
}
|
37
ProjectStormtrooper/MoveToCenter.java
Normal file
37
ProjectStormtrooper/MoveToCenter.java
Normal file
@ -0,0 +1,37 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
public class MoveToCenter extends AbstractStrategy {
|
||||
@Override
|
||||
protected void MoveToTarget() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return;
|
||||
}
|
||||
var diffX = objParams.ObjectMiddleHorizontal() - FieldWidth / 2;
|
||||
if (Math.abs(diffX) > GetStep()) {
|
||||
if (diffX > 0) {
|
||||
MoveLeft();
|
||||
} else {
|
||||
MoveRight();
|
||||
}
|
||||
}
|
||||
var diffY = objParams.ObjectMiddleVertical() - FieldHeight / 2;
|
||||
if (Math.abs(diffY) > GetStep()) {
|
||||
if (diffY > 0) {
|
||||
MoveUp();
|
||||
} else {
|
||||
MoveDown();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean IsTargetDestination() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return false;
|
||||
}
|
||||
return objParams.ObjectMiddleHorizontal() <= FieldWidth / 2 && objParams.ObjectMiddleHorizontal() + GetStep() >= FieldWidth / 2 &&
|
||||
objParams.ObjectMiddleVertical() <= FieldHeight / 2 && objParams.ObjectMiddleVertical() + GetStep() >= FieldHeight / 2;
|
||||
}
|
||||
}
|
26
ProjectStormtrooper/MoveToRightBottom.java
Normal file
26
ProjectStormtrooper/MoveToRightBottom.java
Normal file
@ -0,0 +1,26 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
public class MoveToRightBottom extends AbstractStrategy {
|
||||
@Override
|
||||
protected void MoveToTarget() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return;
|
||||
}
|
||||
if (objParams.RightBorder() < FieldWidth - GetStep()) {
|
||||
MoveRight();
|
||||
}
|
||||
if (objParams.TopBorder() < FieldHeight - GetStep()) {
|
||||
MoveDown();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean IsTargetDestination() {
|
||||
var objParams = GetObjectParameters();
|
||||
if (objParams == null) {
|
||||
return false;
|
||||
}
|
||||
return objParams.RightBorder() >= FieldWidth - GetStep() && objParams.DownBorder() >= FieldHeight - GetStep();
|
||||
}
|
||||
}
|
39
ProjectStormtrooper/ObjectParameters.java
Normal file
39
ProjectStormtrooper/ObjectParameters.java
Normal file
@ -0,0 +1,39 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
public class ObjectParameters {
|
||||
private int _x;
|
||||
private int _y;
|
||||
private int _width;
|
||||
private int _height;
|
||||
|
||||
public int LeftBorder() {
|
||||
return _x;
|
||||
}
|
||||
|
||||
public int TopBorder() {
|
||||
return _y;
|
||||
}
|
||||
|
||||
public int RightBorder() {
|
||||
return _x + _width;
|
||||
}
|
||||
|
||||
public int DownBorder() {
|
||||
return _y + _height;
|
||||
}
|
||||
|
||||
public int ObjectMiddleHorizontal() {
|
||||
return _x + _width / 2;
|
||||
}
|
||||
|
||||
public int ObjectMiddleVertical() {
|
||||
return _y + _height / 2;
|
||||
}
|
||||
|
||||
public ObjectParameters(int x, int y, int width, int height) {
|
||||
_x = x;
|
||||
_y = y;
|
||||
_width = width;
|
||||
_height = height;
|
||||
}
|
||||
}
|
7
ProjectStormtrooper/Status.java
Normal file
7
ProjectStormtrooper/Status.java
Normal file
@ -0,0 +1,7 @@
|
||||
package ProjectStormtrooper;
|
||||
|
||||
public enum Status {
|
||||
NotInit,
|
||||
InProgress,
|
||||
Finish
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user
Доп класс с первой части должен был быть одной из реализаций Доп интерфейса