From eb538c1a1b3757e0d311905a5c5f9e0062c1b9c8 Mon Sep 17 00:00:00 2001 From: frog24 Date: Sun, 3 Dec 2023 00:04:53 +0400 Subject: [PATCH 1/3] test(add class and images) --- .idea/.gitignore | 3 +++ images/ArrowDown.png | Bin 0 -> 1659 bytes images/ArrowLeft.png | Bin 0 -> 1614 bytes images/ArrowRight.png | Bin 0 -> 1365 bytes images/ArrowUp.png | Bin 0 -> 1993 bytes scr/Main.java | 5 +++++ 6 files changed, 8 insertions(+) create mode 100644 .idea/.gitignore create mode 100644 images/ArrowDown.png create mode 100644 images/ArrowLeft.png create mode 100644 images/ArrowRight.png create mode 100644 images/ArrowUp.png create mode 100644 scr/Main.java diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..26d3352 --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,3 @@ +# Default ignored files +/shelf/ +/workspace.xml diff --git a/images/ArrowDown.png b/images/ArrowDown.png new file mode 100644 index 0000000000000000000000000000000000000000..6f2438fabc6546668454036a665fbccb65724c47 GIT binary patch literal 1659 zcma)7eK?!<8jh>8B{D`uw4^kq*~O7Ybz8bFGR;R5YYCO`suJmjTB_kfg`CtjiAEw+ zm6{!Oh<;LI7V$A}NpomRtH-5`MYTOsMB-zMkYLVx&bhX~&mYhId+z7@J@<3}^*lup z;S5Iy4+j_w<`~MPoq)mYjzDqdjU7 zhxpEj<81ok;v$r8Z*Pl4qW1Q7DwVoSt;mH+h;(LbCJg3u|36_jAh`883}*jpDD4Pa zIBC*{UH;o4XZsfzY05iqTE5q3e%beOtIBmKef$3Ltq|ffduapvMi8b{df!}cP+X~D zJ*uzXAJf6Twm3eKHrRPe>nYY#;8=0RFV*=<)SNb?)OO?J}3Y z;-S5`9LHa=<+&Fwgb!)Z1kFTWburj4kl?y4w79yyxrMEQr-?4_<)Nw-;FEmxNd>sl zcBweq^wRpH@hpA%$IN;nN5>PqPQ1g2}6XGEH^O!FbTnrK{aZJ%-Q z({V3v_Rse`i@+z|$TU<22|YPCdF+J=8Ah8na^ZMX#?(O!+%e1ac;$1}nY}hl4?6mj z7W2(o`_U3`o(*)$#JX9(>~700Y}4V!h12BnJCo|!4%TBswh2oMUgNaN#(Nc3b9=)0 zbL-ih7yxfO_m%r9LU`Bbu-q-$FuB&N5Xt`@ZVp2cnoj7FhMldxN0oD)esln9>$>FI z^i-Wv>pNNsVpogyuKGNAI2@3gV=~{ob4B&tL*e2vjcotFItkBWr_^yv2NQzVuJ0DR z&cNMLvNgG<3L^-%eo|e6d1?oNdTR_4@*9ZH$-%?YoKHnU!VMbZ^QM^byl z4}2o1TZ{5lEp0CNAE5L#Pi^=>7#z8~4sgj~RL4%2Up7p>Td~uD&Yc}ZB*_m|x<0}H zg&{K%pPOJoS@LV5gV^fhbYRJofRcf@Xy$io7Z=j3bD5D#BCtSw4?m?AaZdt=Z8(2? zz$smMS#rtKt0qX%9bNNm>UG9-DZSfbw3qBt3E;li06;gPfFr#C%tN?>K5bCztY&3D7v zmsvNKxdi+#=hGM?lw@;F>H8Cuj^R)*s~@P9?~pd2-4CornK#j29PZG>{h zg__H=e3fMRRI88T>X`>~EUUtAV|2JJ<>j1~g|r0oM|9qUBCwzDklAISRcni5<42fn zUoPWSk}mBp&0ve1pz4FxzB-^SvYM4%&v;c!(7T z*2x9~L*uH_6GOdH&k3mgzo+*ol_1$#u_N=X?&tmIO|8{|LAI_4)_U-5$p@0icoDq0 zJ`iWy$*7h}576IcbA->;p4=Frm$<~>z)Hy;?``xaDZ!#IkSuu>c_d&zDfduDgH3z& zpEZ(O`E zK%Rink#G3+K}otsR-^INE5Nbg{=RO|3dk`y@b_v zm@y`)P0kMMjB(O$z0BJHXal*oP525|a+Zk+ a+fggY`##%u@ilZ3V4?JIS~Df_>wg0?wHQ4B literal 0 HcmV?d00001 diff --git a/images/ArrowLeft.png b/images/ArrowLeft.png new file mode 100644 index 0000000000000000000000000000000000000000..4ce0e4fefd10c52aa429801eb18665e166158993 GIT binary patch literal 1614 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 Kv5-!*@A&`QD|Z|K literal 0 HcmV?d00001 diff --git a/images/ArrowUp.png b/images/ArrowUp.png new file mode 100644 index 0000000000000000000000000000000000000000..54e5abe7abad4f9d871dfb5c3a1b839de969487a GIT binary patch literal 1993 zcmV;)2R8VLP)Px#1ZP1_K>z@;j|==^1poj55>QN3MegqI00030|Nnb?d$zW=LqkLGLzQ^|000Sa zNLh0L01m?d01m?e$8V@)000L-NklrGRpafWPKVqxA=?++FX6jq z!Wy7O?IGI(6eVUt4j;noAzK{@H;4&8Ed;)_ zXA651@e%GNVS$pchJjj)gsUOp#v@^WN}yUFa`+;adHZBfpTkyP2{#-Yp{UkE+Y%X} zXn0Z`$3=K);kor;A!HSd)ZilAjR|v9gcBB?sx}rvwx1#_5E0e@Y7;RKmaA#P4IU3c zA%=zUNk#Y#3*kXUxJ5$v3`%uA2z%L2acT=c=ZEwYEUREf4M#w@n&_EOZY%T?sF@Cu51ME)}7&;Yp?SkSQCURF{-+u38IiQxdZ0WkA=!(~Yp) z=@8}#2`kW2la6qwN0=ugtU*()6JdYKVr*M#cv1z=l1#AL7Jg=R2?&=Pp45h?Amji> zCR$$TcWXkuYAw|9_#WysJSqFYb7lLDW)?aHo|fOJTdjpeR%d*nzibIBFjN!SL;Y$k zR9F)JVM$nnvD&B}np73D&<3#Iuvm;JCz*_Grqx=gfeVx8lF_n{d-u0SGC?f z^i{2e3hy3zwopIt)P0uyRcoP*wuikI<}?o8#dNN#KVv`pC;X3V5o*rZKC89Rw$vhg z)glaGp>E)*=V7@EL6~a=o_ZN<1wqt!^N{Vr5av3O>~|f)8Um^HUbE; zLao44!$bcKPinIqc>Y)>1C z;=1y1fv|$WY8D6|mI(Ku2~Sy_y@xdfS36JmTZ~9^UWcDf=pP3lURxt@TT!o>YU^zq;QxU3@rKh-ry@@6s9^w*iO9i2FC-n@G)p0Wq zV_T>WJQXQ1t01}>ZsH-^#V5?U$$eNu0<{Jn#%y>}#bn?){f1-`3l)Lqq=#$;Nwnd* zJ%vLeF-;FsSvVbdPCd)apx2_K_J zn)Ax}vWJPPwNSf!A0}ydQWJsa1z}yHwW=9Aal?}; z6f-u0YAwX3Jxt#4qy~ZKaIXi5#HKt%QLTl#bKp71z7RA#DH(W54^de-2t3dCVTq(# z3+3gdhe#TpRC7@e8JcP>RPe7JqG@o@liHs5Dd?)TP$N7<*6^f`t#6$nwyXKeg$5#XP(@xLpA-@~8i32XGLOwY1AA-&xlj2TDsmMJL(tUUj zgx9djy=cZ3gtTAIXumu@{7I{PNqB>+jQ_XcD90WV8hglz@RE>|hbajAQ)uVIj0lO4 z2#JsgiI511@TLfR(Tpt!X(vUiOoTdww92%~ Date: Sun, 3 Dec 2023 00:38:53 +0400 Subject: [PATCH 2/3] Lab1 --- scr/DeckType.java | 5 ++ scr/DirectionType.java | 6 ++ scr/DrawingDecks.java | 47 +++++++++++++++ scr/DrawingWarmlyShip.java | 112 +++++++++++++++++++++++++++++++++++ scr/EntityWarmlyShip.java | 58 ++++++++++++++++++ scr/WarmlyShipForm.java | 117 +++++++++++++++++++++++++++++++++++++ 6 files changed, 345 insertions(+) create mode 100644 scr/DeckType.java create mode 100644 scr/DirectionType.java create mode 100644 scr/DrawingDecks.java create mode 100644 scr/DrawingWarmlyShip.java create mode 100644 scr/EntityWarmlyShip.java create mode 100644 scr/WarmlyShipForm.java diff --git a/scr/DeckType.java b/scr/DeckType.java new file mode 100644 index 0000000..3c80b42 --- /dev/null +++ b/scr/DeckType.java @@ -0,0 +1,5 @@ +public enum DeckType { + OneDeck, + TwoDecks, + ThreeDecks +} diff --git a/scr/DirectionType.java b/scr/DirectionType.java new file mode 100644 index 0000000..35657f0 --- /dev/null +++ b/scr/DirectionType.java @@ -0,0 +1,6 @@ +public enum DirectionType { + Up, + Down, + Left, + Right +} diff --git a/scr/DrawingDecks.java b/scr/DrawingDecks.java new file mode 100644 index 0000000..15d7b2b --- /dev/null +++ b/scr/DrawingDecks.java @@ -0,0 +1,47 @@ +import java.awt.*; + +public class DrawingDecks { + private DeckType deckType; + private int NumberDecks; + public void SetNumberDecks(int value){ + NumberDecks = value; + switch (value){ + case 2: + deckType = DeckType.TwoDecks; + break; + case 3: + deckType = DeckType.ThreeDecks; + break; + default: + deckType = DeckType.OneDeck; + } + }; + public void DrawingDecks(int _startPosX, int _startPosY, Color MainColor, Graphics g){ + switch (deckType){ + case OneDeck: + g.setColor(MainColor); + g.fillRect(_startPosX + 30, _startPosY + 30, 60, 10); + g.setColor(Color.black); + g.drawRect(_startPosX + 30, _startPosY + 30, 60, 10); + break; + case TwoDecks: + g.setColor(MainColor); + g.fillRect(_startPosX + 30, _startPosY + 30, 60, 10); + g.fillRect(_startPosX + 36, _startPosY + 22, 54, 8); + g.setColor(Color.black); + g.drawRect(_startPosX + 30, _startPosY + 30, 60, 10); + g.drawRect(_startPosX + 36, _startPosY + 22, 54, 8); + break; + case ThreeDecks: + g.setColor(MainColor); + g.fillRect(_startPosX + 30, _startPosY + 30, 60, 10); + g.fillRect(_startPosX + 36, _startPosY + 22, 54, 8); + g.fillRect(_startPosX + 50, _startPosY + 14, 40, 8); + g.setColor(Color.black); + g.drawRect(_startPosX + 30, _startPosY + 30, 60, 10); + g.drawRect(_startPosX + 36, _startPosY + 22, 54, 8); + g.drawRect(_startPosX + 50, _startPosY + 14, 40, 8); + break; + } + } +} diff --git a/scr/DrawingWarmlyShip.java b/scr/DrawingWarmlyShip.java new file mode 100644 index 0000000..c5e0903 --- /dev/null +++ b/scr/DrawingWarmlyShip.java @@ -0,0 +1,112 @@ +import java.awt.*; +public class DrawingWarmlyShip { + private EntityWarmlyShip entityWarmlyShip; + public EntityWarmlyShip GetEntityWarmlyShip(){ + return entityWarmlyShip; + } + private void SetEntityWarmlyShip(EntityWarmlyShip entityWarmlyShip){ + this.entityWarmlyShip = entityWarmlyShip; + } + private DrawingDecks drawingDecks; + public DrawingDecks GetDrawingDecks(){ + return drawingDecks; + } + private void SetDrawingDecks( DrawingDecks drawingDecks){ + this.drawingDecks = drawingDecks; + } + private int _pictureWidth; + private int _pictureHeight; + private int _startPosX; + private int _startPosY; + private final int _shipWidth = 100; + private final int _shipHeight = 70; + public boolean Init(int speed, double weight, Color mainColor, Color optionalColor, boolean pipes, boolean fuelCompartment, int width, int height, int numberDecks){ + if (width < _shipWidth || height <_shipHeight){ + return false; + } + _pictureWidth = width; + _pictureHeight = height; + entityWarmlyShip = new EntityWarmlyShip(); + entityWarmlyShip.Init(speed, weight, mainColor, optionalColor, pipes, fuelCompartment); + drawingDecks = new DrawingDecks(); + drawingDecks.SetNumberDecks(numberDecks); + return true; + } + public void SetPosition(int x, int y){ + if (x < 0 || x + _shipWidth > _pictureWidth){ + x = 20; + } + if (y < 0 || y + _shipHeight > _pictureHeight){ + y = 20; + } + _startPosX = x; + _startPosY = y; + } + public void MoveTransport(DirectionType direction){ + if (entityWarmlyShip == null){ + return; + } + switch (direction){ + case Left: + System.out.println(_startPosX + " " + entityWarmlyShip.GetStep() + " " + _shipWidth + " " + (_startPosX + entityWarmlyShip.GetStep() + _shipWidth) + " " + _pictureWidth); + if (_startPosX - entityWarmlyShip.GetStep() > 0){ + _startPosX -= (int)entityWarmlyShip.GetStep(); + } + break; + case Up: + System.out.println(_startPosY + " " + entityWarmlyShip.GetStep() + " " + (_startPosY + entityWarmlyShip.GetStep()) + " " + _pictureHeight); + if (_startPosY - entityWarmlyShip.GetStep() > 0){ + _startPosY -= (int)entityWarmlyShip.GetStep(); + } + break; + case Right: + System.out.println(_startPosX + " " + entityWarmlyShip.GetStep() + " " + _shipWidth + " " + (_startPosX + entityWarmlyShip.GetStep() + _shipWidth) + " " + _pictureWidth); + if (_startPosX + entityWarmlyShip.GetStep() + _shipWidth < _pictureWidth){ + _startPosX += (int)entityWarmlyShip.GetStep(); + } + break; + case Down: + System.out.println(_startPosY + " " + entityWarmlyShip.GetStep() + " " + (_startPosY + entityWarmlyShip.GetStep()) + " " + _pictureHeight); + if (_startPosY + entityWarmlyShip.GetStep() + _shipHeight < _pictureHeight){ + _startPosY += (int)entityWarmlyShip.GetStep(); + } + break; + } + } + public void DrawTransport(Graphics g){ + if (entityWarmlyShip == null || drawingDecks == null){ + System.out.println("?????????"); + return; + } + if (entityWarmlyShip.GetPipes()){ + g.setColor(entityWarmlyShip.GetOptionalColor()); + g.fillRect(_startPosX + 70, _startPosY, 10, 30); + g.fillRect(_startPosX + 50, _startPosY + 10, 10, 20); + g.setColor(Color.black); + g.drawRect(_startPosX + 50, _startPosY + 10, 10, 20); + g.drawRect(_startPosX + 70, _startPosY, 10, 30); + } + if (entityWarmlyShip.GetFuelCompartment()) + { + g.setColor(entityWarmlyShip.GetOptionalColor()); + g.fillRect(_startPosX + 10, _startPosY + 30, 10, 10); + g.setColor(Color.black); + g.drawRect(_startPosX + 10, _startPosY + 30, 10, 10); + } + //палуба + drawingDecks.DrawingDecks(_startPosX, _startPosY, entityWarmlyShip.GetMainColor(), g); + //корпус + int[] xPoints = {_startPosX, _startPosX + 100, _startPosX + 90, _startPosX + 20, _startPosX}; + int[] yPoints = {_startPosY + 40, _startPosY + 40, _startPosY + 60, _startPosY + 60, _startPosY + 40}; + int nPoints = 5; + g.setColor(entityWarmlyShip.GetMainColor()); + g.fillPolygon(xPoints, yPoints, nPoints); + g.setColor(Color.black); + g.drawPolygon(xPoints, yPoints, nPoints); + //якорь + g.drawLine(_startPosX + 25, _startPosY + 45, _startPosX + 25, _startPosY + 55); + g.drawLine(_startPosX + 20, _startPosY + 50, _startPosX + 30, _startPosY + 50); + g.drawLine(_startPosX + 23, _startPosY + 55, _startPosX + 27, _startPosY + 55); + } + +} diff --git a/scr/EntityWarmlyShip.java b/scr/EntityWarmlyShip.java new file mode 100644 index 0000000..0411129 --- /dev/null +++ b/scr/EntityWarmlyShip.java @@ -0,0 +1,58 @@ +import java.awt.*; +public class EntityWarmlyShip { + private int Speed; + public int GetSpeed(){ + return Speed; + } + private void SetSpeed(int speed){ + Speed = speed; + } + private double Weight; + public double GetWeight(){ + return Weight; + } + private void SetWeight(int weight){ + Weight = weight; + } + private Color MainColor; + public Color GetMainColor(){ + return MainColor; + } + private void SetMainColor(Color mainColor){ + MainColor = mainColor; + } + private Color OptionalColor; + public Color GetOptionalColor(){ + return OptionalColor; + } + private void SetOptionalColor(Color optionalColor){ + OptionalColor = optionalColor; + } + private boolean Pipes; + public boolean GetPipes(){ + return Pipes; + } + private void SetPipes(boolean pipes){ + Pipes = pipes; + } + private boolean FuelCompartment; + public boolean GetFuelCompartment(){ + return FuelCompartment; + } + private void SetFuelCompartment(boolean fuelCompartment){ + FuelCompartment = fuelCompartment; + } + private double Step; + public double GetStep() { + return (double)Speed * 100 / Weight; + } + public void Init(int speed, double weight, Color mainColor, Color optionalColor, boolean pipes, boolean fuelCompartment) + { + Speed = speed; + Weight = weight; + MainColor = mainColor; + OptionalColor = optionalColor; + Pipes = pipes; + FuelCompartment = fuelCompartment; + } +} \ No newline at end of file diff --git a/scr/WarmlyShipForm.java b/scr/WarmlyShipForm.java new file mode 100644 index 0000000..283ae78 --- /dev/null +++ b/scr/WarmlyShipForm.java @@ -0,0 +1,117 @@ +import javax.swing.*; +import java.awt.*; +import java.awt.Graphics; +import java.awt.event.ActionEvent; +import java.awt.event.ActionListener; +import java.util.*; + +public class WarmlyShipForm{ + private DrawingWarmlyShip _drawingWarmlyShip; + Canvas canv; + public void Draw(){ + canv.repaint(); + } + public WarmlyShipForm(){ + JFrame frame = new JFrame("Warmly Ship"); + JButton buttonCreate = new JButton("Создать"); + buttonCreate.setFocusPainted(false); + buttonCreate.setContentAreaFilled(false); + JButton buttonUp = new JButton(); + //buttonUp.setBorderPainted(false); //граница кнопки + buttonUp.setFocusPainted(false); //контур вокруг текста + buttonUp.setContentAreaFilled(false); //раскраска конпки + buttonUp.setName("up"); //имя кнопки при обработке нажания + buttonUp.setIcon(new ImageIcon(((new ImageIcon("images/ArrowUp.png")).getImage()).getScaledInstance(35, 35, java.awt.Image.SCALE_SMOOTH))); + JButton buttonDown = new JButton(); + buttonDown.setFocusPainted(false); + buttonDown.setContentAreaFilled(false); + buttonDown.setName("down"); + buttonDown.setIcon(new ImageIcon(((new ImageIcon("images/ArrowDown.png")).getImage()).getScaledInstance(35, 35, java.awt.Image.SCALE_SMOOTH))); + JButton buttonLeft = new JButton(); + buttonLeft.setFocusPainted(false); + buttonLeft.setContentAreaFilled(false); + buttonLeft.setName("left"); + buttonLeft.setIcon(new ImageIcon(((new ImageIcon("images/ArrowLeft.png")).getImage()).getScaledInstance(35, 35, java.awt.Image.SCALE_SMOOTH))); + JButton buttonRight = new JButton(); + buttonRight.setFocusPainted(false); + buttonRight.setContentAreaFilled(false); + buttonRight.setName("right"); + buttonRight.setIcon(new ImageIcon(((new ImageIcon("images/ArrowRight.png")).getImage()).getScaledInstance(35, 35, java.awt.Image.SCALE_SMOOTH))); + buttonCreate.addActionListener( + new ActionListener() { + public void actionPerformed(ActionEvent e) { + System.out.println(e.getActionCommand()); + Random random = new Random(); + _drawingWarmlyShip = new DrawingWarmlyShip(); + _drawingWarmlyShip.Init( + random.nextInt(200) + 100, + random.nextInt(2000) + 1000, + 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(), 900, 460, random.nextInt(3) + 1); + _drawingWarmlyShip.SetPosition(random.nextInt(90) + 10, random.nextInt(90) + 10); + canv._drawingWarmlyShip = _drawingWarmlyShip; + Draw(); + } + } + ); + ActionListener actionListener = new ActionListener() { + public void actionPerformed(ActionEvent e) { + System.out.println(((JButton)(e.getSource())).getName()); + if (_drawingWarmlyShip == null){ + return; + } + switch ((((JButton)(e.getSource())).getName())){ + case "up": + _drawingWarmlyShip.MoveTransport(DirectionType.Up); + break; + case "down": + _drawingWarmlyShip.MoveTransport(DirectionType.Down); + break; + case "left": + _drawingWarmlyShip.MoveTransport(DirectionType.Left); + break; + case "right": + _drawingWarmlyShip.MoveTransport(DirectionType.Right); + break; + } + Draw(); + } + }; + buttonUp.addActionListener(actionListener); + buttonDown.addActionListener(actionListener); + buttonLeft.addActionListener(actionListener); + buttonRight.addActionListener(actionListener); + frame.setSize(920, 500); + frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); + frame.setLayout(null); + canv = new Canvas(); + canv.setBounds(0, 0, 900, 500); + buttonCreate.setBounds(2, 420, 100, 40); + buttonUp.setBounds(800, 380, 40, 40); + buttonDown.setBounds(800, 420, 40, 40); + buttonLeft.setBounds(760, 420, 40, 40); + buttonRight.setBounds(840, 420, 40, 40); + frame.add(canv); + frame.add(buttonCreate); + frame.add(buttonUp); + frame.add(buttonDown); + frame.add(buttonLeft); + frame.add(buttonRight); + frame.setVisible(true); + } + class Canvas extends JComponent{ + public DrawingWarmlyShip _drawingWarmlyShip; + public Canvas(){} + + public void paintComponent(Graphics g){ + if (_drawingWarmlyShip == null){ + return; + } + super.paintComponents(g); + Graphics2D g2d = (Graphics2D)g; + _drawingWarmlyShip.DrawTransport(g2d); + super.repaint(); + } + } +} \ No newline at end of file -- 2.25.1 From 137bd293e80f1e18344e38b869d2e14ceba403e9 Mon Sep 17 00:00:00 2001 From: frog24 Date: Sun, 3 Dec 2023 01:42:04 +0400 Subject: [PATCH 3/3] code upgreat --- scr/DrawingDecks.java | 31 +++++++++++++------------------ 1 file changed, 13 insertions(+), 18 deletions(-) diff --git a/scr/DrawingDecks.java b/scr/DrawingDecks.java index 15d7b2b..5e6bae3 100644 --- a/scr/DrawingDecks.java +++ b/scr/DrawingDecks.java @@ -16,31 +16,26 @@ public class DrawingDecks { deckType = DeckType.OneDeck; } }; + public void DrawDeck(int x, int y, int width, int heght, Graphics g, Color MainColor){ + g.setColor(MainColor); + g.fillRect(x, y, width, heght); + g.setColor(Color.black); + g.drawRect(x, y, width, heght); + } + public void DrawingDecks(int _startPosX, int _startPosY, Color MainColor, Graphics g){ switch (deckType){ case OneDeck: - g.setColor(MainColor); - g.fillRect(_startPosX + 30, _startPosY + 30, 60, 10); - g.setColor(Color.black); - g.drawRect(_startPosX + 30, _startPosY + 30, 60, 10); + DrawDeck(_startPosX + 30, _startPosY + 30, 60, 10, g, MainColor); break; case TwoDecks: - g.setColor(MainColor); - g.fillRect(_startPosX + 30, _startPosY + 30, 60, 10); - g.fillRect(_startPosX + 36, _startPosY + 22, 54, 8); - g.setColor(Color.black); - g.drawRect(_startPosX + 30, _startPosY + 30, 60, 10); - g.drawRect(_startPosX + 36, _startPosY + 22, 54, 8); + DrawDeck(_startPosX + 30, _startPosY + 30, 60, 10, g, MainColor); + DrawDeck(_startPosX + 36, _startPosY + 22, 54, 8, g, MainColor); break; case ThreeDecks: - g.setColor(MainColor); - g.fillRect(_startPosX + 30, _startPosY + 30, 60, 10); - g.fillRect(_startPosX + 36, _startPosY + 22, 54, 8); - g.fillRect(_startPosX + 50, _startPosY + 14, 40, 8); - g.setColor(Color.black); - g.drawRect(_startPosX + 30, _startPosY + 30, 60, 10); - g.drawRect(_startPosX + 36, _startPosY + 22, 54, 8); - g.drawRect(_startPosX + 50, _startPosY + 14, 40, 8); + DrawDeck(_startPosX + 30, _startPosY + 30, 60, 10, g, MainColor); + DrawDeck(_startPosX + 36, _startPosY + 22, 54, 8, g, MainColor); + DrawDeck(_startPosX + 50, _startPosY + 14, 40, 8, g, MainColor); break; } } -- 2.25.1