diff --git a/ProjectMonorail/.gitignore b/ProjectMonorail/.gitignore
new file mode 100644
index 0000000..f68d109
--- /dev/null
+++ b/ProjectMonorail/.gitignore
@@ -0,0 +1,29 @@
+### IntelliJ IDEA ###
+out/
+!**/src/main/**/out/
+!**/src/test/**/out/
+
+### Eclipse ###
+.apt_generated
+.classpath
+.factorypath
+.project
+.settings
+.springBeans
+.sts4-cache
+bin/
+!**/src/main/**/bin/
+!**/src/test/**/bin/
+
+### NetBeans ###
+/nbproject/private/
+/nbbuild/
+/dist/
+/nbdist/
+/.nb-gradle/
+
+### VS Code ###
+.vscode/
+
+### Mac OS ###
+.DS_Store
\ No newline at end of file
diff --git a/ProjectMonorail/.idea/.gitignore b/ProjectMonorail/.idea/.gitignore
new file mode 100644
index 0000000..13566b8
--- /dev/null
+++ b/ProjectMonorail/.idea/.gitignore
@@ -0,0 +1,8 @@
+# Default ignored files
+/shelf/
+/workspace.xml
+# Editor-based HTTP Client requests
+/httpRequests/
+# Datasource local storage ignored files
+/dataSources/
+/dataSources.local.xml
diff --git a/ProjectMonorail/.idea/misc.xml b/ProjectMonorail/.idea/misc.xml
new file mode 100644
index 0000000..69ace3f
--- /dev/null
+++ b/ProjectMonorail/.idea/misc.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ProjectMonorail/.idea/modules.xml b/ProjectMonorail/.idea/modules.xml
new file mode 100644
index 0000000..8a2f0e7
--- /dev/null
+++ b/ProjectMonorail/.idea/modules.xml
@@ -0,0 +1,8 @@
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ProjectMonorail/.idea/uiDesigner.xml b/ProjectMonorail/.idea/uiDesigner.xml
new file mode 100644
index 0000000..2b63946
--- /dev/null
+++ b/ProjectMonorail/.idea/uiDesigner.xml
@@ -0,0 +1,124 @@
+
+
+
+
+ -
+
+
+ -
+
+
+ -
+
+
+ -
+
+
+ -
+
+
+
+
+
+ -
+
+
+
+
+
+ -
+
+
+
+
+
+ -
+
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+
+
+ -
+
+
+ -
+
+
+ -
+
+
+ -
+
+
+ -
+
+
+
+
+ -
+
+
+ -
+
+
+
+
+
\ No newline at end of file
diff --git a/ProjectMonorail/.idea/vcs.xml b/ProjectMonorail/.idea/vcs.xml
new file mode 100644
index 0000000..6c0b863
--- /dev/null
+++ b/ProjectMonorail/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ProjectMonorail/ProjectMonorail.iml b/ProjectMonorail/ProjectMonorail.iml
new file mode 100644
index 0000000..c90834f
--- /dev/null
+++ b/ProjectMonorail/ProjectMonorail.iml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ProjectMonorail/Resource/Arrows/ArrowDown.png b/ProjectMonorail/Resource/Arrows/ArrowDown.png
new file mode 100644
index 0000000..271d5b4
Binary files /dev/null and b/ProjectMonorail/Resource/Arrows/ArrowDown.png differ
diff --git a/ProjectMonorail/Resource/Arrows/ArrowLeft.png b/ProjectMonorail/Resource/Arrows/ArrowLeft.png
new file mode 100644
index 0000000..313d764
Binary files /dev/null and b/ProjectMonorail/Resource/Arrows/ArrowLeft.png differ
diff --git a/ProjectMonorail/Resource/Arrows/ArrowRight.png b/ProjectMonorail/Resource/Arrows/ArrowRight.png
new file mode 100644
index 0000000..bbee88e
Binary files /dev/null and b/ProjectMonorail/Resource/Arrows/ArrowRight.png differ
diff --git a/ProjectMonorail/Resource/Arrows/ArrowUp.png b/ProjectMonorail/Resource/Arrows/ArrowUp.png
new file mode 100644
index 0000000..0812cc2
Binary files /dev/null and b/ProjectMonorail/Resource/Arrows/ArrowUp.png differ
diff --git a/ProjectMonorail/src/CountWheels.java b/ProjectMonorail/src/CountWheels.java
new file mode 100644
index 0000000..1e14a19
--- /dev/null
+++ b/ProjectMonorail/src/CountWheels.java
@@ -0,0 +1,12 @@
+public enum CountWheels {
+ Two(2),
+ Three(3),
+ Four(4);
+ private final int Value;
+ CountWheels(int Count){
+ Value=Count;
+ }
+ public int getCountWheels(){
+ return Value;
+ }
+}
diff --git a/ProjectMonorail/src/DirectionType.java b/ProjectMonorail/src/DirectionType.java
new file mode 100644
index 0000000..b6f4136
--- /dev/null
+++ b/ProjectMonorail/src/DirectionType.java
@@ -0,0 +1,6 @@
+public enum DirectionType {
+ Up,
+ Down,
+ Left,
+ Right;
+}
diff --git a/ProjectMonorail/src/DrawingField.java b/ProjectMonorail/src/DrawingField.java
new file mode 100644
index 0000000..1ff7a05
--- /dev/null
+++ b/ProjectMonorail/src/DrawingField.java
@@ -0,0 +1,58 @@
+import javax.swing.*;
+import java.awt.*;
+import java.util.Random;
+
+public class DrawingField extends JPanel {
+ private final FormModernMonorail field;
+ DrawingModernMonorail _monorail;
+ public DrawingField(FormModernMonorail field) {
+ this.field = field;
+ }
+
+ @Override
+ protected void paintComponent(Graphics g) {
+ super.paintComponent(g);
+ Graphics2D g2 =(Graphics2D)g;
+ if (_monorail !=null)
+ _monorail.DrawTransport(g2);
+ else return;
+ }
+
+ public void UpButtonAction(){
+ if (_monorail !=null)
+ _monorail.MoveTransport(DirectionType.Up);
+ return;
+ }
+
+ public void DownButtonAction(){
+ if (_monorail !=null)
+ _monorail.MoveTransport(DirectionType.Down);
+ return;
+ }
+
+ public void RightButtonAction(){
+ if (_monorail !=null)
+ _monorail.MoveTransport(DirectionType.Right);
+ return;
+ }
+
+ public void LeftButtonAction(){
+ if (_monorail !=null)
+ _monorail.MoveTransport(DirectionType.Left);
+ return;
+ }
+
+ public void CreateButtonAction(){
+ Random rnd=new Random();
+ _monorail =new DrawingModernMonorail();
+ _monorail.SetPictureSize(getWidth(),getHeight());
+ _monorail.Initialization(rnd.nextInt(50)+10,rnd.nextInt(100)+500,new Color(rnd.nextInt(256),rnd.nextInt(256),rnd.nextInt(256)), new Color(rnd.nextInt(256),rnd.nextInt(256),rnd.nextInt(256)), rnd.nextBoolean(), rnd.nextBoolean());
+ _monorail.SetPosition(rnd.nextInt(100)+10,rnd.nextInt(100)+10,getWidth(),getHeight());
+ }
+
+ public void ResizeField(){
+ if (_monorail !=null)
+ _monorail.SetPictureSize(getWidth(),getHeight());
+ else return;
+ }
+}
diff --git a/ProjectMonorail/src/DrawingModernMonorail.java b/ProjectMonorail/src/DrawingModernMonorail.java
new file mode 100644
index 0000000..b83b309
--- /dev/null
+++ b/ProjectMonorail/src/DrawingModernMonorail.java
@@ -0,0 +1,239 @@
+import java.awt.*;
+import java.util.Random;
+
+public class DrawingModernMonorail {
+ private EntityModernMonorail _entityMonorail;
+ private DrawingWheels _wheels;
+
+ private Integer _pictureWidth = null;
+ private Integer _pictureHeight = null;
+
+ private int _startPositionX;
+ private int _startPositionY;
+
+ private int _drawningMonorailWidth = 100;
+ private final int _drawningMonorailHeight = 40;
+
+ public EntityModernMonorail getMonorail() {return _entityMonorail;}
+ public DrawingWheels getWheels() {return _wheels;}
+ private int _wheelsSeed;
+
+ public void Initialization(int speed, float weight, Color bodyColor, Color additionalColor, boolean monorailTrack, boolean cabin)
+ {
+ _entityMonorail = new EntityModernMonorail();
+ _entityMonorail.Initialization(speed, weight, bodyColor, additionalColor, monorailTrack, cabin);
+ _wheels = new DrawingWheels();
+ Random rnd = new Random();
+ if (_entityMonorail.getCabin()) _drawningMonorailWidth = 190;
+ _wheels.SetCountWheels(2 + rnd.nextInt(0, 3));
+ _wheelsSeed = rnd.nextInt(0, 2);
+ }
+
+ public boolean SetPictureSize(int width, int height)
+ {
+ if (_drawningMonorailWidth > width || _drawningMonorailHeight > height) return false;
+
+ if (_startPositionX >= 0 && _startPositionY >= 0)
+ {
+ if (_startPositionX + _drawningMonorailWidth > width)
+ {
+ _startPositionX = width - _drawningMonorailWidth;
+ }
+ if (_startPositionY + _drawningMonorailHeight > height)
+ {
+ _startPositionY = height - _drawningMonorailHeight;
+ }
+ }
+
+ _pictureWidth = width;
+ _pictureHeight = height;
+ return true;
+ }
+
+ public void SetPosition(int x, int y, int width, int height)
+ {
+ if (_pictureHeight == null || _pictureWidth == null) return;
+
+ if (x + _drawningMonorailWidth > _pictureWidth || x < 0)
+ {
+ _startPositionX = (int)Math.random() * (_pictureWidth - _drawningMonorailWidth);
+ }
+ else
+ {
+ _startPositionX = x;
+ }
+
+ if (y + _drawningMonorailHeight > _pictureHeight || y < 0)
+ {
+ _startPositionY = (int)Math.random() * (_pictureHeight - _drawningMonorailHeight);
+ }
+ else
+ {
+ _startPositionY = y;
+ }
+ }
+
+ public boolean MoveTransport(DirectionType direction)
+ {
+ if (_pictureWidth == null || _pictureHeight == null) return false;
+
+ switch (direction)
+ {
+ case Right:
+ if (_startPositionX + _drawningMonorailWidth + _entityMonorail.Step < _pictureWidth)
+ {
+ _startPositionX += _entityMonorail.Step;
+ }
+ return true;
+ case Left:
+ if (_startPositionX - _entityMonorail.Step >= 0)
+ {
+ _startPositionX -= _entityMonorail.Step;
+ }
+ return true;
+ case Up:
+ if (_startPositionY - _entityMonorail.Step >= 0)
+ {
+ _startPositionY -= _entityMonorail.Step;
+ }
+ return true;
+ case Down:
+ if (_startPositionY + _drawningMonorailHeight + _entityMonorail.Step < _pictureHeight)
+ {
+ _startPositionY += _entityMonorail.Step;
+ }
+ return true;
+ default:
+ return false;
+ }
+ }
+
+ public void DrawTransport(Graphics g)
+ {
+ if (_startPositionX < 0 || _startPositionY < 0 || _pictureHeight== null || _pictureWidth== null) return;
+
+ Graphics2D g2 = (Graphics2D) g;
+ g.setColor(_entityMonorail.getBodyColor());
+
+ //Кузов монорельса
+ g.drawLine(_startPositionX + 8, _startPositionY + 10, _startPositionX + 13, _startPositionY);
+ g.drawLine(_startPositionX + 13, _startPositionY, _startPositionX + 80, _startPositionY);
+ g.drawLine(_startPositionX + 80, _startPositionY, _startPositionX + 80, _startPositionY + 25);
+ g.drawLine(_startPositionX + 80, _startPositionY + 25, _startPositionX + 8, _startPositionY + 25);
+ g.drawLine(_startPositionX + 8, _startPositionY + 25, _startPositionX + 8, _startPositionY + 10);
+ g.drawLine(_startPositionX + 8, _startPositionY + 10, _startPositionX + 30, _startPositionY + 10);
+ g.drawLine(_startPositionX + 39, _startPositionY + 10, _startPositionX + 80, _startPositionY + 10);
+
+ //Дверь
+ g.drawRect(_startPositionX + 30, _startPositionY + 5, 9, 15);
+
+ //Окна
+ g.setColor(_entityMonorail.getAdditionalColor());
+ g.drawRect(_startPositionX + 14, _startPositionY + 2, 5, 6);
+ g.drawRect(_startPositionX + 21, _startPositionY + 2, 5, 6);
+ g.drawRect(_startPositionX + 70, _startPositionY + 2, 5, 6);
+
+ //Связка монорельса
+ g.setColor(_entityMonorail.getBodyColor());
+ g.fillRect(_startPositionX + 80, _startPositionY + 2, 7, 22);
+
+ //Нижняя часть монорельса
+ int xPoly_LeftSide[] = {_startPositionX, _startPositionX + 8, _startPositionX + 72, _startPositionX + 36, _startPositionX + 36, _startPositionX + 15, _startPositionX + 15, _startPositionX};
+ int yPoly_LeftSide[] = {_startPositionY + 30, _startPositionY + 25, _startPositionY + 25, _startPositionY + 25, _startPositionY + 32, _startPositionY + 32, _startPositionY + 35, _startPositionY + 32};
+ g.fillPolygon(xPoly_LeftSide, yPoly_LeftSide, xPoly_LeftSide.length);
+
+ int xPoly_RightSide[] = {_startPositionX + 86, _startPositionX + 80, _startPositionX + 50, _startPositionX + 50, _startPositionX + 69, _startPositionX + 79, _startPositionX + 86};
+ int yPoly_RightSide[] = {_startPositionY + 30, _startPositionY + 25, _startPositionY + 25, _startPositionY + 32, _startPositionY + 32, _startPositionY + 35, _startPositionY + 32};
+ g.fillPolygon(xPoly_RightSide, yPoly_RightSide, xPoly_RightSide.length);
+
+ g.fillRect(_startPositionX + 8, _startPositionY + 25, 70, 3);
+
+ if (_entityMonorail.getMonorailTrack()) {
+ if (_entityMonorail.getCabin()) {
+ g.fillRect(_startPositionX, _startPositionY + 35, 170, 5);
+ }
+ else {
+ g.fillRect(_startPositionX, _startPositionY + 35, 86, 5);
+ }
+ }
+
+ //Колеса
+ int[] coordinatesX = new int[_wheels.getCountWheels()];
+ coordinatesX[0] = _startPositionX + 10;
+ coordinatesX[1] = _startPositionX + 65;
+
+ if (coordinatesX.length == 4) {
+ coordinatesX[2] = _startPositionX + 25;
+ coordinatesX[3] = _startPositionX + 50;
+ }
+ else if (coordinatesX.length == 3) {
+ Random rnd = new Random();
+ if (_wheelsSeed == 1) {
+ coordinatesX[2] = _startPositionX + 25;
+ }
+ else {
+ coordinatesX[2] = _startPositionX + 50;
+ }
+ }
+
+ _wheels.DrawWheels(g2, coordinatesX, _startPositionY + 30, _entityMonorail.getAdditionalColor());
+
+ if (_entityMonorail.getCabin()) {
+ int offset = 170;
+
+ //Кузов монорельса
+ g.drawLine(_startPositionX - 8 + offset, _startPositionY + 10, _startPositionX - 13 + offset, _startPositionY);
+ g.drawLine(_startPositionX - 13 + offset, _startPositionY, _startPositionX - 80 + offset, _startPositionY);
+ g.drawLine(_startPositionX - 80 + offset, _startPositionY, _startPositionX - 80 + offset, _startPositionY + 25);
+ g.drawLine(_startPositionX - 80 + offset, _startPositionY + 25, _startPositionX - 8 + offset, _startPositionY + 25);
+ g.drawLine(_startPositionX - 8 + offset, _startPositionY + 25, _startPositionX - 8 + offset, _startPositionY + 10);
+ g.drawLine(_startPositionX - 8 + offset, _startPositionY + 10, _startPositionX - 30 + offset, _startPositionY + 10);
+ g.drawLine(_startPositionX - 39 + offset, _startPositionY + 10, _startPositionX - 80 + offset, _startPositionY + 10);
+
+ //Дверь
+ g.drawRect(_startPositionX - 39 + offset, _startPositionY + 5, 9, 15);
+
+ //Окна
+ g.setColor(_entityMonorail.getAdditionalColor());
+ g.drawRect(_startPositionX - 20 + offset, _startPositionY + 2, 5, 6);
+ g.drawRect(_startPositionX - 27 + offset, _startPositionY + 2, 5, 6);
+ g.drawRect(_startPositionX - 76 + offset, _startPositionY + 2, 5, 6);
+
+ //Связка монорельса
+ g.setColor(_entityMonorail.getBodyColor());
+ g.fillRect(_startPositionX - 87 + offset, _startPositionY + 2, 7, 22);
+
+ //Нижняя часть монорельса
+ xPoly_LeftSide = new int[]{_startPositionX + offset, _startPositionX - 8 + offset, _startPositionX - 72 + offset, _startPositionX - 36 + offset, _startPositionX - 36 + offset, _startPositionX - 15 + offset, _startPositionX - 15 + offset, _startPositionX + offset};
+ yPoly_LeftSide = new int[] {_startPositionY + 30, _startPositionY + 25, _startPositionY + 25, _startPositionY + 25, _startPositionY + 32, _startPositionY + 32, _startPositionY + 35, _startPositionY + 32};
+ g.fillPolygon(xPoly_LeftSide, yPoly_LeftSide, xPoly_LeftSide.length);
+
+ xPoly_RightSide = new int[]{_startPositionX - 86 + offset, _startPositionX - 80 + offset, _startPositionX - 50 + offset, _startPositionX - 50 + offset, _startPositionX - 69 + offset, _startPositionX - 79 + offset, _startPositionX - 86 + offset};
+ yPoly_RightSide = new int[] {_startPositionY + 30, _startPositionY + 25, _startPositionY+ 25, _startPositionY + 32, _startPositionY + 32 , _startPositionY + 35, _startPositionY + 32};
+ g.fillPolygon(xPoly_RightSide, yPoly_RightSide, xPoly_RightSide.length);
+ g.fillRect(_startPositionX - 80 + offset, _startPositionY + 25, 70, 3);
+
+ //Колеса
+ coordinatesX = new int[_wheels.getCountWheels()];
+ coordinatesX[0] = _startPositionX - 20 + offset;
+ coordinatesX[1] = _startPositionX - 75 + offset;
+
+ if (coordinatesX.length == 4) {
+ coordinatesX[2] = _startPositionX - 35 + offset;
+ coordinatesX[3] = _startPositionX - 60 + offset;
+ }
+ else if (coordinatesX.length == 3) {
+ Random rnd = new Random();
+ if (_wheelsSeed == 1) {
+ coordinatesX[2] = _startPositionX - 35 + offset;
+ }
+ else {
+ coordinatesX[2] = _startPositionX - 60 + offset;
+ }
+ }
+
+ _wheels.DrawWheels(g2, coordinatesX , _startPositionY + 30, _entityMonorail.getAdditionalColor());
+ }
+
+ }
+}
diff --git a/ProjectMonorail/src/DrawingWheels.java b/ProjectMonorail/src/DrawingWheels.java
new file mode 100644
index 0000000..6693c95
--- /dev/null
+++ b/ProjectMonorail/src/DrawingWheels.java
@@ -0,0 +1,26 @@
+import java.awt.*;
+
+public class DrawingWheels {
+
+ private CountWheels _wheels;
+
+ public void SetCountWheels(int Count){
+ for (CountWheels temp: CountWheels.values())
+ if (temp.getCountWheels() == Count){
+ _wheels=temp;
+ return;
+ }
+ }
+
+ public int getCountWheels() {
+ return _wheels.getCountWheels();
+ }
+
+ public void DrawWheels(Graphics2D g,int startPosX[], int startPosY, Color color) {
+ g.setColor(color);
+ for (int i = 0; i < startPosX.length; i++) {
+ g.drawOval(startPosX[i], startPosY, 10, 10);
+ g.fillOval(startPosX[i], startPosY, 10, 10);
+ }
+ }
+}
diff --git a/ProjectMonorail/src/EntityModernMonorail.java b/ProjectMonorail/src/EntityModernMonorail.java
new file mode 100644
index 0000000..84be183
--- /dev/null
+++ b/ProjectMonorail/src/EntityModernMonorail.java
@@ -0,0 +1,38 @@
+import java.awt.*;
+import java.util.Random;
+
+public class EntityModernMonorail {
+ public float Step;
+ private int _speed;
+ private float _weight;
+ private Color _bodyColor;
+ private Color _additionalColor;
+ private boolean _monorailTrack;
+ private boolean _cabin;
+
+ public int getSpeed() {
+ return _speed;
+ }
+ public float getWeight() {
+ return _weight;
+ }
+ public Color getBodyColor() {
+ return _bodyColor;
+ }
+ public Color getAdditionalColor() {return _additionalColor;}
+ public boolean getMonorailTrack() {return _monorailTrack;}
+ public boolean getCabin() {return _cabin;}
+
+ public void Initialization(int speed, float weight, Color bodyColor, Color additionalColor, boolean monorailTrack, boolean cabin){
+ Random rnd = new Random();
+ _speed = speed <= 0 ? rnd.nextInt(50)+10 : speed;
+ _weight = weight <= 0 ? rnd.nextInt(100)+500 : weight;
+ _bodyColor = bodyColor;
+ _additionalColor = additionalColor;
+ _monorailTrack = monorailTrack;
+ _cabin = cabin;
+
+ Step = _speed * 100/ (int)_weight;
+ }
+}
+
diff --git a/ProjectMonorail/src/FormModernMonorail.java b/ProjectMonorail/src/FormModernMonorail.java
new file mode 100644
index 0000000..29c88e0
--- /dev/null
+++ b/ProjectMonorail/src/FormModernMonorail.java
@@ -0,0 +1,127 @@
+import javax.swing.*;
+import java.awt.*;
+import java.awt.event.ComponentAdapter;
+import java.awt.event.ComponentEvent;
+public class FormModernMonorail extends JFrame{
+ private int Width;
+ private int Height;
+
+ private JPanel BottomPanel = new JPanel();
+ private JPanel CreatePanel = new JPanel();
+ private JPanel BottomAndCreatePanel = new JPanel();
+ private JPanel DimentionPanel = new JPanel();
+ private JPanel UPanel = new JPanel();
+ private JPanel DPanel = new JPanel();
+ private JPanel LRPanel = new JPanel();
+
+ private DrawingField field = new DrawingField(this);
+
+ private JButton ButtonCreate=new JButton("Create Monorail");
+
+ private Icon _iconUp = new ImageIcon("Resource\\Arrows\\ArrowUp.png");
+ private Icon _iconDown = new ImageIcon("Resource\\Arrows\\ArrowDown.png");
+ private Icon _iconRight = new ImageIcon("Resource\\Arrows\\ArrowRight.png");
+ private Icon _iconLeft = new ImageIcon("Resource\\Arrows\\ArrowLeft.png");
+
+ private JButton ButtonUp=new JButton(_iconUp);
+ private JButton ButtonDown=new JButton(_iconDown);
+ private JButton ButtonRight=new JButton(_iconRight);
+ private JButton ButtonLeft=new JButton(_iconLeft);
+
+ public FormModernMonorail(){
+ super("Modern Monorail");
+ setSize(600,480);
+ Width=getWidth();
+ Height=getHeight();
+ ShowWindow();
+ RefreshWindow();
+ setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
+ setVisible(true);
+ }
+
+ public void ShowWindow(){
+
+ Dimension dimen=new Dimension(30,30);
+
+ ButtonUp.setPreferredSize(dimen);
+ ButtonUp.addActionListener(e->{
+ field.UpButtonAction();
+ repaint();
+ });
+
+ ButtonDown.setPreferredSize(dimen);
+ ButtonDown.addActionListener(e->{
+ field.DownButtonAction();
+ repaint();
+ });
+
+ ButtonRight.setPreferredSize(dimen);
+ ButtonRight.addActionListener(e->{
+ field.RightButtonAction();
+ repaint();
+ });
+
+ ButtonLeft.setPreferredSize(dimen);
+ ButtonLeft.addActionListener(e->{
+ field.LeftButtonAction();
+ repaint();
+ });
+
+ LRPanel.setLayout(new FlowLayout(FlowLayout.CENTER,50,0));
+ LRPanel.setBackground(new Color(0,0,0,0));
+ LRPanel.add(ButtonLeft);
+ LRPanel.add(ButtonRight);
+
+ UPanel.setLayout(new FlowLayout());
+ UPanel.setBackground(new Color(0,0,0,0));
+ UPanel.add(ButtonUp);
+
+ DPanel.setLayout(new FlowLayout());
+ DPanel.setBackground(new Color(0,0,0,0));
+ DPanel.add(ButtonDown);
+
+ DimentionPanel.setLayout(new BoxLayout(DimentionPanel,BoxLayout.Y_AXIS));
+ DimentionPanel.setBackground(new Color(0,0,0,0));
+ DimentionPanel.add(UPanel);
+ DimentionPanel.add(LRPanel);
+ DimentionPanel.add(DPanel);
+ add(DimentionPanel);
+
+ CreatePanel.setLayout(new FlowLayout());
+ CreatePanel.setBackground(new Color(0,0,0,0));
+ CreatePanel.add(ButtonCreate);
+ ButtonCreate.addActionListener(e->{
+ field.CreateButtonAction();
+ repaint();
+ });
+
+ BottomPanel.setLayout(new FlowLayout());
+ BottomPanel.setBackground(new Color(0,0,0,0));
+
+ BottomAndCreatePanel.setLayout(new BoxLayout(BottomAndCreatePanel,BoxLayout.Y_AXIS));
+ BottomAndCreatePanel.setBackground(new Color(0,0,0,0));
+ BottomAndCreatePanel.add(CreatePanel);
+ BottomAndCreatePanel.add(BottomPanel);
+
+ add(BottomAndCreatePanel);
+ add(field);
+
+ addComponentListener(new ComponentAdapter() {
+ @Override
+ public void componentResized(ComponentEvent e) {
+ super.componentResized(e);
+ Width=getWidth();
+ Height=getHeight();
+
+ field.ResizeField();
+ repaint();
+ RefreshWindow();
+ }
+ });
+ }
+ public void RefreshWindow(){
+ field.setBounds(0,0,Width,Height);
+ BottomAndCreatePanel.setBounds(-220,Height-110,Width,80);
+ DimentionPanel.setBounds(Width-170,Height-170,190,140);
+ }
+}
diff --git a/ProjectMonorail/src/Program.java b/ProjectMonorail/src/Program.java
new file mode 100644
index 0000000..b6da7d7
--- /dev/null
+++ b/ProjectMonorail/src/Program.java
@@ -0,0 +1,5 @@
+public class Program {
+ public static void main(String[] args){
+ new FormModernMonorail();
+ }
+}