aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorZach Jordan <zjordan58@fairport.org>2023-05-18 08:21:57 -0400
committerZach Jordan <zjordan58@fairport.org>2023-05-18 08:21:57 -0400
commitbbad14a33c614ac3480c599dd72a06e14a86295c (patch)
treec66a48226ad8fc99cd8ebe8894646d6f14228ca7
parent6e58f0c2ea47c33555e236c5f3bcb64a89c633fc (diff)
parent33b5b82b1a2c511c6de0c1f744aec1f04bee12f7 (diff)
downloadNPEhero-bbad14a33c614ac3480c599dd72a06e14a86295c.tar.gz
NPEhero-bbad14a33c614ac3480c599dd72a06e14a86295c.tar.bz2
NPEhero-bbad14a33c614ac3480c599dd72a06e14a86295c.zip
Merge branch 'main' of
https://gitlab.sowgro.net/guitarheros/guitarhero.git into main Conflicts: .classpath
-rw-r--r--.vscode/launch.json3
-rw-r--r--src/fallTest/Block.java27
-rw-r--r--src/fallTest/Driver.java45
-rw-r--r--src/fallTest/Hbox.java5
-rw-r--r--src/fallTest/LaneInfo.java28
-rw-r--r--src/fallTest/Level.java106
-rw-r--r--src/fallTest/NoteNode.java20
-rw-r--r--src/fallTest/TButton.java27
-rw-r--r--src/fallTest/newSongPlayer.java110
-rw-r--r--src/gui/Driver.java16
-rw-r--r--src/gui/LevelDetails.java9
-rw-r--r--src/gui/LevelSurround.java97
-rw-r--r--src/gui/SongPlayer2.java232
13 files changed, 714 insertions, 11 deletions
diff --git a/.vscode/launch.json b/.vscode/launch.json
index 9596ad3..257652c 100644
--- a/.vscode/launch.json
+++ b/.vscode/launch.json
@@ -49,7 +49,8 @@
"name": "Driver",
"request": "launch",
"mainClass": "fallTest.Driver",
- "projectName": "GuitarHero"
+ "projectName": "GuitarHero",
+ "vmArgs": "--module-path lib/linux --add-modules javafx.base,javafx.media,javafx.graphics,javafx.controls,javafx.fxml"
},
{
"type": "java",
diff --git a/src/fallTest/Block.java b/src/fallTest/Block.java
new file mode 100644
index 0000000..ab2f902
--- /dev/null
+++ b/src/fallTest/Block.java
@@ -0,0 +1,27 @@
+//glowing block of color c (jfx node)
+
+package fallTest;
+
+import javafx.scene.effect.BlurType;
+import javafx.scene.effect.DropShadow;
+import javafx.scene.paint.Color;
+import javafx.scene.shape.Rectangle;
+
+public class Block extends Rectangle
+{
+ public Block(Color c, double a, double b, int r)
+ {
+ super();
+ DropShadow dropShadow = new DropShadow();
+ dropShadow.setRadius(200.0);
+ dropShadow.setColor(c);
+ dropShadow.setBlurType(BlurType.GAUSSIAN);
+
+ super.setFill(c);
+ super.setWidth(a);
+ super.setHeight(b);
+ super.setArcHeight(r);
+ super.setArcWidth(r);
+ super.setEffect(dropShadow);
+ }
+} \ No newline at end of file
diff --git a/src/fallTest/Driver.java b/src/fallTest/Driver.java
index 0ad60f0..3bc7c25 100644
--- a/src/fallTest/Driver.java
+++ b/src/fallTest/Driver.java
@@ -6,16 +6,49 @@
*/
package fallTest;
+import javafx.application.*;
+import javafx.geometry.Side;
+import javafx.scene.Scene;
+import javafx.scene.image.Image;
+import javafx.scene.layout.Background;
+import javafx.scene.layout.BackgroundImage;
+import javafx.scene.layout.BackgroundPosition;
+import javafx.scene.layout.BackgroundRepeat;
+import javafx.scene.layout.BackgroundSize;
+import javafx.scene.layout.Pane;
+import javafx.stage.Stage;
-public class Driver
+public class Driver extends Application
{
+ static Pane primaryPane = new Pane();
+
public static void main(String[] args)
{
- // TODO Auto-generated method stub
- SongPlayer g = new SongPlayer();
- g.loadSong();
- g.createAndShowGui();
- }
+ launch(args);
+ }
+ @Override
+ public void start(Stage primaryStage) throws Exception {
+ Scene primaryScene = new Scene(primaryPane, 800, 600);
+ primaryScene.getStylesheets().add("gui/style.css");
+ primaryStage.setScene(primaryScene);
+ newSongPlayer player = new newSongPlayer();
+ primaryStage.setTitle("TEST");
+ primaryPane.getChildren().add(player);
+ setBackground("assets/water.png");
+ player.init();
+ primaryStage.show();
+ }
+
+ public static void setBackground(String url)
+ {
+ primaryPane.setBackground(new Background(
+ new BackgroundImage(
+ new Image(url),
+ BackgroundRepeat.REPEAT, BackgroundRepeat.NO_REPEAT,
+ new BackgroundPosition(Side.LEFT, 0, true, Side.BOTTOM, 0, true),
+ new BackgroundSize(BackgroundSize.AUTO, BackgroundSize.AUTO, true, true, false, true)
+ )));
+ }
}
diff --git a/src/fallTest/Hbox.java b/src/fallTest/Hbox.java
new file mode 100644
index 0000000..a7a97a7
--- /dev/null
+++ b/src/fallTest/Hbox.java
@@ -0,0 +1,5 @@
+package fallTest;
+
+public class Hbox {
+
+}
diff --git a/src/fallTest/LaneInfo.java b/src/fallTest/LaneInfo.java
new file mode 100644
index 0000000..7fe5567
--- /dev/null
+++ b/src/fallTest/LaneInfo.java
@@ -0,0 +1,28 @@
+package fallTest;
+
+import java.util.ArrayList;
+import java.util.LinkedList;
+import java.util.Queue;
+
+import javax.swing.JButton;
+
+public class LaneInfo {
+ //test
+ Queue<NoteInfo> sends = new LinkedList<NoteInfo>(); //Queue that dictates when to send the notes
+ ArrayList<Block> nodes = new ArrayList<Block>(); //Array list containing all the notes currently on the field
+ public void addSends(int t) {
+ sends.add(new NoteInfo(t));
+ }
+
+ public void addNodes(int t) {
+ nodes.add(new Block());
+ }
+
+ public ArrayList<Block> getNodes() {
+ return nodes;
+ }
+
+ public Queue<NoteInfo> getSends() {
+ return sends;
+ }
+}
diff --git a/src/fallTest/Level.java b/src/fallTest/Level.java
new file mode 100644
index 0000000..71ee0a8
--- /dev/null
+++ b/src/fallTest/Level.java
@@ -0,0 +1,106 @@
+package fallTest;
+
+import javafx.application.Application;
+import javafx.event.ActionEvent;
+import javafx.event.EventHandler;
+import javafx.geometry.Insets;
+import javafx.scene.Scene;
+import javafx.scene.control.Button;
+import javafx.scene.effect.BlurType;
+import javafx.scene.effect.DropShadow;
+import javafx.scene.layout.AnchorPane;
+import javafx.scene.layout.Background;
+import javafx.scene.layout.BackgroundFill;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.CornerRadii;
+import javafx.scene.layout.GridPane;
+import javafx.scene.layout.Pane;
+import javafx.scene.layout.StackPane;
+import javafx.scene.paint.Color;
+import javafx.scene.shape.Rectangle;
+import javafx.scene.text.Font;
+import javafx.scene.text.FontWeight;
+import javafx.scene.text.Text;
+import javafx.stage.Stage;
+
+// will eventually extend pane
+public class Level extends Pane {
+
+
+ public Level() {
+
+ BorderPane background = new BorderPane();
+ Scene game = new Scene(background, 800, 600);
+ GridPane blockGrid = new GridPane();
+ blockGrid.setBackground(new Background(new BackgroundFill(Color.BLACK, CornerRadii.EMPTY, Insets.EMPTY)));
+ background.setCenter(blockGrid);
+
+ blockGrid.maxWidthProperty().bind(game.heightProperty().multiply(0.53));
+ blockGrid.maxHeightProperty().bind(game.heightProperty());
+ System.out.println(game.heightProperty());
+
+ //blockGrid.setMaxHeight(700);
+ //blockGrid.setMaxWidth(500);
+ //blockGrid.setScaleX(1);
+ //blockGrid.setScaleY(1);
+ //blockGrid.scaleXProperty().bind(game.heightProperty().divide(1000));
+ //blockGrid.scaleYProperty().bind(game.heightProperty().divide(1000));
+ //blockGrid.hgapProperty().bind(blockGrid.heightProperty().divide(11));
+ //blockGrid.vgapProperty().bind(blockGrid.widthProperty().divide(21));
+ blockGrid.setVgap(10);
+ blockGrid.setHgap(25);
+
+ int blocksize = 50;
+ //AnchorPane b11 = new AnchorPane();
+ //b11.getChildren().add(new Block(Color.ORANGE, b11, 10));
+ Block b1 = new Block(Color.RED, blocksize, blocksize, 10);
+ //b1.heightProperty().bind(blockGrid.heightProperty().divide((blockGrid.getColumnCount()*2)+1));
+ //b1.widthProperty().bind(blockGrid.widthProperty().divide((blockGrid.getRowCount()*2)+1));
+
+ Block b2 = new Block(Color.BLUE, blocksize, blocksize, 10);
+ //b2.heightProperty().bind(blockGrid.heightProperty().divide(21));
+ //b2.widthProperty().bind(blockGrid.widthProperty().divide(11));
+
+ Block b3 = new Block(Color.GREEN, blocksize, blocksize, 10);
+ //b3.heightProperty().bind(blockGrid.heightProperty().divide(21));
+ //b3.widthProperty().bind(blockGrid.widthProperty().divide(11));
+
+ Block b4 = new Block(Color.YELLOW, blocksize, blocksize, 10);
+ //b4.heightProperty().bind(blockGrid.heightProperty().divide(21));
+ //b4.widthProperty().bind(blockGrid.widthProperty().divide(11));
+
+ Pane test = new Pane();
+
+ Block b5 = new Block(Color.ORANGE, blocksize, blocksize, 10);
+ DropShadow dropShadow = new DropShadow();
+ dropShadow.setRadius(200.0);
+ dropShadow.setColor(Color.ORANGE);
+ dropShadow.setBlurType(BlurType.GAUSSIAN);
+ test.getChildren().add(b5);
+ test.setEffect(dropShadow);
+
+
+
+ blockGrid.add(b1, 0, 0);
+ blockGrid.add(b2, 1, 0);
+ blockGrid.add(b3, 0, 1);
+ blockGrid.add(b4, 1, 1);
+ blockGrid.add(test, 1, 2);
+
+ Button btn = new Button();
+ btn.setText("Test");
+ btn.setOnAction(new EventHandler<ActionEvent>()
+ {
+ @Override
+ public void handle(ActionEvent event)
+ {
+ System.out.println("test");
+ }
+ });
+
+ background.setLeft(btn);
+
+
+
+ }
+} \ No newline at end of file
diff --git a/src/fallTest/NoteNode.java b/src/fallTest/NoteNode.java
new file mode 100644
index 0000000..64e1b8a
--- /dev/null
+++ b/src/fallTest/NoteNode.java
@@ -0,0 +1,20 @@
+package fallTest;
+
+import javafx.animation.*;
+import javafx.util.Duration;
+
+public class NoteNode {
+ private final int TIME = 20;
+ private NoteField info;
+ private Block vis;
+ TranslateTransition anim = new TranslateTransition(Duration.millis(TIME));
+ public NoteNode(NoteField newInfo, Block newVis) {
+ vis=newVis;
+ info = newInfo;
+ anim.setNode(vis);
+ anim.setByY(height);
+ anim.setCycleCount(1);
+ anim.setAutoReverse(false);
+ anim.play();
+ }
+}
diff --git a/src/fallTest/TButton.java b/src/fallTest/TButton.java
new file mode 100644
index 0000000..d18771f
--- /dev/null
+++ b/src/fallTest/TButton.java
@@ -0,0 +1,27 @@
+//glowing block of color c (jfx node)
+
+package fallTest;
+
+import javafx.scene.effect.BlurType;
+import javafx.scene.effect.DropShadow;
+import javafx.scene.paint.Color;
+import javafx.scene.shape.Rectangle;
+import javafx.scene.text.Text;
+import javafx.scene.paint.*;
+
+public class TButton extends Rectangle
+{
+ public TButton(Color c, double a, double b, int r)
+ {
+ super();
+
+ Color newCol = new Color(c.darker().getRed(), c.darker().getGreen(), c.darker().getBlue(), 0.25);
+ super.setFill(newCol);
+ super.setWidth(a);
+ super.setHeight(b);
+ super.setArcHeight(r);
+ super.setArcWidth(r);
+ super.setStroke(c);
+ super.setStrokeWidth(5);
+ }
+} \ No newline at end of file
diff --git a/src/fallTest/newSongPlayer.java b/src/fallTest/newSongPlayer.java
new file mode 100644
index 0000000..3f6d4ed
--- /dev/null
+++ b/src/fallTest/newSongPlayer.java
@@ -0,0 +1,110 @@
+package fallTest;
+
+import javafx.event.EventHandler;
+
+import java.awt.Insets;
+import java.util.ArrayList;
+import java.util.LinkedList;
+import java.util.Queue;
+
+import javafx.beans.property.DoubleProperty;
+import javafx.event.*;
+import javafx.event.ActionEvent;
+import javafx.geometry.Pos;
+import javafx.scene.control.Button;
+import javafx.scene.effect.BlurType;
+import javafx.scene.effect.DropShadow;
+import javafx.scene.input.KeyCode;
+import javafx.scene.layout.Border;
+import javafx.scene.layout.BorderStroke;
+import javafx.scene.layout.BorderStrokeStyle;
+import javafx.scene.layout.BorderWidths;
+import javafx.scene.layout.CornerRadii;
+import javafx.scene.layout.HBox;
+import javafx.scene.layout.Pane;
+import javafx.scene.layout.StackPane;
+import javafx.scene.layout.VBox;
+import javafx.scene.paint.Color;
+import javafx.scene.shape.Rectangle;
+import javafx.scene.text.Font;
+import javafx.scene.text.Text;
+
+public class newSongPlayer extends Pane
+{
+ Timer time = new Timer();
+
+ private double dLaneX = 0;
+ TButton dButton = new TButton(Color.RED, 50, 50, 5);
+
+ public void init() {
+ Queue<NoteInfo> dSends = new LinkedList<NoteInfo>(); //Queue that dictates when to send the notes
+ ArrayList<Block> dLane = new ArrayList<Block>(); //Array list containing all the notes currently on the field
+
+ Rectangle field = new Rectangle(50, 50, new Color(0, 0, 0, 0.7));
+ field.heightProperty().bind(this.getScene().getWindow().heightProperty().multiply(0.95));
+ field.widthProperty().bind(this.getScene().getWindow().widthProperty().divide(2.7).add(50));
+ genButton(dButton);
+ /*dButton.setOnKeyPressed(e -> {
+ if (e.getCode() == KeyCode.D) {
+ System.out.println("D");
+ }
+ });*/
+
+ TButton fButton = new TButton(Color.BLUE, 50, 50, 5);
+ genButton(fButton);
+
+ TButton sButton = new TButton(Color.GREEN, 50, 50, 5);
+ genButton(sButton);
+
+ TButton jButton = new TButton(Color.PURPLE, 50, 50, 5);
+ genButton(jButton);
+
+ TButton kButton = new TButton(Color.YELLOW, 50, 50, 5);
+ genButton(kButton);
+
+
+ HBox buttonBox = new HBox();
+ buttonBox.setStyle("-fx-padding: 0;" + "-fx-border-style: solid inside;"
+ + "-fx-border-width: 0;" + "-fx-border-insets: 20;"
+ + "-fx-background-color: black;" + "-fx-opacity: 0.67;");
+ buttonBox.setAlignment(Pos.CENTER);
+ buttonBox.getChildren().addAll(dButton, fButton, sButton, jButton, kButton);
+ buttonBox.setSpacing(10);
+
+ VBox polish = new VBox();
+ polish.getChildren().addAll(field);
+ polish.setAlignment(Pos.TOP_CENTER);
+
+ VBox place = new VBox();
+ place.prefWidthProperty().bind(this.getScene().widthProperty());
+ place.prefHeightProperty().bind(this.getScene().heightProperty());
+ place.setAlignment(Pos.BOTTOM_CENTER);
+ place.getChildren().addAll(buttonBox);
+ place.setSpacing(10);
+
+ StackPane root = new StackPane();
+ root.getChildren().addAll(polish, place);
+
+ super.getChildren().add(root);
+ sendNote(dLane, buttonBox.getLayoutX());
+ }
+
+ public void sendNote(ArrayList<Block> lane, double pos) {
+ lane.add(new Block(Color.PINK, 50, 50, 5));
+ lane.get(lane.size()-1).heightProperty().bind(this.getScene().getWindow().widthProperty().divide(16));
+ lane.get(lane.size()-1).widthProperty().bind(this.getScene().getWindow().widthProperty().divide(16));
+ lane.get(lane.size()-1).arcHeightProperty().bind(this.getScene().getWindow().widthProperty().divide(50));
+ lane.get(lane.size()-1).arcWidthProperty().bind(this.getScene().getWindow().widthProperty().divide(50));
+ lane.get(lane.size()-1).setX(pos);
+ System.out.println(pos);
+ super.getChildren().add(lane.get(lane.size()-1));
+ }
+
+ public void genButton(TButton button) {
+ button.heightProperty().bind(this.getScene().getWindow().widthProperty().divide(16));
+ button.widthProperty().bind(this.getScene().getWindow().widthProperty().divide(16));
+ button.arcHeightProperty().bind(this.getScene().getWindow().widthProperty().divide(50));
+ button.arcWidthProperty().bind(this.getScene().getWindow().widthProperty().divide(50));
+ button.strokeWidthProperty().bind(this.getScene().getWindow().widthProperty().divide(210));
+ }
+}
diff --git a/src/gui/Driver.java b/src/gui/Driver.java
index 77fe0b0..59002c2 100644
--- a/src/gui/Driver.java
+++ b/src/gui/Driver.java
@@ -17,6 +17,7 @@ import javafx.stage.Stage;
public class Driver extends Application
{
+ static Stage primaryStage;
static HashMap<String,Pane> menus = new HashMap<String,Pane>();
static Pane primaryPane = new Pane();
@@ -26,8 +27,9 @@ public class Driver extends Application
}
@Override
- public void start(Stage primaryStage)
+ public void start(Stage newPrimaryStage)
{
+ primaryStage = newPrimaryStage;
menus.put("MainMenu", new MainMenu());
menus.put("LevelSelector", new LevelSelector());
menus.put("Settings", new Settings());
@@ -61,6 +63,18 @@ public class Driver extends Application
primaryPane.requestFocus();
}
+ public static void setCustomMenu(Pane pane)
+ {
+ if (! primaryPane.getChildren().isEmpty())
+ {
+ primaryPane.getChildren().remove(0);
+ }
+ pane.minWidthProperty().bind(primaryStage.widthProperty());
+ pane.minHeightProperty().bind(primaryStage.heightProperty());
+ primaryPane.getChildren().add(pane);
+ primaryPane.requestFocus();
+ }
+
public static void setBackground(String url)
{
primaryPane.setBackground(new Background(
diff --git a/src/gui/LevelDetails.java b/src/gui/LevelDetails.java
index dee2f00..5623261 100644
--- a/src/gui/LevelDetails.java
+++ b/src/gui/LevelDetails.java
@@ -1,5 +1,6 @@
package gui;
+import javafx.geometry.Insets;
import javafx.geometry.Pos;
import javafx.scene.control.Button;
import javafx.scene.control.ListView;
@@ -22,6 +23,7 @@ public class LevelDetails extends VBox
details.maxWidthProperty().bind(super.widthProperty());
details.maxHeightProperty().bind(super.heightProperty().multiply(0.75));
details.getStyleClass().add("textBox");
+ details.setPadding(new Insets(10));
Button play = new Button();
play.setText("Play");
@@ -31,7 +33,7 @@ public class LevelDetails extends VBox
Text desc = new Text();
desc.setText("Select a level from the left pane");
desc.setFill(Color.WHITE);
- desc.wrappingWidthProperty().bind(super.widthProperty());
+ desc.wrappingWidthProperty().bind(super.widthProperty().subtract(10));
desc.setTextAlignment(TextAlignment.CENTER);
details.setAlignment(Pos.CENTER);
details.getChildren().addAll(desc);
@@ -44,12 +46,12 @@ public class LevelDetails extends VBox
title.setText("Test level 1");
title.setFill(Color.WHITE);
title.setFont(new Font(50));
- title.wrappingWidthProperty().bind(super.widthProperty());
+ title.wrappingWidthProperty().bind(super.widthProperty().subtract(10));
Text desc = new Text();
desc.setText("long description with lots of words. what we write does not actually need to be long i just wan t make sure it can word wrap");
desc.setFill(Color.WHITE);
- desc.wrappingWidthProperty().bind(super.widthProperty());
+ desc.wrappingWidthProperty().bind(super.widthProperty().subtract(10));
ImageView previewView = new ImageView();
Image preview = new Image("assets/pico.png");
@@ -58,6 +60,7 @@ public class LevelDetails extends VBox
previewView.fitWidthProperty().bind(super.widthProperty().multiply(0.5));
previewView.setPreserveRatio(true);
details.getChildren().addAll(title,desc,previewView);
+ play.setOnAction(e -> Driver.setCustomMenu(new LevelSurround()));
}
VBox rightBox = new VBox();
diff --git a/src/gui/LevelSurround.java b/src/gui/LevelSurround.java
new file mode 100644
index 0000000..bf71f2f
--- /dev/null
+++ b/src/gui/LevelSurround.java
@@ -0,0 +1,97 @@
+package gui;
+
+import fallTest.Hbox;
+import javafx.geometry.Insets;
+import javafx.geometry.Pos;
+import javafx.scene.control.Button;
+import javafx.scene.layout.BorderPane;
+import javafx.scene.layout.HBox;
+import javafx.scene.layout.Pane;
+import javafx.scene.layout.StackPane;
+import javafx.scene.layout.VBox;
+import javafx.scene.paint.Color;
+import javafx.scene.text.Font;
+import javafx.scene.text.Text;
+
+public class LevelSurround extends Pane
+{
+ //will have param (Level l)
+ public LevelSurround()
+ {
+ Button exit = new Button();
+ exit.setText("Exit");
+ exit.setOnAction(e -> Driver.setMenu("LevelSelector"));
+
+ Button pause = new Button();
+ pause.setText("Pause");
+
+ HBox buttonBox = new HBox();
+ buttonBox.getChildren().addAll(exit,pause);
+ buttonBox.setAlignment(Pos.TOP_LEFT);
+ buttonBox.setSpacing(10);
+
+ Text title = new Text();
+ title.setText("Test level 1");
+ title.setFill(Color.WHITE);
+ title.setFont(new Font(50));
+
+ Text diff = new Text();
+ diff.setText("Easy");
+ diff.setFill(Color.WHITE);
+
+ VBox titleTextBox = new VBox();
+ titleTextBox.setAlignment(Pos.TOP_RIGHT);
+ titleTextBox.getChildren().addAll(title,diff);
+
+ BorderPane topBar = new BorderPane();
+ topBar.setLeft(buttonBox);
+ topBar.setRight(titleTextBox);
+ topBar.setPadding(new Insets(10));
+
+
+ Text scoreLabel = new Text();
+ scoreLabel.setText("Score:");
+ scoreLabel.setFill(Color.WHITE);
+
+ Text score = new Text();
+ score.setText("100000");
+ score.setFill(Color.WHITE);
+ score.setFont(new Font(50));
+
+ VBox scoreTextBox = new VBox();
+ scoreTextBox.setAlignment(Pos.BOTTOM_LEFT);
+ scoreTextBox.getChildren().addAll(scoreLabel,score);
+ scoreTextBox.setPadding(new Insets(10));
+
+
+ Text comboLabel = new Text();
+ comboLabel.setText("Combo:");
+ comboLabel.setFill(Color.WHITE);
+
+ Text combo = new Text();
+ combo.setText("100000");
+ combo.setFill(Color.WHITE);
+ combo.setFont(new Font(50));
+
+ VBox comboTextBox = new VBox();
+ comboTextBox.setAlignment(Pos.BOTTOM_RIGHT);
+ comboTextBox.getChildren().addAll(comboLabel,combo);
+ comboTextBox.setPadding(new Insets(10));
+
+ Pane game = new Pane();
+ game.minWidthProperty().bind(super.heightProperty().multiply(0.66));
+ game.minHeightProperty().bind(super.heightProperty());
+ game.getStyleClass().add("textBox");
+
+ HBox centerBox = new HBox();
+ centerBox.getChildren().addAll(comboTextBox,game, scoreTextBox);
+ centerBox.setAlignment(Pos.BOTTOM_CENTER);
+
+ StackPane root = new StackPane();
+ root.getChildren().addAll(centerBox, topBar);
+
+ super.getChildren().add(root);
+ root.minWidthProperty().bind(super.minWidthProperty());
+ root.minHeightProperty().bind(super.minHeightProperty());
+ }
+} \ No newline at end of file
diff --git a/src/gui/SongPlayer2.java b/src/gui/SongPlayer2.java
new file mode 100644
index 0000000..ed6476d
--- /dev/null
+++ b/src/gui/SongPlayer2.java
@@ -0,0 +1,232 @@
+/*Name: Guitar Hero Project
+ *Description: Contains the main game loop for gameplay
+ */
+package gui;
+
+import javafx.scene.control.Button;
+import javafx.scene.layout.HBox;
+import javafx.scene.layout.Pane;
+
+import java.util.*;
+
+import fallTest.NoteField;
+import fallTest.NoteInfo;
+import fallTest.Score;
+import fallTest.Timer;
+//test
+public class SongPlayer2 extends Pane
+{
+ Timer time = new Timer();
+
+ public static final int HEIGHT = 650;
+ public static final int LENGTH = 400;
+
+ private final int BLENGTH = LENGTH/7;
+ private final int BHEIGHT = HEIGHT/20;
+
+ Button d = new Button("D");
+ Button f = new Button("F");
+ Button space= new Button("...");
+ Button j = new Button("J");
+ Button k = new Button("K");
+
+ Queue<NoteInfo> dSends = new LinkedList<NoteInfo>(); //Queue that dictates when to send the notes
+ ArrayList<NoteField> dLane = new ArrayList<NoteField>(); //Array list containing all the notes currently on the field
+ ArrayList<Block> dVis = new ArrayList<Block>(); //Array list containing the visual representations of the notes in lanes
+
+ Queue<NoteInfo> fSends = new LinkedList<NoteInfo>();
+ ArrayList<NoteField> fLane = new ArrayList<NoteField>();
+ ArrayList<Block> fVis = new ArrayList<Block>();
+
+ Queue<NoteInfo> spaceSends = new LinkedList<NoteInfo>();
+ ArrayList<NoteField> spaceLane = new ArrayList<NoteField>();
+ ArrayList<Block> spaceVis = new ArrayList<Block>();
+
+ Queue<NoteInfo> jSends = new LinkedList<NoteInfo>();
+ ArrayList<NoteField> jLane = new ArrayList<NoteField>();
+ ArrayList<Block> jVis = new ArrayList<Block>();
+
+ Queue<NoteInfo> kSends = new LinkedList<NoteInfo>();
+ ArrayList<NoteField> kLane = new ArrayList<NoteField>();
+ ArrayList<Block> kVis = new ArrayList<Block>();
+
+ Score score = new Score();
+
+ /**
+ * Establishes what the chart for the song is going to look like
+ */
+ public void loadSong() {
+ dSends.add(new NoteInfo(4000));
+ dSends.add(new NoteInfo(4333));
+ dSends.add(new NoteInfo(4666));
+ fSends.add(new NoteInfo(5000));
+ kSends.add(new NoteInfo(5500));
+ spaceSends.add(new NoteInfo(6000));
+ jSends.add(new NoteInfo(6000));
+ jSends.add(new NoteInfo(6250));
+ dSends.add(new NoteInfo(6500));
+ jSends.add(new NoteInfo(6750));
+ spaceSends.add(new NoteInfo(7000));
+ fSends.add(new NoteInfo(7500));
+ jSends.add(new NoteInfo(7750));
+ spaceSends.add(new NoteInfo(8000));
+ fSends.add(new NoteInfo(8500));
+ jSends.add(new NoteInfo(8500));
+ dSends.add(new NoteInfo(9000));
+ spaceSends.add(new NoteInfo(9000));
+ kSends.add(new NoteInfo(9000));
+ spaceSends.add(new NoteInfo(9500));
+
+ kSends.add(new NoteInfo(10000));
+ dSends.add(new NoteInfo(10000));
+ kSends.add(new NoteInfo(10333));
+ fSends.add(new NoteInfo(10333));
+ kSends.add(new NoteInfo(10666));
+ spaceSends.add(new NoteInfo(10666));
+ dSends.add(new NoteInfo(11000));
+ spaceSends.add(new NoteInfo(11000));
+ dSends.add(new NoteInfo(11333));
+ jSends.add(new NoteInfo(11333));
+ dSends.add(new NoteInfo(11666));
+ kSends.add(new NoteInfo(11666));
+ spaceSends.add(new NoteInfo(12000));
+ }
+
+
+ /**
+ * Creates the GUI used to play the game
+ */
+ public SongPlayer2() {
+
+ // d.setBounds(1*BLENGTH, (5*HEIGHT)/6, BLENGTH, BHEIGHT); //makes the button bounds for each button
+ // f.setBounds(2*BLENGTH, (5*HEIGHT)/6, BLENGTH, BHEIGHT);
+ // space.setBounds(3*BLENGTH, (5*HEIGHT)/6, BLENGTH, BHEIGHT);
+ // j.setBounds(4*BLENGTH, (5*HEIGHT)/6, BLENGTH, BHEIGHT);
+ // k.setBounds(5*BLENGTH, (5*HEIGHT)/6, BLENGTH, BHEIGHT);
+ // d.setFocusable(false); //makes it so you can't focus on the button
+ // f.setFocusable(false);
+ // space.setFocusable(false);
+ // j.setFocusable(false);
+ // k.setFocusable(false);
+
+
+ HBox bottom = new HBox();
+ bottom.getChildren().add(d); //adds the buttons to the frame
+ bottom.getChildren().add(f);
+ bottom.getChildren().add(space);
+ bottom.getChildren().add(j);
+ bottom.getChildren().add(k);
+ super.getChildren().add(bottom);
+ //frame.setSize(LENGTH, HEIGHT); //sets the size of the frame
+ //frame.setLayout(null);
+ //frame.setVisible(true); //makes the frame visible
+
+
+ //while (true) { //TRY TO FIND A BETTER SOLUTION FOR THIS?? maybe something like sends.size() > 0 || lanes.size() > 0
+
+ // update(d, dSends, dLane, dVis, 'd', "dPress", 1); //updates the provided lane
+ // update(f, fSends, fLane, fVis, 'f', "fPress", 2);
+ // update(space, spaceSends, spaceLane, spaceVis, ' ', "spacePress", 3);
+ // update(j, jSends, jLane, jVis, 'j', "jPress", 4);
+ // update(k, kSends, kLane, kVis, 'k', "kPress", 5);
+
+ // frame.repaint(); //updates the visuals every frame
+
+ // try {
+ // Thread.sleep(10); //THIS IS PROBABLY NOT THE BEST WAY TO DO THIS
+ // } catch (InterruptedException e)
+ // {
+ // e.printStackTrace();
+ // }
+ //}
+ }
+
+ /**
+ * Updates a lane. An update involves:
+ * Checking to see if a note needs to be sent down a lane
+ * Checking to see if the user hit the button
+ * Checking to see if any notes have moved past the lane
+ * @param sends The sending queue for the given lane
+ * @param lane The place where note information is stored for notes currently in that lane
+ * @param vis The place where the visual representation for a note is stored in that lane
+ * @param key The button on the keyboard corresponding to the button for the lane being updated
+ * @param id The id for the action map
+ * @param k The lane number
+ */
+ /*
+ private void update(JButton button, Queue<NoteInfo> sends, ArrayList<NoteField> lane, ArrayList<JButton> vis, char key, String id, int k) {
+ if (!sends.isEmpty() && sends.peek().getTime()-time.time()<3) { //checks if any notes in the queue need to be sent at this time
+ lane.add(new NoteField()); //adds that note's information to the lane list
+
+ vis.add(new JButton()); //creates a visual representation of that note in the visualizer list
+ frame.add(vis.get(vis.size()-1));
+
+ sends.remove(); //removes the note just sent from the sending queue
+ }
+
+ if (lane.size() > 0) { //if there are any notes in the lanes, tests for a button press
+ button.getInputMap(JComponent.WHEN_IN_FOCUSED_WINDOW).put(KeyStroke.getKeyStroke(key), id); //Input map and Action map setting
+ button.getActionMap().put(id, new AbstractAction() { //Defines what happens when the proper button is pressed
+ public void actionPerformed(ActionEvent e)
+ {
+ if (lane.size() > 0) {
+ int i = getClosestNote(lane);
+ int dist = (int)Math.abs(lane.get(i).goalDistance());
+
+ lane.remove(i); //removes the notes and visual representation from the playing field when the button is pressed
+ frame.remove(vis.get(i));
+ vis.remove(i);
+
+ if (dist > 2*BHEIGHT) { //Determines what to add to the score depending on the proximity of the note
+ score.miss();
+ }
+ else if (dist > BHEIGHT) {
+ score.combo();
+ score.close();
+ }
+ else {
+ score.combo();
+ score.perfect();
+ }
+
+ System.out.println("Score: " + score.getScore() + " Combo: " + score.getCombo());
+ }
+ }
+ });
+ }
+
+ for (int i=0; i<lane.size(); i++) { //goes through every note on the field
+ lane.get(i).gameTick(); //moves every note down
+ vis.get(i).setBounds(k*BLENGTH, HEIGHT-lane.get(i).getY(), BLENGTH, BHEIGHT);
+
+ if (lane.size() > 0 && lane.get(i).getFailed()) { //if the note has passed into the fail boundary, removes the note from the field
+ score.miss();
+ System.out.println(score.getScore() + " Combo: " + score.getCombo());
+
+
+ lane.remove(i);
+ frame.remove(vis.get(i));
+ vis.remove(i);
+
+ i--;
+ }
+ }
+ }
+
+ /**
+ * Finds the note closest to the goal
+ * @return the location in the array list of the closest note
+
+ private int getClosestNote(ArrayList<NoteField> searchLane) {
+ int pos = 0;
+
+ for (int i=0; i<searchLane.size(); i++) {
+ if (Math.abs(searchLane.get(i).goalDistance()) < Math.abs(searchLane.get(pos).goalDistance())) {
+ pos = i;
+ }
+ }
+
+ return pos;
+ }
+ */
+}