From 738d5f9a463052dda2a53fcfed2c562617b0d1ec Mon Sep 17 00:00:00 2001 From: Maxim Boyko Date: Thu, 14 Mar 2024 10:59:47 +0400 Subject: [PATCH] lab1 ready --- ProjectElectroTrans/ProjectElectroTrans.iml | 1 + ProjectElectroTrans/Resources/arrowDown.png | Bin 0 -> 965 bytes ProjectElectroTrans/Resources/arrowLeft.png | Bin 0 -> 1005 bytes ProjectElectroTrans/Resources/arrowRight.png | Bin 0 -> 978 bytes ProjectElectroTrans/Resources/arrowUp.png | Bin 0 -> 1012 bytes ProjectElectroTrans/src/DirectionType.java | 6 + .../src/DrawningElectroTrans.java | 184 ++++++++++++++++++ .../src/DrawningElectroTransWheels.java | 24 +++ .../src/EntityElectroTrans.java | 41 ++++ ProjectElectroTrans/src/FormElectroTrans.form | 93 +++++++++ ProjectElectroTrans/src/FormElectroTrans.java | 114 +++++++++++ ProjectElectroTrans/src/Main.java | 12 +- ProjectElectroTrans/src/WheelsCount.java | 14 ++ 13 files changed, 488 insertions(+), 1 deletion(-) create mode 100644 ProjectElectroTrans/Resources/arrowDown.png create mode 100644 ProjectElectroTrans/Resources/arrowLeft.png create mode 100644 ProjectElectroTrans/Resources/arrowRight.png create mode 100644 ProjectElectroTrans/Resources/arrowUp.png create mode 100644 ProjectElectroTrans/src/DirectionType.java create mode 100644 ProjectElectroTrans/src/DrawningElectroTrans.java create mode 100644 ProjectElectroTrans/src/DrawningElectroTransWheels.java create mode 100644 ProjectElectroTrans/src/EntityElectroTrans.java create mode 100644 ProjectElectroTrans/src/FormElectroTrans.form create mode 100644 ProjectElectroTrans/src/FormElectroTrans.java create mode 100644 ProjectElectroTrans/src/WheelsCount.java diff --git a/ProjectElectroTrans/ProjectElectroTrans.iml b/ProjectElectroTrans/ProjectElectroTrans.iml index c90834f..d5b343a 100644 --- a/ProjectElectroTrans/ProjectElectroTrans.iml +++ b/ProjectElectroTrans/ProjectElectroTrans.iml @@ -3,6 +3,7 @@ + diff --git a/ProjectElectroTrans/Resources/arrowDown.png b/ProjectElectroTrans/Resources/arrowDown.png new file mode 100644 index 0000000000000000000000000000000000000000..2d51306b4744a97dc0e59ef5af54c90401b042ab GIT binary patch literal 965 zcmeAS@N?(olHy`uVBq!ia0vp^av;nBBpBqPKh^;$rX+877l!}s{b%+Ad7K3vk;M!Q ze1}1p@p%4<6rdn`iKnkC`wM11HgV3Ed38EKA;$b7zYxari^^vKIdQ2Go@u_m3|c@o z2Ll_U5Cbzv2@o+Os=fURW#3jNzvTANa`edDA)u%t&?FXS*L))~ zQ!zu{>D|nm)w{pVsTM4{f1rBDoWnJnzr|IbJs`F}>-h;rMG+gr$aRnYA3ZxIU$T?i zDCn5p#-h2a1%w|Rd(KntX!l^_O5>-Gk1j1bf5)#;#QD>svrBd^bK1M5_wk-M9!<9+ z4a5)#LSlL`Bb!mi_OOBf~Y`RR5rG-K_ zZeZH+`QeTOuQ-bixp(dptoc|FtX`L^eIsX`zQxz?a@*D=O}793I8l0eWPV~;&bPeX&Zolj kR^9LWxcxrg)ur3_Pftwk{2Z#54U9_$Pgg&ebxsLQ07u_nH~;_u literal 0 HcmV?d00001 diff --git a/ProjectElectroTrans/Resources/arrowLeft.png b/ProjectElectroTrans/Resources/arrowLeft.png new file mode 100644 index 0000000000000000000000000000000000000000..2c406e851276b58c97852701a1cfdefe9432fda5 GIT binary patch literal 1005 zcmeAS@N?(olHy`uVBq!ia0vp^av;nBBpBqPKh^;$rX+877l!}s{b%+Ad7K3vk;M!Q ze1}1p@p%4<6rdn`iKnkC`wM11HgV3Ed38EKA;$b7zYxari^^vKIdQ2Go@u_m3|c@o z2Ll_U5Cbzv2@oe9Oqx+J-LZPkx|gGBUowGl|KxN z7Pvbxz3OO*z5PCQ-rk!Ykuxs8eOqbs`Pet(5~q-}PnByXTeWqby>(mpX0=yUvzV^b zs-#_Id&0z-WtD6%-HCaj8(FgDg!xsO*OTAP`!ezJvu8W|e;!xfv&J>;*_xf#56C|I zr&Ygjsf(n`{+x<6kG9TxZg*Tz;BukvCz;p-Oz)2s1U1aEtdDble1XY&zTKX9z5Z#U z7c>^t&pTMEdsFQ|<9$BmperRc=eO!Dco;A4ba~sob}qNye^nlcO`THd*8aWVUg(22 zM`gDxd!q5ioI!VW&zJM1_glQI_}@#-P6^doTX}tPGq3fh2KUQJM$ZlFZkOHDd3i7+ z_W9iRGtM6<{U3TWKH=!9brtPN294HU&GG$>w>RA2-?rUsyIfx10;|q>oppPimG^o$*ZF_e(#I7--~dMGxZL7 z#jZ_WpUs|<>Nox0t_$7okJi-jo-%#;|N6?E>(uyDm;T?u_O#DXeRk}po@tx*S>>*( a<#hX!T5R}r!CYXRGkCiCxvXdO-0aPLhR}zp}k(v{bS`?a>SrWluY;Iwoqp;Rn-V&#xNT{O3 zhw{sTiUd$i0vW@g_hQ~B8=#yNTrN1s-6<$FFD11oGcVmUuOu}OsA?n$LTp=Ew;{Kiamqs{|2T&C-z+)>WUuD?z8@| zOi@eK3JP4{p_pEsCh_~s-1iOJr~pUwiewF?vTeeyrP3Q6j@$&xR>;p?xnzj;f<{Ei>D z|H*KrhAmxfz1-f7+U`pKRS$+%ynl1xaP$GG#|`ECzr0D%is4&%O{!mR+3O2$KlW_f zASR`wdFAj=zSq}-rIxB$)UG+rX|=~j%6yCC#Vnz@U)kp8mE7OA=>3K{OZD`>oLduT z&|a2Yw#oeU)uZ)4wWny?uePwYmygX$UckL4{{O)_m;Nk#W!T?i?tMV7{Z@R3sN$WC zFQ!W5{5w|rJrh~xyNxOLOmdKI;Vst0Q-|& ABme*a literal 0 HcmV?d00001 diff --git a/ProjectElectroTrans/Resources/arrowUp.png b/ProjectElectroTrans/Resources/arrowUp.png new file mode 100644 index 0000000000000000000000000000000000000000..e3a03831d7aab179980ec7b6fd5d56167851a114 GIT binary patch literal 1012 zcmeAS@N?(olHy`uVBq!ia0vp^av;nBBpBqPKh^;$rX+877l!}s{b%+Ad7K3vk;M!Q ze1}1p@p%4<6rdn`iKnkC`wM11HZi_D!CU8mLX7!Eej$wK7nRQfa^g}WJkxxA8MJ_G z4hA+xAqHlU5+Gz?W@KOmvl$q|n3+K$V9XFG0AYg!0tFdZAmV&S0)-H4pcqhf+X4oL zjs06fO+ePFmbgZgq$HN4S|t~y0x1R~10xe%17lr7lMn+lD-0aPLhR}zp}k(v{bS`?a>SrWluY;Iwoqp;Rn-V&#xNT{O3hw{sT ziUd$i0vW@g_hQ~B8=#yNTrN1s-6<$FFD11oGcVmUuOu}OsA?||7Y9eAHH4MC} zwu%ck8Zf@I{cX7JW{f^t-GSP9GiRD^PCI)bZF$tQ*H3!v>(28%t3TN_wK{*f*@gM* zcTK)(T-|wl|C%W#-{Tj(PG}d}IPHbz^$SbIs(WUyvepUuKW%?WbX{|YT=(;%&Fgn; zmc7q)>0z6la)0)j?8>gVi=8Lpd_O-q8db1qeL!MaXVvwrwc=3+PK$i|_1o`_iGv7t zMWV2}vkJ#jKId3={|BOirT2?6GY`5Mc%}gufaO zLoG{VlIKmz^>}Z)xVgkHp#O#@=On3v>>akAu67MA7d^s?rFrKZcsZ#m?c=#Q(k!25 zeaQLnQEu<=KQA9Y+qA+-<;CZ<-{bB6e7F`>zet!J*gAB{3joJE-Dnp zDLA{#Z?e9R(`{aU-To;>1xp^z_IBbf-muZkmaTu~O#V49Ja6;6{n_l3%z1}3@A0>q e{ _pictureWidth || x < 0) { + _startPosX = 0; + } + if (_drawingElectroTransHeight + y > _pictureHeight || y < 0) { + _startPosY = 0; + } + } + + public boolean setPictureSize(int width, int height) { + + if (_drawingElectroTransHeight > height || _drawingElectroTransWidth > width) + return false; + _pictureHeight = height; + _pictureWidth = width; + + if (_startPosX != null && _startPosY != null) { + if (_startPosX + _drawingElectroTransWidth > width) + _startPosX = width - _drawingElectroTransWidth; + if (_startPosY + _drawingElectroTransHeight > height) + _startPosY = height - _drawingElectroTransHeight; + } + + return true; + + + } + + public boolean moveTransport(DirectionType direction) { + if (entityElectroTrans == null || _pictureWidth == null || _pictureHeight == null) + return false; + switch (direction) { + case Left: + if (_startPosX - entityElectroTrans.Step() > 0) + _startPosX -= (int) entityElectroTrans.Step(); + return true; + case Up: + if (_startPosY - entityElectroTrans.Step() > 0) + _startPosY -= (int) entityElectroTrans.Step(); + return true; + case Right: + if (_startPosX + entityElectroTrans.Step() < _pictureWidth - _drawingElectroTransWidth) + _startPosX += (int) entityElectroTrans.Step(); + return true; + case Down: + if (_startPosY + entityElectroTrans.Step() < _pictureHeight - _drawingElectroTransHeight) + _startPosY += (int) entityElectroTrans.Step(); + return true; + default: + return false; + + + } + } + + public void drawElectroTrans(Graphics g) { + if (entityElectroTrans == null || _startPosX == null || _startPosY == null) { + return; + } + + Graphics2D g2d = (Graphics2D) g; + + Point[] electroTransBorders = new Point[]{ + new Point(_startPosX, _startPosY + 30), + new Point(_startPosX + 10, _startPosY + 10), + new Point(_startPosX + 70, _startPosY + 10), + new Point(_startPosX + 80, _startPosY + 30), + new Point(_startPosX + 80, _startPosY + 50), + new Point(_startPosX, _startPosY + 50), + }; + Polygon electroTransPolygon = new Polygon(); + for (Point point : electroTransBorders) + electroTransPolygon.addPoint(point.x, point.y); + + g2d.setColor(entityElectroTrans.getBodyColor()); + g2d.drawPolygon(electroTransPolygon); + + Point[] electroTransGlass = new Point[]{ + new Point(_startPosX + 2, _startPosY + 30), + new Point(_startPosX + 10, _startPosY + 13), + new Point(_startPosX + 70, _startPosY + 13), + new Point(_startPosX + 78, _startPosY + 30), + }; + + Polygon electroTransGlassPolygon = new Polygon(); + for (Point point : electroTransGlass) + electroTransGlassPolygon.addPoint(point.x, point.y); + + g2d.setColor(entityElectroTrans.getBodyColor()); + g2d.drawPolygon(electroTransGlassPolygon); + + + Point[] electroTransHorns; + if (entityElectroTrans.getHorns()) { + electroTransHorns = new Point[]{ + new Point(_startPosX + 40, _startPosY + 10), + new Point(_startPosX + 20, _startPosY), + new Point(_startPosX + 60, _startPosY), + + }; + } else { + electroTransHorns = new Point[]{ + new Point(_startPosX + 40, _startPosY + 7), + new Point(_startPosX + 20, _startPosY + 7), + new Point(_startPosX + 60, _startPosY + 7), + + }; + } + + Polygon electroTransHornsPolygon = new Polygon(); + for (Point point : electroTransHorns) + electroTransHornsPolygon.addPoint(point.x, point.y); + + g2d.setColor(entityElectroTrans.getAdditionalColor()); + g2d.drawPolygon(electroTransHornsPolygon); + + + if (entityElectroTrans.getBattery()) { + Point[] electroTransBattery = new Point[]{ + new Point(_startPosX + 25, _startPosY + 32), + new Point(_startPosX + 25, _startPosY + 36), + new Point(_startPosX + 22, _startPosY + 36), + new Point(_startPosX + 22, _startPosY + 40), + new Point(_startPosX + 25, _startPosY + 40), + new Point(_startPosX + 25, _startPosY + 46), + new Point(_startPosX + 58, _startPosY + 46), + new Point(_startPosX + 58, _startPosY + 32), + + }; + Polygon electroTransBatteryPolygon = new Polygon(); + for (Point point : electroTransBattery) + electroTransBatteryPolygon.addPoint(point.x, point.y); + + g2d.setColor(entityElectroTrans.getAdditionalColor()); + g2d.fillPolygon(electroTransBatteryPolygon); + + } + + drawningElectroTransWheels.drawElectroTransWheels(g, entityElectroTrans.getAdditionalColor(), _startPosX, _startPosY); + + + } + +} + diff --git a/ProjectElectroTrans/src/DrawningElectroTransWheels.java b/ProjectElectroTrans/src/DrawningElectroTransWheels.java new file mode 100644 index 0000000..03dca71 --- /dev/null +++ b/ProjectElectroTrans/src/DrawningElectroTransWheels.java @@ -0,0 +1,24 @@ +import java.awt.*; + +public class DrawningElectroTransWheels { + private WheelsCount wheelsCount; + + public void setEnumNumber(int wheelCount) { + for (WheelsCount value : WheelsCount.values()) { + if (value.getEnumNumber() == wheelCount) { + wheelsCount = value; + return; + } + } + } + + public void drawElectroTransWheels(Graphics g, Color color, float startPosX, float startPosY) { + + Graphics2D g2d = (Graphics2D) g; + g2d.setColor(color); + g2d.setStroke(new BasicStroke(4)); + for (int i = 0; i < wheelsCount.getEnumNumber(); i++) { + g2d.drawOval((int) startPosX + (70 / 4) * (i + 1) + -4, (int) startPosY + 46, 8, 8); + } + } +} diff --git a/ProjectElectroTrans/src/EntityElectroTrans.java b/ProjectElectroTrans/src/EntityElectroTrans.java new file mode 100644 index 0000000..f987970 --- /dev/null +++ b/ProjectElectroTrans/src/EntityElectroTrans.java @@ -0,0 +1,41 @@ +import java.awt.*; + +public class EntityElectroTrans { + private int Speed; + public int getSpeed() { + return Speed; + } + private double Weight; + public double getWeight() { + return Weight; + } + private Color BodyColor; + public Color getBodyColor() { + return BodyColor; + } + private Color AdditionalColor; + public Color getAdditionalColor() { + return AdditionalColor; + } + + + public double Step() { + return Speed*100/Weight; + } + private boolean Horns; + public boolean getHorns() { + return Horns; + } + private boolean Battery; + public boolean getBattery() { + return Battery; + } + public void Init(int speed, double weight, Color bodyColor, Color additionalColor, boolean horns, boolean battery) { + Speed = speed; + Weight = weight; + BodyColor = bodyColor; + AdditionalColor = additionalColor; + Horns = horns; + Battery = battery; + } +} diff --git a/ProjectElectroTrans/src/FormElectroTrans.form b/ProjectElectroTrans/src/FormElectroTrans.form new file mode 100644 index 0000000..054558e --- /dev/null +++ b/ProjectElectroTrans/src/FormElectroTrans.form @@ -0,0 +1,93 @@ + +
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
diff --git a/ProjectElectroTrans/src/FormElectroTrans.java b/ProjectElectroTrans/src/FormElectroTrans.java new file mode 100644 index 0000000..fefd453 --- /dev/null +++ b/ProjectElectroTrans/src/FormElectroTrans.java @@ -0,0 +1,114 @@ +import javax.swing.*; +import java.awt.*; +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import java.util.LinkedList; +import java.util.Random; +import java.util.List; + +public class FormElectroTrans extends JFrame { + protected DrawningElectroTrans _drawningElectroTrans = new DrawningElectroTrans(); + JPanel PanelWrapper; + private JPanel PictureBox; + private JButton buttonCreate; + private JButton buttonRight; + private JButton buttonDown; + private JButton buttonLeft; + private JButton buttonUp; + + private List controls; + public FormElectroTrans() { + buttonUp.setName("buttonUp"); + buttonDown.setName("buttonDown"); + buttonLeft.setName("buttonLeft"); + buttonRight.setName("buttonRight"); + + InitializeControlsRepaintList(); + + buttonCreate.addActionListener(new ActionListener() { + @Override + public void actionPerformed(ActionEvent e) { + _drawningElectroTrans = new DrawningElectroTrans(); + Random random = new Random(); + + _drawningElectroTrans.Init(random.nextInt(30, 100), + random.nextInt(100, 500), + new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256)), + new Color(random.nextInt(256), random.nextInt(256), random.nextInt(256)), + random.nextBoolean(), random.nextBoolean() ); + _drawningElectroTrans.setPictureSize(PictureBox.getWidth(), PictureBox.getHeight()); + _drawningElectroTrans.setPosition(random.nextInt(25, 100), + random.nextInt(25, 100)); + + Draw(); + + } + }); + ActionListener buttonMoveClickedListener = new ActionListener() { + @Override + public void actionPerformed(ActionEvent e) { + String buttonName = ((JButton) e.getSource()).getName(); + boolean result = false; + + switch (buttonName) { + case "buttonUp": { + result = _drawningElectroTrans.moveTransport(DirectionType.Up); + } + break; + case "buttonDown": { + result = _drawningElectroTrans.moveTransport(DirectionType.Down); + } + break; + case "buttonLeft": { + result = _drawningElectroTrans.moveTransport(DirectionType.Left); + } + break; + case "buttonRight": { + result = _drawningElectroTrans.moveTransport(DirectionType.Right); + } + break; + + } + if (result) + Draw(); + + } + }; + buttonRight.addActionListener(buttonMoveClickedListener); + buttonDown.addActionListener(buttonMoveClickedListener); + buttonLeft.addActionListener(buttonMoveClickedListener); + buttonUp.addActionListener(buttonMoveClickedListener); + + } + private void Draw() { + if (_drawningElectroTrans.getEntityElectroTrans() == null) + return; + if (PictureBox.getWidth() == 0 || PictureBox.getHeight() == 0) { + return; + } + Graphics g = PictureBox.getGraphics(); + g.setColor(PictureBox.getBackground()); + g.fillRect(0,0, PictureBox.getWidth(), PictureBox.getHeight()); + _drawningElectroTrans.drawElectroTrans(g); + + RepaintControls(); + + } + private void RepaintControls() { + for (JComponent control : controls) { + control.repaint(); + } + } + + + private void InitializeControlsRepaintList() { + controls = new LinkedList<>(); + controls.add(buttonCreate); + controls.add(buttonUp); + controls.add(buttonDown); + controls.add(buttonLeft); + controls.add(buttonRight); + } + + +} diff --git a/ProjectElectroTrans/src/Main.java b/ProjectElectroTrans/src/Main.java index 71d53dd..7f24cba 100644 --- a/ProjectElectroTrans/src/Main.java +++ b/ProjectElectroTrans/src/Main.java @@ -1,9 +1,19 @@ +import javax.swing.*; + //TIP To Run code, press or // click the icon in the gutter. public class Main { public static void main(String[] args) { + JFrame.setDefaultLookAndFeelDecorated(false); + JFrame frame = new JFrame("Катамаран"); + frame.setContentPane(new FormElectroTrans().PanelWrapper); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + frame.setLocation(500, 200); + frame.pack(); + frame.setSize(700, 500); + frame.setVisible(true); //TIP Press with your caret at the highlighted text // to see how IntelliJ IDEA suggests fixing it. - System.out.println("Hello and welcome!"); + } } \ No newline at end of file diff --git a/ProjectElectroTrans/src/WheelsCount.java b/ProjectElectroTrans/src/WheelsCount.java new file mode 100644 index 0000000..847d4b0 --- /dev/null +++ b/ProjectElectroTrans/src/WheelsCount.java @@ -0,0 +1,14 @@ +public enum WheelsCount { + Two(2), + Three(3), + Four(4); + + final private int EnumNumber; + WheelsCount(int enumNumber) { + EnumNumber = enumNumber; + } + public int getEnumNumber() { + return EnumNumber; + } + +}