refactorings I
This commit is contained in:
parent
e31f2e3544
commit
50937ab7fd
refactoring/flappy-bird
.idea
src/main/java/com/example/flappybird
@ -8,7 +8,7 @@
|
|||||||
</list>
|
</list>
|
||||||
</option>
|
</option>
|
||||||
</component>
|
</component>
|
||||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_23" default="true" project-jdk-name="openjdk-23" project-jdk-type="JavaSDK">
|
<component name="ProjectRootManager" version="2" languageLevel="JDK_X" default="true" project-jdk-name="openjdk-23" project-jdk-type="JavaSDK">
|
||||||
<output url="file://$PROJECT_DIR$/out" />
|
<output url="file://$PROJECT_DIR$/out" />
|
||||||
</component>
|
</component>
|
||||||
</project>
|
</project>
|
124
refactoring/flappy-bird/.idea/uiDesigner.xml
Normal file
124
refactoring/flappy-bird/.idea/uiDesigner.xml
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<project version="4">
|
||||||
|
<component name="Palette2">
|
||||||
|
<group name="Swing">
|
||||||
|
<item class="com.intellij.uiDesigner.HSpacer" tooltip-text="Horizontal Spacer" icon="/com/intellij/uiDesigner/icons/hspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="1" hsize-policy="6" anchor="0" fill="1" />
|
||||||
|
</item>
|
||||||
|
<item class="com.intellij.uiDesigner.VSpacer" tooltip-text="Vertical Spacer" icon="/com/intellij/uiDesigner/icons/vspacer.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="1" anchor="0" fill="2" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JPanel" icon="/com/intellij/uiDesigner/icons/panel.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JScrollPane" icon="/com/intellij/uiDesigner/icons/scrollPane.svg" removable="false" auto-create-binding="false" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="7" hsize-policy="7" anchor="0" fill="3" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JButton" icon="/com/intellij/uiDesigner/icons/button.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="3" anchor="0" fill="1" />
|
||||||
|
<initial-values>
|
||||||
|
<property name="text" value="Button" />
|
||||||
|
</initial-values>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JRadioButton" icon="/com/intellij/uiDesigner/icons/radioButton.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||||
|
<initial-values>
|
||||||
|
<property name="text" value="RadioButton" />
|
||||||
|
</initial-values>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JCheckBox" icon="/com/intellij/uiDesigner/icons/checkBox.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="3" anchor="8" fill="0" />
|
||||||
|
<initial-values>
|
||||||
|
<property name="text" value="CheckBox" />
|
||||||
|
</initial-values>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JLabel" icon="/com/intellij/uiDesigner/icons/label.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="0" anchor="8" fill="0" />
|
||||||
|
<initial-values>
|
||||||
|
<property name="text" value="Label" />
|
||||||
|
</initial-values>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JTextField" icon="/com/intellij/uiDesigner/icons/textField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||||
|
<preferred-size width="150" height="-1" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JPasswordField" icon="/com/intellij/uiDesigner/icons/passwordField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||||
|
<preferred-size width="150" height="-1" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JFormattedTextField" icon="/com/intellij/uiDesigner/icons/formattedTextField.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1">
|
||||||
|
<preferred-size width="150" height="-1" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JTextArea" icon="/com/intellij/uiDesigner/icons/textArea.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||||
|
<preferred-size width="150" height="50" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JTextPane" icon="/com/intellij/uiDesigner/icons/textPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||||
|
<preferred-size width="150" height="50" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JEditorPane" icon="/com/intellij/uiDesigner/icons/editorPane.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||||
|
<preferred-size width="150" height="50" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JComboBox" icon="/com/intellij/uiDesigner/icons/comboBox.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="2" anchor="8" fill="1" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JTable" icon="/com/intellij/uiDesigner/icons/table.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||||
|
<preferred-size width="150" height="50" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JList" icon="/com/intellij/uiDesigner/icons/list.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="2" anchor="0" fill="3">
|
||||||
|
<preferred-size width="150" height="50" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JTree" icon="/com/intellij/uiDesigner/icons/tree.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3">
|
||||||
|
<preferred-size width="150" height="50" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JTabbedPane" icon="/com/intellij/uiDesigner/icons/tabbedPane.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||||
|
<preferred-size width="200" height="200" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JSplitPane" icon="/com/intellij/uiDesigner/icons/splitPane.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="3" hsize-policy="3" anchor="0" fill="3">
|
||||||
|
<preferred-size width="200" height="200" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JSpinner" icon="/com/intellij/uiDesigner/icons/spinner.svg" removable="false" auto-create-binding="true" can-attach-label="true">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JSlider" icon="/com/intellij/uiDesigner/icons/slider.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="6" anchor="8" fill="1" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JSeparator" icon="/com/intellij/uiDesigner/icons/separator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="6" anchor="0" fill="3" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JProgressBar" icon="/com/intellij/uiDesigner/icons/progressbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JToolBar" icon="/com/intellij/uiDesigner/icons/toolbar.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="6" anchor="0" fill="1">
|
||||||
|
<preferred-size width="-1" height="20" />
|
||||||
|
</default-constraints>
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JToolBar$Separator" icon="/com/intellij/uiDesigner/icons/toolbarSeparator.svg" removable="false" auto-create-binding="false" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="0" hsize-policy="0" anchor="0" fill="1" />
|
||||||
|
</item>
|
||||||
|
<item class="javax.swing.JScrollBar" icon="/com/intellij/uiDesigner/icons/scrollbar.svg" removable="false" auto-create-binding="true" can-attach-label="false">
|
||||||
|
<default-constraints vsize-policy="6" hsize-policy="0" anchor="0" fill="2" />
|
||||||
|
</item>
|
||||||
|
</group>
|
||||||
|
</component>
|
||||||
|
</project>
|
@ -1,53 +0,0 @@
|
|||||||
package com.example.flappybird; /**
|
|
||||||
* Animation.java
|
|
||||||
* Creates animation with array of sprites
|
|
||||||
*
|
|
||||||
* @author Paul Krishnamurthy
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.awt.Graphics;
|
|
||||||
import java.awt.Graphics2D;
|
|
||||||
import java.awt.image.BufferedImage;
|
|
||||||
import java.awt.geom.AffineTransform;
|
|
||||||
|
|
||||||
public class Animation {
|
|
||||||
|
|
||||||
// Start at first frame
|
|
||||||
private static double currentFrame = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates an animation with an array of sprites
|
|
||||||
*
|
|
||||||
* @param sprites Array of BufferedImages
|
|
||||||
* @param x x-coordinate
|
|
||||||
* @param y y-coordinate
|
|
||||||
* @param speed Speed of animation
|
|
||||||
* @param angle Angle to rotate sprite
|
|
||||||
*/
|
|
||||||
public static void animate (Graphics g, BufferedImage[] sprites, int x, int y, double speed, double angle) {
|
|
||||||
|
|
||||||
Graphics2D g2d = (Graphics2D) g;
|
|
||||||
AffineTransform trans = g2d.getTransform();
|
|
||||||
AffineTransform at = new AffineTransform();
|
|
||||||
|
|
||||||
// Number of frames
|
|
||||||
int count = sprites.length;
|
|
||||||
|
|
||||||
// Rotate the image
|
|
||||||
at.rotate(angle, x + 25, y + 25);
|
|
||||||
g2d.transform(at);
|
|
||||||
|
|
||||||
// Draw the current rotated frame
|
|
||||||
g2d.drawImage(sprites[(int) (Math.round(currentFrame))], x, y, null);
|
|
||||||
|
|
||||||
g2d.setTransform(trans);
|
|
||||||
|
|
||||||
// Switch animation frames
|
|
||||||
if (currentFrame >= count - 1) {
|
|
||||||
currentFrame = 0;
|
|
||||||
} else currentFrame += speed;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -8,12 +8,9 @@ package com.example.flappybird; /**
|
|||||||
import javax.sound.sampled.AudioInputStream;
|
import javax.sound.sampled.AudioInputStream;
|
||||||
import javax.sound.sampled.AudioSystem;
|
import javax.sound.sampled.AudioSystem;
|
||||||
import javax.sound.sampled.Clip;
|
import javax.sound.sampled.Clip;
|
||||||
|
import java.net.URL;
|
||||||
|
|
||||||
public class Audio {
|
public class Audio {
|
||||||
|
|
||||||
private AudioInputStream audioInputStream;
|
|
||||||
private Clip clip;
|
|
||||||
|
|
||||||
private void playSound (String sound) {
|
private void playSound (String sound) {
|
||||||
|
|
||||||
// Path to sound file
|
// Path to sound file
|
||||||
@ -21,8 +18,11 @@ public class Audio {
|
|||||||
|
|
||||||
// Try to load and play sound
|
// Try to load and play sound
|
||||||
try {
|
try {
|
||||||
audioInputStream = AudioSystem.getAudioInputStream(this.getClass().getResource(soundURL));
|
URL audioUrl = this.getClass().getResource(soundURL);
|
||||||
clip = AudioSystem.getClip();
|
assert audioUrl != null;
|
||||||
|
|
||||||
|
AudioInputStream audioInputStream = AudioSystem.getAudioInputStream(audioUrl);
|
||||||
|
Clip clip = AudioSystem.getClip();
|
||||||
clip.open(audioInputStream);
|
clip.open(audioInputStream);
|
||||||
clip.start();
|
clip.start();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
@ -5,15 +5,15 @@ package com.example.flappybird; /**
|
|||||||
* @author Paul Krishnamurthy
|
* @author Paul Krishnamurthy
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import javax.swing.JPanel;
|
import java.awt.*;
|
||||||
|
import java.awt.geom.AffineTransform;
|
||||||
import java.awt.image.BufferedImage;
|
import java.awt.image.BufferedImage;
|
||||||
import java.awt.Graphics;
|
|
||||||
|
|
||||||
public class Bird extends JPanel {
|
public class Bird extends HasPosition {
|
||||||
|
|
||||||
// Bird attributes
|
// Bird attributes
|
||||||
public String color;
|
public String color;
|
||||||
private int x, y;
|
|
||||||
private boolean isAlive = true;
|
private boolean isAlive = true;
|
||||||
|
|
||||||
// Bird constants
|
// Bird constants
|
||||||
@ -34,11 +34,12 @@ public class Bird extends JPanel {
|
|||||||
// Bird sprites
|
// Bird sprites
|
||||||
private BufferedImage[] sprites;
|
private BufferedImage[] sprites;
|
||||||
|
|
||||||
|
private static double currentFrame = 0;
|
||||||
|
|
||||||
|
|
||||||
public Bird (String color, int x, int y, BufferedImage[] s) {
|
public Bird (String color, int x, int y, BufferedImage[] s) {
|
||||||
|
super(x, y);
|
||||||
this.color = color;
|
this.color = color;
|
||||||
this.x = x;
|
|
||||||
this.y = y;
|
|
||||||
this.sprites = s;
|
this.sprites = s;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -144,7 +145,7 @@ public class Bird extends JPanel {
|
|||||||
rotation /= 2;
|
rotation /= 2;
|
||||||
|
|
||||||
// Handle rotation offset
|
// Handle rotation offset
|
||||||
rotation = rotation > Math.PI / 2 ? Math.PI / 2 : rotation;
|
rotation = Math.min(rotation, Math.PI / 2);
|
||||||
|
|
||||||
if (!isAlive()) {
|
if (!isAlive()) {
|
||||||
|
|
||||||
@ -157,8 +158,32 @@ public class Bird extends JPanel {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Create bird animation and pass in rotation angle
|
// Create bird animation and pass in rotation angle
|
||||||
Animation.animate(g, sprites, x, y, .09, rotation);
|
animateBird(g, rotation);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void animateBird(Graphics g, double angle) {
|
||||||
|
|
||||||
|
Graphics2D g2d = (Graphics2D) g;
|
||||||
|
AffineTransform trans = g2d.getTransform();
|
||||||
|
AffineTransform at = new AffineTransform();
|
||||||
|
|
||||||
|
// Number of frames
|
||||||
|
int count = sprites.length;
|
||||||
|
|
||||||
|
// Rotate the image
|
||||||
|
at.rotate(angle, x + 25, y + 25);
|
||||||
|
g2d.transform(at);
|
||||||
|
|
||||||
|
// Draw the current rotated frame
|
||||||
|
g2d.drawImage(sprites[(int) (Math.round(currentFrame))], x, y, null);
|
||||||
|
|
||||||
|
g2d.setTransform(trans);
|
||||||
|
|
||||||
|
// Switch animation frames
|
||||||
|
if (currentFrame >= count - 1) {
|
||||||
|
currentFrame = 0;
|
||||||
|
} else currentFrame += 0.09;
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -8,6 +8,7 @@ package com.example.flappybird; /**
|
|||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
|
import java.net.URI;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
@ -501,6 +502,18 @@ public class GamePanel extends JPanel implements KeyListener, MouseListener {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void openURL (String url) {
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (Desktop.isDesktopSupported()) {
|
||||||
|
Desktop.getDesktop().browse(new URI(url));
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
System.out.println("Sorry could not open URL...");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
//////////////////////
|
//////////////////////
|
||||||
// Keyboard actions //
|
// Keyboard actions //
|
||||||
@ -569,7 +582,7 @@ public class GamePanel extends JPanel implements KeyListener, MouseListener {
|
|||||||
if (gameBird.isAlive()) {
|
if (gameBird.isAlive()) {
|
||||||
|
|
||||||
if (isTouching(textures.get("rateButton").getRect())) {
|
if (isTouching(textures.get("rateButton").getRect())) {
|
||||||
Helper.openURL("http://paulkr.com"); // Open website
|
openURL("http://paulkr.com"); // Open website
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,19 @@
|
|||||||
|
package com.example.flappybird;
|
||||||
|
|
||||||
|
public class HasPosition {
|
||||||
|
protected int x;
|
||||||
|
protected int y;
|
||||||
|
|
||||||
|
public HasPosition(int x, int y) {
|
||||||
|
this.x = x;
|
||||||
|
this.y = y;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getX() {
|
||||||
|
return this.x;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getY() {
|
||||||
|
return this.y;
|
||||||
|
}
|
||||||
|
}
|
@ -1,31 +0,0 @@
|
|||||||
package com.example.flappybird; /**
|
|
||||||
* Helper.java
|
|
||||||
* Helper class with various tools
|
|
||||||
*
|
|
||||||
* @author Paul Krishnamurthy
|
|
||||||
*/
|
|
||||||
|
|
||||||
import java.awt.Desktop;
|
|
||||||
import java.net.URI;
|
|
||||||
|
|
||||||
public class Helper {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Tries to open url in default web browser
|
|
||||||
*
|
|
||||||
* @param url Destination URL
|
|
||||||
*/
|
|
||||||
public static void openURL (String url) {
|
|
||||||
|
|
||||||
try {
|
|
||||||
if (Desktop.isDesktopSupported()) {
|
|
||||||
Desktop.getDesktop().browse(new URI(url));
|
|
||||||
}
|
|
||||||
} catch (Exception e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
System.out.println("Sorry could not open URL...");
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -7,12 +7,7 @@ package com.example.flappybird;
|
|||||||
* @author Paul Krishnamurthy
|
* @author Paul Krishnamurthy
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public class Pipe {
|
public class Pipe extends HasPosition {
|
||||||
|
|
||||||
// Pipe coordinates
|
|
||||||
private int x = FlappyBird.WIDTH + 5;
|
|
||||||
private int y;
|
|
||||||
|
|
||||||
// Placement (top or bottom) of pipe
|
// Placement (top or bottom) of pipe
|
||||||
String location;
|
String location;
|
||||||
|
|
||||||
@ -27,17 +22,18 @@ public class Pipe {
|
|||||||
public boolean canAwardPoint = true;
|
public boolean canAwardPoint = true;
|
||||||
|
|
||||||
public Pipe (String location) {
|
public Pipe (String location) {
|
||||||
|
super(FlappyBird.WIDTH + 5, 0);
|
||||||
this.location = location;
|
this.location = location;
|
||||||
reset();
|
reset();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void reset () {
|
public void reset () {
|
||||||
x = FlappyBird.WIDTH + 5; // Reset x-coordinate
|
super.x = FlappyBird.WIDTH + 5; // Reset x-coordinate
|
||||||
|
|
||||||
// Set boundaries for top pipes
|
// Set boundaries for top pipes
|
||||||
// This y-coordinte + PIPE_SPACING will be for the bottom pipe
|
// This y-coordinte + PIPE_SPACING will be for the bottom pipe
|
||||||
if (location.equals("top")) {
|
if (location.equals("top")) {
|
||||||
y = - Math.max((int) (Math.random() * 320) + 30, 140);
|
super.y = - Math.max((int) (Math.random() * 320) + 30, 140);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -45,7 +41,7 @@ public class Pipe {
|
|||||||
* Moves the pipe
|
* Moves the pipe
|
||||||
*/
|
*/
|
||||||
public void move () {
|
public void move () {
|
||||||
x += SPEED;
|
super.x += SPEED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -61,29 +57,14 @@ public class Pipe {
|
|||||||
public boolean collide (int nX, int nY, int nW, int nH) {
|
public boolean collide (int nX, int nY, int nW, int nH) {
|
||||||
|
|
||||||
// Do not allow bird to jump over pipe
|
// Do not allow bird to jump over pipe
|
||||||
if (nX > x && nY < 0 && canAwardPoint) {
|
if (nX > super.x && nY < 0 && canAwardPoint) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return nX < x + WIDTH &&
|
return nX < super.x + WIDTH &&
|
||||||
nX + nW > x &&
|
nX + nW > super.x &&
|
||||||
nY < y + HEIGHT &&
|
nY < super.y + HEIGHT &&
|
||||||
nY + nH > y;
|
nY + nH > super.y;
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Pipe's x-coordinate
|
|
||||||
*/
|
|
||||||
public int getX () {
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @return Pipe's y-coordinate
|
|
||||||
*/
|
|
||||||
public int getY () {
|
|
||||||
return y;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -94,6 +75,5 @@ public class Pipe {
|
|||||||
public void setY (int newY) {
|
public void setY (int newY) {
|
||||||
y = newY;
|
y = newY;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -8,20 +8,20 @@ package com.example.flappybird; /**
|
|||||||
import java.awt.image.BufferedImage;
|
import java.awt.image.BufferedImage;
|
||||||
import java.awt.Rectangle;
|
import java.awt.Rectangle;
|
||||||
|
|
||||||
public class Texture {
|
public class Texture extends HasPosition {
|
||||||
|
|
||||||
// Image attributes
|
// Image attributes
|
||||||
private BufferedImage image;
|
private final BufferedImage image;
|
||||||
private int x, y, width, height;
|
private final Rectangle rect;
|
||||||
private Rectangle rect;
|
|
||||||
|
|
||||||
|
|
||||||
public Texture (BufferedImage image, int x, int y) {
|
public Texture (BufferedImage image, int x, int y) {
|
||||||
|
super(x, y);
|
||||||
|
|
||||||
this.image = image;
|
this.image = image;
|
||||||
this.x = x;
|
int width = image.getWidth();
|
||||||
this.y = y;
|
int height = image.getHeight();
|
||||||
this.width = image.getWidth();
|
|
||||||
this.height = image.getHeight();
|
|
||||||
this.rect = new Rectangle(x, y, width, height);
|
this.rect = new Rectangle(x, y, width, height);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -33,22 +33,6 @@ public class Texture {
|
|||||||
return image;
|
return image;
|
||||||
}
|
}
|
||||||
|
|
||||||
public int getX () {
|
|
||||||
return x;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getY () {
|
|
||||||
return y;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getWidth () {
|
|
||||||
return width;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getHeight () {
|
|
||||||
return height;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Rectangle getRect () {
|
public Rectangle getRect () {
|
||||||
return rect;
|
return rect;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user