diff --git a/RadarAirplane/src/AirplaneMixer.java b/RadarAirplane/src/AirplaneMixer.java new file mode 100644 index 0000000..cad043d --- /dev/null +++ b/RadarAirplane/src/AirplaneMixer.java @@ -0,0 +1,50 @@ +import java.util.Random; + +public class AirplaneMixer { + private T[] airplanes; + private U[] portholes; + + public AirplaneMixer(int countAirplane, int countPortholes) { + airplanes = (T[])(new EntityAirPlane[countAirplane]); + portholes = (U[])(new IDrawingPorthole[countPortholes]); + } + + public int add(T a) { + int index = 0; + while(index < airplanes.length && airplanes[index] != null) index++; + + if(index == airplanes.length) return -1; + + airplanes[index] = a; + return index; + } + + public int add(U e) { + int index = 0; + while(index < portholes.length && portholes[index] != null) index++; + + if(index == portholes.length) return -1; + + portholes[index] = e; + return index; + } + + public DrawingEntityPlain constructAirplane(int width, int height) { + Random rnd = new Random(); + + DrawingEntityPlain air; + + T selectedAirplane = airplanes[rnd.nextInt(0, airplanes.length)]; + U selectedPortholes = portholes[rnd.nextInt(0, portholes.length)]; + + DrawingEntityPlain result; + + if(selectedAirplane instanceof EntityRadarPlain) { + result = new DrawingRadarPlain(selectedAirplane, selectedPortholes); + } + else result = new DrawingEntityPlain(selectedAirplane, selectedPortholes); + + result.SetPosition(10, 10, width, height); + return result; + } +} diff --git a/RadarAirplane/src/DrawingEntityPlain.java b/RadarAirplane/src/DrawingEntityPlain.java index e74d87e..1642cad 100644 --- a/RadarAirplane/src/DrawingEntityPlain.java +++ b/RadarAirplane/src/DrawingEntityPlain.java @@ -42,6 +42,11 @@ class DrawingEntityPlain _AirplaneWidth = airPlaneWidth; _AirplaneHeight = airPlaneHeight; } + public DrawingEntityPlain(EntityAirPlane entityAirPlane, IDrawingPorthole iDrawingPorthole){ + Airplane = entityAirPlane; + drawingPortholes = iDrawingPorthole; + } + public void SetPosition(int x, int y, int width, int height) { if (width < _AirplaneWidth || height < _AirplaneHeight) return; diff --git a/RadarAirplane/src/DrawingRadarPlain.java b/RadarAirplane/src/DrawingRadarPlain.java index 9781da8..1602af3 100644 --- a/RadarAirplane/src/DrawingRadarPlain.java +++ b/RadarAirplane/src/DrawingRadarPlain.java @@ -7,6 +7,9 @@ public class DrawingRadarPlain extends DrawingEntityPlain super(speed, weight, bodyColor, 240, 150); Airplane = new EntityRadarPlain(speed, weight, bodyColor, dopColor, Radar, OilBox); } + public DrawingRadarPlain(EntityAirPlane entityAirPlane, IDrawingPorthole iDrawingPorthole){ + super(entityAirPlane,iDrawingPorthole); + } @Override public void DrawTransport(Graphics2D g) { diff --git a/RadarAirplane/src/FormAirPlane.form b/RadarAirplane/src/FormAirPlane.form index 9f861cb..1fdcec6 100644 --- a/RadarAirplane/src/FormAirPlane.form +++ b/RadarAirplane/src/FormAirPlane.form @@ -52,19 +52,17 @@ - + - - - + - + @@ -77,7 +75,7 @@ - + @@ -90,7 +88,7 @@ - + @@ -103,7 +101,7 @@ - + @@ -116,7 +114,7 @@ - + @@ -127,8 +125,24 @@ + + + + + + + + + + + + + + + + - + \ No newline at end of file diff --git a/RadarAirplane/src/FormAirPlane.java b/RadarAirplane/src/FormAirPlane.java index 7e93acc..ef85972 100644 --- a/RadarAirplane/src/FormAirPlane.java +++ b/RadarAirplane/src/FormAirPlane.java @@ -1,11 +1,10 @@ import javax.swing.*; -import javax.swing.border.LineBorder; import java.awt.*; import java.awt.event.ComponentAdapter; import java.awt.event.ComponentEvent; import java.util.Random; -public class FormAirPlane implements Form { +public class FormAirPlane extends JDialog implements Form { private JButton createButton; private JButton upButton; private JButton rightButton; @@ -16,22 +15,18 @@ public class FormAirPlane implements Form { private JLabel speedLabel; private JLabel weightLabel; private JLabel colorLabel; - + private JButton createModifButton; + private JButton selectButton; DrawingEntityPlain _airPlane; + private DrawingEntityPlain selectedPlane; - private JFrame jframe = getFrame(); - - private JFrame getFrame() { - JFrame frame = new JFrame(); - frame.setVisible(true); - frame.setBounds(300, 100, 800, 600); - frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); - return frame; + public DrawingEntityPlain getSelectedPlane() { + return selectedPlane; } public void run() { - jframe.add(mainPanel); + add(mainPanel); Canvas canv = new Canvas(this); DrawPlace.add(canv); @@ -40,8 +35,11 @@ public class FormAirPlane implements Form { Dimension canvSize = canv.getSize(); Random rnd = new Random(); - _airPlane = new DrawingEntityPlain(rnd.nextInt(100, 300), rnd.nextInt(1000, 2000), - new Color(rnd.nextInt(0, 256), rnd.nextInt(0, 256), rnd.nextInt(0, 256))); + Color color = JColorChooser.showDialog(this, "Цвет", Color.BLACK); + + if(color == null) color = Color.BLACK; + + _airPlane = new DrawingEntityPlain(rnd.nextInt(100, 300), rnd.nextInt(1000, 2000), color); _airPlane.SetPosition((int)rnd.nextInt(10, 100), (int)rnd.nextInt(10, 100), canvSize.width, canvSize.height); @@ -55,12 +53,42 @@ public class FormAirPlane implements Form { canv.repaint(); }); - jframe.addComponentListener(new ComponentAdapter() { + createModifButton.addActionListener(e -> { + + Dimension canvSize = canv.getSize(); + Random rnd = new Random(); + + Color color = JColorChooser.showDialog(this, "Цвет", Color.BLACK); + Color dopColor = JColorChooser.showDialog(this, "Цвет", Color.BLACK); + + if(color == null) color = Color.BLACK; + if(dopColor == null) dopColor = Color.BLACK; + + _airPlane = new DrawingRadarPlain(rnd.nextInt(100, 300), rnd.nextInt(1000, 2000), + color, dopColor, + rnd.nextInt(0, 2) == 1, rnd.nextInt(0, 2) == 1); + + _airPlane.SetPosition((int)rnd.nextInt(10, 100), (int)rnd.nextInt(10, 100), canvSize.width, canvSize.height); + + Color bodyColor = _airPlane.Airplane.BodyColor; + String colorString = "(" + bodyColor.getRed() + ", " + bodyColor.getGreen() + ", " + bodyColor.getBlue() + ")"; + + speedLabel.setText("Скорость: " + _airPlane.Airplane.Speed + " "); + weightLabel.setText("Вес: " + _airPlane.Airplane.Weight + " "); + colorLabel.setText("Цвет: " + colorString); + + canv.repaint(); + }); + + selectButton.addActionListener(e -> { + selectedPlane = _airPlane; + dispose(); + }); + addComponentListener(new ComponentAdapter() { @Override public void componentResized(ComponentEvent e) { if(_airPlane == null) return; _airPlane.ChangeBorders(canv.getSize().width, canv.getSize().height); - jframe.revalidate(); } }); diff --git a/RadarAirplane/src/MapWithSetPlane.java b/RadarAirplane/src/MapWithSetPlane.java new file mode 100644 index 0000000..658b32d --- /dev/null +++ b/RadarAirplane/src/MapWithSetPlane.java @@ -0,0 +1,182 @@ +import java.awt.*; +import java.awt.image.BufferedImage; + +public class MapWithSetPlane +{ + private int _pictureWidth; + private int _pictureHeight; + private int _placeSizeWidth = 210; + private int _placeSizeHeight = 170; + private SetPlaneGeneric _setPlane; + private U _map; + + public MapWithSetPlane(int picWidth, int picHeight, U map) + { + int width = picWidth / _placeSizeWidth; + int height = picHeight / _placeSizeHeight; + _setPlane = new SetPlaneGeneric(width * height); + _pictureWidth = picWidth; + _pictureHeight = picHeight; + _map = map; + } + + public int addAirPlane(T airplane) + { + return _setPlane.Insert(airplane); + } + + public T removeAirPlane(int position) + { + return _setPlane.Remove(position); + } + + public Image ShowSet() + { + BufferedImage img = new BufferedImage(_pictureWidth, _pictureHeight, BufferedImage.TYPE_INT_ARGB); + Graphics2D gr = (Graphics2D) img.getGraphics(); + + DrawBackground(gr); + DrawPlanes(gr); + + return img; + } + + public Image ShowOnMap() + { + BufferedImage img = new BufferedImage(_pictureWidth, _pictureHeight, BufferedImage.TYPE_INT_ARGB); + Graphics2D g = (Graphics2D) img.getGraphics(); + + Shaking(); + for (int i = 0; i < _setPlane.getCount(); i++) + { + var car = _setPlane.Get(i); + if (car != null) + { + _map.CreateMap(_pictureWidth, _pictureHeight, car); + _map.DrawMapWithObject(g); + return img; + } + } + + return img; + } + + public Image MoveObject(Direction direction) + { + BufferedImage img = new BufferedImage(_pictureWidth, _pictureHeight, BufferedImage.TYPE_INT_ARGB); + Graphics2D g = (Graphics2D) img.getGraphics(); + + if (_map != null) + { + _map.MoveObject(direction); + _map.DrawMapWithObject(g); + } + return img; + } + + private void Shaking() + { + int j = _setPlane.getCount() - 1; + for (int i = 0; i < _setPlane.getCount(); i++) + { + if (_setPlane.Get(i) == null) + { + for (; j > i; j--) + { + var car = _setPlane.Get(j); + if (car != null) + { + _setPlane.Insert(car, i); + _setPlane.Remove(j); + break; + } + } + if (j <= i) + { + return; + } + } + } + } + + private void DrawBackground(Graphics2D g) + { + + + g.setPaint(new Color(160, 160, 160)); + g.fillRect(0, 0, _pictureWidth , _pictureHeight ); + + g.setPaint(Color.black); + g.setStroke(new BasicStroke(3)); + + for (int i = 0; i < _pictureWidth / _placeSizeWidth; i++) + { + for (int j = 0; j < _pictureHeight / _placeSizeHeight + 1; ++j) + { + g.drawLine(i * _placeSizeWidth, j * _placeSizeHeight, i * + _placeSizeWidth + _placeSizeWidth / 2, j * _placeSizeHeight); + } + g.drawLine( i * _placeSizeWidth, 0, i * _placeSizeWidth, + (_pictureHeight / _placeSizeHeight) * _placeSizeHeight); + } + + g.setStroke(new BasicStroke(1)); + } + + private void DrawPlanes(Graphics2D g) + { + int CountWidth = _pictureWidth / _placeSizeWidth; + + int x = _pictureWidth - _placeSizeWidth - _placeSizeWidth/2 - _placeSizeWidth / 4; + int y = _placeSizeHeight/4; + + for (int k = 0; k < _setPlane.getCount(); k++) + { + if (_setPlane.Get(k) != null) + { + if ((k+1) % CountWidth != 0 || k ==0) + { + _setPlane.Get(k).SetObject(x, y, _pictureWidth, _pictureHeight); + _setPlane.Get(k).DrawningObject(g); + x -= _placeSizeWidth; + } + else + { + + _setPlane.Get(k).SetObject(x, y, _pictureWidth, _pictureHeight); + _setPlane.Get(k).DrawningObject(g); + x = _pictureWidth - _placeSizeWidth - _placeSizeWidth / 2 - _placeSizeWidth / 4; + y += _placeSizeHeight ; + + } + } + if (_setPlane.Get(k) == null) + { + if ((k + 1) % CountWidth != 0 || k ==0) + x -= _placeSizeWidth; + else + { + x = _pictureWidth - _placeSizeWidth - _placeSizeWidth / 2 - _placeSizeWidth / 4; + y += _placeSizeHeight; + } + } + } + + } + + + /*int width = _pictureWidth / _placeSizeWidth; + + for (int i = 0; i < _setPlane.getCount(); i++) + { + int x = i % width; + int y = i / width; + + T current =_setPlane.Get(i); + + if(current == null) continue; + + current.SetObject(x * _placeSizeWidth, y * _placeSizeHeight, _pictureWidth, _pictureHeight); + current.DrawningObject(g); + }*/ +} \ No newline at end of file diff --git a/RadarAirplane/src/PortholeFabric.java b/RadarAirplane/src/PortholeFabric.java new file mode 100644 index 0000000..f4de365 --- /dev/null +++ b/RadarAirplane/src/PortholeFabric.java @@ -0,0 +1,17 @@ +import java.awt.*; +import java.util.Random; + +public class PortholeFabric { + public static IDrawingPorthole createRandom(Color color) { + Random rnd = new Random(); + + int type = rnd.nextInt(0, 3); + + return switch(type) { + case 0 -> new DrawingPorthole(rnd.nextInt(1, 40), color); + case 1 -> new DrawingSquarePorthole(rnd.nextInt(1, 40), color); + case 2 -> new DrawingTrianglePorthole(rnd.nextInt(1, 40), color); + default -> null; + }; + } +} \ No newline at end of file diff --git a/RadarAirplane/src/Program.java b/RadarAirplane/src/Program.java index 1efe066..a74f0dd 100644 --- a/RadarAirplane/src/Program.java +++ b/RadarAirplane/src/Program.java @@ -3,6 +3,6 @@ import java.awt.*; public class Program { public static void main(String[] args) { - new formMap().run(); + new formPlaneGenerator().run(); } } \ No newline at end of file diff --git a/RadarAirplane/src/SetPlaneGeneric.java b/RadarAirplane/src/SetPlaneGeneric.java new file mode 100644 index 0000000..7037d1d --- /dev/null +++ b/RadarAirplane/src/SetPlaneGeneric.java @@ -0,0 +1,50 @@ +public class SetPlaneGeneric +{ + private T[] _places; + + public int getCount() { + return _places.length; + } + + public SetPlaneGeneric(int count) + { + _places = (T[])(new Object[count]); + } + public int Insert(T plane) + { + for(int i = 0; i < _places.length; i++) + { + if (_places[i] == null) + { + _places[i] = plane; + return i; + } + } + return -1; + } + public int Insert(T plane, int position) + { + int index = position; + + while (_places[index] != null && index < _places.length) index++; + + if (index == _places.length) return -1; + for (int i = index; i > position; --i) _places[i] = _places[i - 1]; + + _places[position] = plane; + return position; + } + + public T Remove(int position) + { + if(position >= _places.length) return null; + T res = _places[position]; + _places[position] = null; + return res; + } + + public T Get(int position) + { + return _places[position]; + } +} \ No newline at end of file diff --git a/RadarAirplane/src/formMapWithSetPlane.form b/RadarAirplane/src/formMapWithSetPlane.form new file mode 100644 index 0000000..f4a798b --- /dev/null +++ b/RadarAirplane/src/formMapWithSetPlane.form @@ -0,0 +1,163 @@ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
\ No newline at end of file diff --git a/RadarAirplane/src/formMapWithSetPlane.java b/RadarAirplane/src/formMapWithSetPlane.java new file mode 100644 index 0000000..bb5fede --- /dev/null +++ b/RadarAirplane/src/formMapWithSetPlane.java @@ -0,0 +1,175 @@ +import javax.swing.*; +import javax.swing.text.DefaultFormatterFactory; +import javax.swing.text.MaskFormatter; +import java.awt.*; +import java.text.ParseException; +import java.util.Objects; + +public class formMapWithSetPlane implements Form { + private JPanel MainPane; + private JButton buttonAdd; + private JComboBox comboBoxSelectorMap; + private JTextField textBoxPosition; + private JButton buttonRemove; + private JButton buttonShowStorage; + private JButton buttonShowOnMap; + private JButton upButton; + private JButton leftButton; + private JButton rightButton; + private JButton downButton; + private JPanel drawPanel; + + + private MapWithSetPlane _mapCarsCollectionGeneric; + private Canvas canv = new Canvas(this); + + JFrame jFrame = getFrame(); + Image img; + + private JFrame getFrame() { + JFrame frame = new JFrame(); + frame.setVisible(true); + frame.setBounds(300, 100, 800, 600); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + return frame; + } + + + public void run() { + jFrame.add(MainPane); + drawPanel.add(canv); + + comboBoxSelectorMap.setSelectedIndex(-1); + + comboBoxSelectorMap.addActionListener(e -> { + AbstractMap map = null; + switch (comboBoxSelectorMap.getSelectedItem().toString()) + { + case "Простая карта": + map = new SimpleMap(); + break; + case "Моя карта": + map = new MyMap(); + break; + } + if (map != null) + { + Dimension canvSize = canv.getSize(); + _mapCarsCollectionGeneric = new MapWithSetPlane( + canvSize.width, canvSize.height, map); + } + else + { + _mapCarsCollectionGeneric = null; + } + }); + + buttonAdd.addActionListener(e -> { + if (_mapCarsCollectionGeneric == null) return; + + FormAirPlane dialog = new FormAirPlane(); + dialog.run(); + dialog.setSize(800, 500); + dialog.setModalityType(Dialog.ModalityType.APPLICATION_MODAL); + dialog.setDefaultCloseOperation(JDialog.DISPOSE_ON_CLOSE); + + dialog.setVisible(true); + + if (dialog.getSelectedPlane() == null) return; + + DrawingObjectPlain aircraft = new DrawingObjectPlain(dialog.getSelectedPlane()); + if (_mapCarsCollectionGeneric.addAirPlane(aircraft) != -1) + { + JOptionPane.showMessageDialog(jFrame, "Объект добавлен"); + img = _mapCarsCollectionGeneric.ShowSet(); + canv.repaint(); + } + else + { + JOptionPane.showMessageDialog(jFrame, "Не удалось добавить объект"); + } + }); + + buttonRemove.addActionListener(e -> { + if(_mapCarsCollectionGeneric == null) return; + + String text = textBoxPosition.getText(); + if(text.isEmpty()) return; + + if(JOptionPane.showConfirmDialog( + jFrame, + "Вы действительно хотите удалить объект?", + "Удаление", + JOptionPane.YES_NO_OPTION) == JOptionPane.NO_OPTION) return; + + int pos; + try { + pos = Integer.parseInt(text); + } catch (Exception err) { + return; + } + pos = Integer.parseInt(text); + + if(_mapCarsCollectionGeneric.removeAirPlane(pos) != null) { + JOptionPane.showMessageDialog(jFrame, "Объект удален"); + img = _mapCarsCollectionGeneric.ShowSet(); + canv.repaint(); + } else { + JOptionPane.showMessageDialog(jFrame, "Не удалось удалить объект"); + } + }); + + buttonShowStorage.addActionListener(e -> { + if (_mapCarsCollectionGeneric == null) + { + return; + } + + img = _mapCarsCollectionGeneric.ShowSet(); + canv.repaint(); + }); + + buttonShowOnMap.addActionListener(e -> { + if (_mapCarsCollectionGeneric == null) + { + return; + } + + img = _mapCarsCollectionGeneric.ShowOnMap(); + canv.repaint(); + }); + + leftButton.addActionListener(e -> { + if(_mapCarsCollectionGeneric == null) return; + img = _mapCarsCollectionGeneric.MoveObject(Direction.Left); + canv.repaint(); + }); + + rightButton.addActionListener(e -> { + if(_mapCarsCollectionGeneric == null) return; + img = _mapCarsCollectionGeneric.MoveObject(Direction.Right); + canv.repaint(); + }); + + upButton.addActionListener(e -> { + if(_mapCarsCollectionGeneric == null) return; + img = _mapCarsCollectionGeneric.MoveObject(Direction.Up); + canv.repaint(); + }); + + downButton.addActionListener(e -> { + + if(_mapCarsCollectionGeneric == null) return; + img = _mapCarsCollectionGeneric.MoveObject(Direction.Down); + canv.repaint(); + }); + + + } + + @Override + public void Draw(Graphics2D g) { + if(img == null) return; + g.drawImage(img, 0, 0, null); + } +} \ No newline at end of file diff --git a/RadarAirplane/src/formPlaneGenerator.form b/RadarAirplane/src/formPlaneGenerator.form new file mode 100644 index 0000000..803c4e2 --- /dev/null +++ b/RadarAirplane/src/formPlaneGenerator.form @@ -0,0 +1,29 @@ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + +
\ No newline at end of file diff --git a/RadarAirplane/src/formPlaneGenerator.java b/RadarAirplane/src/formPlaneGenerator.java new file mode 100644 index 0000000..8b7a50d --- /dev/null +++ b/RadarAirplane/src/formPlaneGenerator.java @@ -0,0 +1,76 @@ +import javax.swing.*; +import java.awt.*; +import java.util.Random; + +public class formPlaneGenerator implements Form { + private JButton generateButton; + private JPanel drawPanel; + private JPanel mainPanel; + private Canvas canv = new Canvas(this); + + private DrawingEntityPlain airplane; + private AirplaneMixer mixer = new AirplaneMixer<>(10, 20); + private JFrame jframe = getFrame(); + + private JFrame getFrame() { + JFrame frame = new JFrame(); + frame.setVisible(true); + frame.setBounds(300, 100, 400, 300); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + return frame; + } + + public void run() { + jframe.add(mainPanel); + drawPanel.add(canv); + + Random rnd = new Random(); + + for(int i = 0; i < 10; ++i) { + if(rnd.nextBoolean()) { + mixer.add(new EntityAirPlane(rnd.nextInt(100, 250), rnd.nextInt(1000, 2000), + new Color( + rnd.nextInt(0, 255), + rnd.nextInt(0, 255), + rnd.nextInt(0, 255) + ))); + continue; + } + + mixer.add(new EntityRadarPlain(rnd.nextInt(100, 250), rnd.nextInt(1000, 2000), + new Color( + rnd.nextInt(0, 255), + rnd.nextInt(0, 255), + rnd.nextInt(0, 255) + ), + new Color( + rnd.nextInt(0, 255), + rnd.nextInt(0, 255), + rnd.nextInt(0, 255) + ), + rnd.nextBoolean(), rnd.nextBoolean() + )); + } + + for(int i = 0; i < 20; ++i) { + Color randomColor = new Color( + rnd.nextInt(0, 255), + rnd.nextInt(0, 255), + rnd.nextInt(0, 255)); + + mixer.add(PortholeFabric.createRandom(randomColor)); + } + + generateButton.addActionListener(e -> { + Dimension canvSize = canv.getSize(); + airplane = mixer.constructAirplane(canvSize.width, canvSize.height); + canv.repaint(); + }); + } + + @Override + public void Draw(Graphics2D g) { + if(airplane == null) return; + airplane.DrawTransport(g); + } +} \ No newline at end of file