aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAidan Ross <aross02@fairport.org>2023-05-16 19:45:01 -0400
committerAidan Ross <aross02@fairport.org>2023-05-16 19:45:01 -0400
commitd2f14ec456a3a3a5b5725af74929c2b58f07bb91 (patch)
treefe4b43898fbe6a9411ab119ff6405ce032c0bbc4 /src
parentd7392b8ba11517117c25f6fc139da84873cb7cac (diff)
parentf6685e0c93ed1f9ea5aab85f17d64ce93ffae6a9 (diff)
downloadNPEhero-d2f14ec456a3a3a5b5725af74929c2b58f07bb91.tar.gz
NPEhero-d2f14ec456a3a3a5b5725af74929c2b58f07bb91.tar.bz2
NPEhero-d2f14ec456a3a3a5b5725af74929c2b58f07bb91.zip
Merge branch 'main' of https://gitlab.sowgro.net/guitarheros/guitarhero into main
Diffstat (limited to 'src')
-rw-r--r--src/assets/BookBetrayal.mp3bin0 -> 5624404 bytes
-rw-r--r--src/assets/levels/test level/background.pngbin0 -> 1009759 bytes
-rw-r--r--src/assets/levels/test level/metadata.json0
-rw-r--r--src/assets/levels/test level/notes_easy.txt0
-rw-r--r--src/assets/levels/test level/notes_hard.txt0
-rw-r--r--src/assets/levels/test level/notes_medium.txt0
-rw-r--r--src/assets/levels/test level/preview.pngbin0 -> 9072089 bytes
-rw-r--r--src/assets/pico.pngbin0 -> 9072089 bytes
-rw-r--r--src/fallTest/Hbox.java5
-rw-r--r--src/gui/Driver.java34
-rw-r--r--src/gui/JsonReader.java5
-rw-r--r--src/gui/JsonStructure.java5
-rw-r--r--src/gui/JsonValue.java9
-rw-r--r--src/gui/JsonWriter.java5
-rw-r--r--src/gui/Leaderboard.java26
-rw-r--r--src/gui/Level.java6
-rw-r--r--src/gui/LevelDetails.java74
-rw-r--r--src/gui/LevelSelector.java47
-rw-r--r--src/gui/LevelSurround.java74
-rw-r--r--src/gui/MainMenu.java20
-rw-r--r--src/gui/Settings.java29
-rw-r--r--src/gui/SettingsController.java5
-rw-r--r--src/gui/SongPlayer2.java232
-rw-r--r--src/gui/style.css78
-rw-r--r--src/main/Level.java25
-rw-r--r--src/main/LevelController.java1
-rw-r--r--src/main/SettingsController.java7
-rw-r--r--src/test/JFXaudioPlayer.java (renamed from src/main/JFXaudioPlayer.java)19
-rw-r--r--src/test/KeyDetection.java (renamed from src/main/KeyDetection.java)2
-rw-r--r--src/test/NoteTest.java (renamed from src/main/NoteTest.java)2
-rw-r--r--src/test/SongPlayer.java (renamed from src/main/SongPlayer.java)2
-rw-r--r--src/test/focusTest.java46
32 files changed, 690 insertions, 68 deletions
diff --git a/src/assets/BookBetrayal.mp3 b/src/assets/BookBetrayal.mp3
new file mode 100644
index 0000000..cf274a6
--- /dev/null
+++ b/src/assets/BookBetrayal.mp3
Binary files differ
diff --git a/src/assets/levels/test level/background.png b/src/assets/levels/test level/background.png
new file mode 100644
index 0000000..0113819
--- /dev/null
+++ b/src/assets/levels/test level/background.png
Binary files differ
diff --git a/src/assets/levels/test level/metadata.json b/src/assets/levels/test level/metadata.json
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/src/assets/levels/test level/metadata.json
diff --git a/src/assets/levels/test level/notes_easy.txt b/src/assets/levels/test level/notes_easy.txt
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/src/assets/levels/test level/notes_easy.txt
diff --git a/src/assets/levels/test level/notes_hard.txt b/src/assets/levels/test level/notes_hard.txt
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/src/assets/levels/test level/notes_hard.txt
diff --git a/src/assets/levels/test level/notes_medium.txt b/src/assets/levels/test level/notes_medium.txt
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/src/assets/levels/test level/notes_medium.txt
diff --git a/src/assets/levels/test level/preview.png b/src/assets/levels/test level/preview.png
new file mode 100644
index 0000000..002ad9e
--- /dev/null
+++ b/src/assets/levels/test level/preview.png
Binary files differ
diff --git a/src/assets/pico.png b/src/assets/pico.png
new file mode 100644
index 0000000..002ad9e
--- /dev/null
+++ b/src/assets/pico.png
Binary files differ
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/gui/Driver.java b/src/gui/Driver.java
index f9449cd..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());
@@ -38,25 +40,39 @@ public class Driver extends Application
value.minHeightProperty().bind(primaryStage.heightProperty());
}
- primaryPane.getChildren().add(menus.get("MainMenu"));
- primaryPane.minWidthProperty().bind(primaryStage.widthProperty());
- primaryPane.minHeightProperty().bind(primaryStage.heightProperty());
- setBackground("assets/water.png");
-
Scene primaryScene = new Scene(primaryPane, 800, 600);
primaryScene.getStylesheets().add("gui/style.css");
primaryStage.setScene(primaryScene);
primaryStage.setTitle("NPE Hero");
+
+ setMenu("MainMenu");
+ setBackground("assets/water.png");
+
primaryStage.show();
- primaryStage.setFullScreen(true);
}
- public static void switchMenu(String name)
+ public static void setMenu(String name)
{
- primaryPane.getChildren().remove(0);
+ if (! primaryPane.getChildren().isEmpty())
+ {
+ primaryPane.getChildren().remove(0);
+ }
primaryPane.getChildren().add(menus.get(name));
+ 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)
diff --git a/src/gui/JsonReader.java b/src/gui/JsonReader.java
new file mode 100644
index 0000000..b1da06f
--- /dev/null
+++ b/src/gui/JsonReader.java
@@ -0,0 +1,5 @@
+package gui;
+
+public interface JsonReader {
+
+}
diff --git a/src/gui/JsonStructure.java b/src/gui/JsonStructure.java
new file mode 100644
index 0000000..1ea2fa1
--- /dev/null
+++ b/src/gui/JsonStructure.java
@@ -0,0 +1,5 @@
+package gui;
+
+public interface JsonStructure {
+
+}
diff --git a/src/gui/JsonValue.java b/src/gui/JsonValue.java
new file mode 100644
index 0000000..e91f45b
--- /dev/null
+++ b/src/gui/JsonValue.java
@@ -0,0 +1,9 @@
+package gui;
+
+public interface JsonValue
+{
+ static JsonValue.ValueType getValueType()
+ {
+ return null;
+ }
+}
diff --git a/src/gui/JsonWriter.java b/src/gui/JsonWriter.java
new file mode 100644
index 0000000..04fae8e
--- /dev/null
+++ b/src/gui/JsonWriter.java
@@ -0,0 +1,5 @@
+package gui;
+
+public interface JsonWriter {
+
+}
diff --git a/src/gui/Leaderboard.java b/src/gui/Leaderboard.java
index 598b6aa..9580a5f 100644
--- a/src/gui/Leaderboard.java
+++ b/src/gui/Leaderboard.java
@@ -1,12 +1,12 @@
package gui;
+
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
-import javafx.event.ActionEvent;
-import javafx.event.EventHandler;
import javafx.geometry.Pos;
import javafx.scene.control.Button;
import javafx.scene.control.ListView;
+import javafx.scene.layout.HBox;
import javafx.scene.layout.Pane;
import javafx.scene.layout.VBox;
@@ -17,16 +17,24 @@ public class Leaderboard extends Pane
ListView<String> scores = new ListView<String>();
ObservableList<String> scoreList= FXCollections.observableArrayList ("Test Score 1", "Test Score 2", "Test Score 3", "Test Score 4");
scores.setItems(scoreList);
+ scores.minWidthProperty().bind(super.widthProperty().multiply(0.25));
+ scores.minHeightProperty().bind(super.heightProperty().multiply(0.75));
Button exit = new Button();
exit.setText("Exit");
- exit.setOnAction(e -> Driver.switchMenu("MainMenu"));
+ exit.setOnAction(e -> Driver.setMenu("MainMenu"));
+
+ VBox centerBox = new VBox();
+ centerBox.setAlignment(Pos.CENTER);
+ centerBox.setSpacing(10);
+ centerBox.getChildren().addAll(scores,exit);
+
+ HBox rootBox = new HBox();
+ rootBox.minWidthProperty().bind(super.widthProperty());
+ rootBox.minHeightProperty().bind(super.heightProperty());
+ rootBox.getChildren().add(centerBox);
+ rootBox.setAlignment(Pos.CENTER);
- VBox centerMenu3 = new VBox();
- centerMenu3.minWidthProperty().bind(super.widthProperty());
- centerMenu3.minHeightProperty().bind(super.heightProperty());
- centerMenu3.setAlignment(Pos.CENTER);
- centerMenu3.getChildren().addAll(scores,exit);
- super.getChildren().add(centerMenu3);
+ super.getChildren().add(rootBox);
}
}
diff --git a/src/gui/Level.java b/src/gui/Level.java
index 8f98903..ecb741d 100644
--- a/src/gui/Level.java
+++ b/src/gui/Level.java
@@ -8,19 +8,13 @@ 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
diff --git a/src/gui/LevelDetails.java b/src/gui/LevelDetails.java
new file mode 100644
index 0000000..5623261
--- /dev/null
+++ b/src/gui/LevelDetails.java
@@ -0,0 +1,74 @@
+package gui;
+
+import javafx.geometry.Insets;
+import javafx.geometry.Pos;
+import javafx.scene.control.Button;
+import javafx.scene.control.ListView;
+import javafx.scene.image.Image;
+import javafx.scene.image.ImageView;
+import javafx.scene.layout.Pane;
+import javafx.scene.layout.VBox;
+import javafx.scene.paint.Color;
+import javafx.scene.text.Font;
+import javafx.scene.text.Text;
+import javafx.scene.text.TextAlignment;
+
+public class LevelDetails extends VBox
+{
+ public LevelDetails(ListView<String> list)
+ {
+ VBox details = new VBox();
+ details.minWidthProperty().bind(super.widthProperty());
+ details.minHeightProperty().bind(super.heightProperty().multiply(0.75));
+ 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");
+
+ if (list.getSelectionModel().getSelectedItem() == null)
+ {
+ Text desc = new Text();
+ desc.setText("Select a level from the left pane");
+ desc.setFill(Color.WHITE);
+ desc.wrappingWidthProperty().bind(super.widthProperty().subtract(10));
+ desc.setTextAlignment(TextAlignment.CENTER);
+ details.setAlignment(Pos.CENTER);
+ details.getChildren().addAll(desc);
+ play.setDisable(true);
+ }
+
+ else
+ {
+ Text title = new Text();
+ title.setText("Test level 1");
+ title.setFill(Color.WHITE);
+ title.setFont(new Font(50));
+ 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().subtract(10));
+
+ ImageView previewView = new ImageView();
+ Image preview = new Image("assets/pico.png");
+ previewView.setImage(preview);
+ //previewView.setFitHeight(100);
+ 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();
+ rightBox.setAlignment(Pos.CENTER_RIGHT);
+ rightBox.setSpacing(10);
+ rightBox.getChildren().addAll(details,play);
+
+ super.setAlignment(Pos.CENTER_RIGHT);
+ super.getChildren().add(rightBox);
+ }
+}
diff --git a/src/gui/LevelSelector.java b/src/gui/LevelSelector.java
index a84444b..5600b07 100644
--- a/src/gui/LevelSelector.java
+++ b/src/gui/LevelSelector.java
@@ -3,12 +3,16 @@ package gui;
import javafx.collections.FXCollections;
import javafx.collections.ObservableList;
import javafx.geometry.Pos;
-import javafx.scene.Scene;
import javafx.scene.control.Button;
import javafx.scene.control.ListView;
+import javafx.scene.image.Image;
+import javafx.scene.image.ImageView;
+import javafx.scene.layout.HBox;
import javafx.scene.layout.Pane;
import javafx.scene.layout.VBox;
-import javafx.stage.Stage;
+import javafx.scene.paint.Color;
+import javafx.scene.text.Font;
+import javafx.scene.text.Text;
public class LevelSelector extends Pane
{
@@ -17,12 +21,45 @@ public class LevelSelector extends Pane
ListView<String> levels = new ListView<String>();
ObservableList<String> levelList= FXCollections.observableArrayList ("Test Level 1", "Test Level 2", "Test Level 3", "Test Level 4");
levels.setItems(levelList);
- //super.setAlignment(Pos.CENTER);
+ levels.minWidthProperty().bind(super.widthProperty().multiply(0.25));
+ levels.minHeightProperty().bind(super.heightProperty().multiply(0.75));
+
Button exit = new Button();
exit.setText("Exit");
- exit.setOnAction(e -> Driver.switchMenu("MainMenu"));
+ exit.setOnAction(e -> Driver.setMenu("MainMenu"));
+
+ VBox leftBox = new VBox();
+ leftBox.setAlignment(Pos.CENTER_LEFT);
+ leftBox.setSpacing(10);
+ leftBox.getChildren().addAll(levels,exit);
+
+ Pane rightBox = new Pane();
+ addDetails(rightBox, levels);
+
- super.getChildren().addAll(levels,exit);
+ HBox rootBox = new HBox();
+ rootBox.minWidthProperty().bind(super.widthProperty());
+ rootBox.minHeightProperty().bind(super.heightProperty());
+ rootBox.getChildren().addAll(leftBox, rightBox);
+ rootBox.setAlignment(Pos.CENTER);
+ rootBox.setSpacing(10);
+
+ levels.setOnMouseClicked(e -> addDetails(rightBox, levels));
+ super.getChildren().add(rootBox);
+ }
+
+ private void addDetails(Pane rightBox, ListView<String> levels)
+ {
+ VBox details = new LevelDetails(levels);
+ if (! rightBox.getChildren().isEmpty())
+ {
+ rightBox.getChildren().remove(0);
+ }
+ rightBox.getChildren().add(details);
+ details.minWidthProperty().bind(super.widthProperty().multiply(0.37));
+ details.minHeightProperty().bind(super.heightProperty());
+ details.maxWidthProperty().bind(super.widthProperty().multiply(0.37));
+ details.maxHeightProperty().bind(super.heightProperty());
}
}
diff --git a/src/gui/LevelSurround.java b/src/gui/LevelSurround.java
new file mode 100644
index 0000000..22fcf97
--- /dev/null
+++ b/src/gui/LevelSurround.java
@@ -0,0 +1,74 @@
+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 textBox = new VBox();
+ textBox.setAlignment(Pos.TOP_RIGHT);
+ textBox.getChildren().addAll(title,diff);
+
+ BorderPane topBar = new BorderPane();
+ topBar.setLeft(buttonBox);
+ topBar.setRight(textBox);
+ topBar.setPadding(new Insets(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 textBox = new VBox();
+ textBox.setAlignment(Pos.TOP_RIGHT);
+ textBox.getChildren().addAll(title,diff);
+
+ HBox centerBox = new HBox();
+ centerBox.getStyleClass().add("textBox");
+
+ StackPane root = new StackPane();
+ root.getChildren().addAll(topBar,centerBox);
+
+ 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/MainMenu.java b/src/gui/MainMenu.java
index 3ad91ad..d04408d 100644
--- a/src/gui/MainMenu.java
+++ b/src/gui/MainMenu.java
@@ -1,16 +1,9 @@
package gui;
-import javafx.event.EventHandler;
-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.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.Pane;
import javafx.scene.layout.VBox;
import javafx.scene.paint.Color;
@@ -21,7 +14,6 @@ public class MainMenu extends Pane
{
public MainMenu()
{
-
DropShadow dropShadow = new DropShadow();
dropShadow.setRadius(50.0);
dropShadow.setColor(Color.WHITE);
@@ -35,36 +27,32 @@ public class MainMenu extends Pane
Button play = new Button();
play.setText("Play");
- play.setOnAction(e -> Driver.switchMenu("LevelSelector"));
+ play.setOnAction(e -> Driver.setMenu("LevelSelector"));
Button settings = new Button();
settings.setText("Settings");
- settings.setOnAction(e -> Driver.switchMenu("Settings"));
+ settings.setOnAction(e -> Driver.setMenu("Settings"));
Button leaderboard = new Button();
leaderboard.setText("Leaderboard");
- leaderboard.setOnAction(e -> Driver.switchMenu("Leaderboard"));
-
- //Border border = new Border(new BorderStroke(Color.WHITE, BorderStrokeStyle.SOLID, CornerRadii.EMPTY, BorderWidths.DEFAULT));
+ leaderboard.setOnAction(e -> Driver.setMenu("Leaderboard"));
VBox buttonBox = new VBox();
buttonBox.getChildren().addAll(play, settings, leaderboard);
buttonBox.setAlignment(Pos.CENTER);
buttonBox.setSpacing(10);
- //buttonBox.setBorder(border);
VBox centerBox = new VBox();
centerBox.setAlignment(Pos.CENTER);
centerBox.getChildren().addAll(title, buttonBox);
centerBox.setSpacing(10);
- //centerBox.setBorder(border);
VBox rootBox = new VBox();
rootBox.minWidthProperty().bind(super.widthProperty());
rootBox.minHeightProperty().bind(super.heightProperty());
rootBox.setAlignment(Pos.CENTER);
rootBox.getChildren().add(centerBox);
- //rootBox.setBorder(border);
+
super.getChildren().add(rootBox);
}
diff --git a/src/gui/Settings.java b/src/gui/Settings.java
index 94c2a89..946be85 100644
--- a/src/gui/Settings.java
+++ b/src/gui/Settings.java
@@ -1,12 +1,12 @@
package gui;
-import javafx.event.ActionEvent;
-import javafx.event.EventHandler;
import javafx.geometry.Pos;
import javafx.scene.control.Button;
import javafx.scene.control.Slider;
+import javafx.scene.layout.HBox;
import javafx.scene.layout.Pane;
import javafx.scene.layout.VBox;
+import javafx.scene.paint.Color;
import javafx.scene.text.Text;
public class Settings extends Pane
@@ -15,6 +15,7 @@ public class Settings extends Pane
{
Text t1 = new Text();
t1.setText("Music Volume");
+ t1.setFill(Color.WHITE);
Slider musicVol = new Slider();
musicVol.setMax(100);
@@ -22,6 +23,7 @@ public class Settings extends Pane
Text t2 = new Text();
t2.setText("Sound Effects Volume");
+ t2.setFill(Color.WHITE);
Slider sfxVol = new Slider();
sfxVol.setMax(100);
@@ -29,25 +31,26 @@ public class Settings extends Pane
Button devMenu = new Button();
devMenu.setText("Debug Menu");
- devMenu.setOnAction(new EventHandler<ActionEvent>()
- {
- @Override
- public void handle(ActionEvent event)
- {
- Driver.setBackground("assets/trees.png");
- }
- });
+ devMenu.setOnAction(e -> Driver.setBackground("assets/trees.png"));
Button exit = new Button();
exit.setText("Exit");
- exit.setOnAction(e -> Driver.switchMenu("MainMenu"));
+ exit.setOnAction(e -> Driver.setMenu("MainMenu"));
VBox options = new VBox();
+ options.setSpacing(10);
options.setAlignment(Pos.CENTER);
options.getChildren().addAll(t1,musicVol,t2,sfxVol,devMenu,exit);
- options.minWidthProperty().bind(super.widthProperty());
+ options.minWidthProperty().bind(super.widthProperty().multiply(0.25));
options.minHeightProperty().bind(super.heightProperty());
- super.getChildren().add(options);
+ //options.getStyleClass().add("textBox");
+
+ HBox rootBox = new HBox();
+ rootBox.minWidthProperty().bind(super.widthProperty());
+ rootBox.minHeightProperty().bind(super.heightProperty());
+ rootBox.getChildren().add(options);
+ rootBox.setAlignment(Pos.CENTER);
+ super.getChildren().add(rootBox);
}
}
diff --git a/src/gui/SettingsController.java b/src/gui/SettingsController.java
new file mode 100644
index 0000000..8898dc3
--- /dev/null
+++ b/src/gui/SettingsController.java
@@ -0,0 +1,5 @@
+package gui;
+
+public class SettingsController {
+
+}
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;
+ }
+ */
+}
diff --git a/src/gui/style.css b/src/gui/style.css
index 3e18f9d..16db327 100644
--- a/src/gui/style.css
+++ b/src/gui/style.css
@@ -1,14 +1,20 @@
+/* button */
+
Button {
-fx-background-color: rgba(0, 0, 0, 0.5);
-fx-text-fill: white;
-fx-padding: .5em;
-fx-font-size: 25;
- -fx-background-radius: 10;
+ -fx-background-radius: 5;
}
Button:hover {
- -fx-background-color: rgb(255, 255, 255);
- -fx-text-fill: rgb(0, 0, 0);
+ -fx-background-color: rgb(50, 50, 50, 0.5);
+}
+
+Button:focused {
+ -fx-background-color: rgb(255, 255, 255);
+ -fx-text-fill: rgb(0, 0, 0);
}
Button:pressed {
@@ -16,6 +22,70 @@ Button:pressed {
-fx-text-fill: rgb(0, 0, 0);
}
-.pad {
+/* list */
+
+ListView {
+ -fx-background-color: rgba(0, 0, 0, 0.5);
+ -fx-background-radius: 5;
+}
+
+.list-cell {
+ -fx-padding: .5em;
+ -fx-background-color: transparent;
+ -fx-text-fill: rgb(255, 255, 255);
+}
+
+.list-cell:hover {
+ -fx-background-color: rgba(100, 100, 100, 0.5);
+
+}
+
+.list-cell:selected {
+ -fx-background-color: rgb(255, 255, 255);
+ -fx-text-fill: rgb(0, 0, 0);
+}
+
+/* slider */
+
+Slider {
-fx-padding: 1em;
+}
+
+.track {
+
+ -fx-padding: 3;
+ -fx-background-color: rgba(0, 0, 0, 0.5);
+ -fx-background-radius: 5;
+}
+
+.thumb {
+ -fx-pref-height: 30;
+ -fx-prefer-width: 30;
+ -fx-background-color: rgba(0, 0, 0, 0.5);
+ -fx-size: 25;
+ -fx-border-radius: 5;
+ -fx-border-color: rgb(231, 231, 231);
+ -fx-border-width: 3;
+}
+
+.thumb:hover {
+ -fx-background-color: rgb(50, 50, 50, 0.5);
+}
+
+Slider:focused .thumb{
+ -fx-background-color: rgb(255,255,255);
+ -fx-border-color: white;
+}
+
+.thumb:pressed {
+ -fx-background-color: rgb(231, 231, 231);
+ -fx-border-color: rgb(231, 231, 231);
+}
+
+/* text box */
+
+.textBox {
+ -fx-background-radius: 5;
+ -fx-background-color: rgba(0, 0, 0, 0.5);
+ -fx-text-fill: white;
} \ No newline at end of file
diff --git a/src/main/Level.java b/src/main/Level.java
new file mode 100644
index 0000000..52047fd
--- /dev/null
+++ b/src/main/Level.java
@@ -0,0 +1,25 @@
+package main;
+
+import java.io.File;
+import java.util.ArrayList;
+
+import javafx.scene.image.Image;
+import javafx.scene.paint.Color;
+
+public class Level
+{
+ private Color[] colors;
+ private Image background;
+ private Image preview;
+ private String text;
+ private String desc;
+ //private ArrayList<String>();
+
+ //google "varargs" to see how this works
+ public void setColors(Color... newColors)
+ {
+ colors = newColors;
+ }
+
+ //INCOMPLETE
+}
diff --git a/src/main/LevelController.java b/src/main/LevelController.java
new file mode 100644
index 0000000..daf7ae3
--- /dev/null
+++ b/src/main/LevelController.java
@@ -0,0 +1 @@
+//coming soon \ No newline at end of file
diff --git a/src/main/SettingsController.java b/src/main/SettingsController.java
new file mode 100644
index 0000000..79fb560
--- /dev/null
+++ b/src/main/SettingsController.java
@@ -0,0 +1,7 @@
+// coming soon
+// needs to have getters and setters for:
+// - sfx vol
+// - music vol
+// - full screen
+//
+// perhaps use public variables instead of getters and setters \ No newline at end of file
diff --git a/src/main/JFXaudioPlayer.java b/src/test/JFXaudioPlayer.java
index 0a2162d..2f12e20 100644
--- a/src/main/JFXaudioPlayer.java
+++ b/src/test/JFXaudioPlayer.java
@@ -1,16 +1,29 @@
-package main;
+package test;
import java.io.File;
+import java.io.IOException;
+
+import javafx.application.Application;
+import javafx.fxml.FXMLLoader;
+import javafx.scene.Parent;
import javafx.scene.media.Media;
import javafx.scene.media.MediaPlayer;
+import javafx.stage.Stage;
-public class JFXaudioPlayer {
+public class JFXaudioPlayer extends Application{
+
public static void main(String[] args)
{
+ launch(args);
+ }
+
+ @Override
+ public void start(Stage primaryStage)
+ {
+ // primaryStage.show();
String musicFile = "EXAMPLE.mp3"; // For example
Media sound = new Media(new File(musicFile).toURI().toString());
MediaPlayer mediaPlayer = new MediaPlayer(sound);
mediaPlayer.play();
- mediaPlayer.stop();
}
} \ No newline at end of file
diff --git a/src/main/KeyDetection.java b/src/test/KeyDetection.java
index 7887405..447b101 100644
--- a/src/main/KeyDetection.java
+++ b/src/test/KeyDetection.java
@@ -4,7 +4,7 @@
*Teacher:
*Description:
*/
-package main;
+package test;
import javax.swing.*;
import java.awt.event.ActionEvent;
diff --git a/src/main/NoteTest.java b/src/test/NoteTest.java
index 34d9c8c..ce74d56 100644
--- a/src/main/NoteTest.java
+++ b/src/test/NoteTest.java
@@ -4,7 +4,7 @@
*Teacher:
*Description:
*/
-package main;
+package test;
import java.awt.*;
public class NoteTest
diff --git a/src/main/SongPlayer.java b/src/test/SongPlayer.java
index caf1ab7..48f859d 100644
--- a/src/main/SongPlayer.java
+++ b/src/test/SongPlayer.java
@@ -4,7 +4,7 @@
*Teacher:
*Description:
*/
-package main;
+package test;
import java.awt.*;
import java.awt.event.*;
diff --git a/src/test/focusTest.java b/src/test/focusTest.java
new file mode 100644
index 0000000..bc337da
--- /dev/null
+++ b/src/test/focusTest.java
@@ -0,0 +1,46 @@
+package test;
+
+import javafx.application.Application;
+import javafx.geometry.Pos;
+import javafx.scene.Scene;
+import javafx.scene.control.ToggleButton;
+import javafx.scene.layout.HBox;
+import javafx.scene.layout.VBox;
+import javafx.stage.Stage;
+
+public class focusTest extends Application {
+
+ public static void main(String[] args)
+ {
+ launch(args);
+ }
+
+ @Override
+ public void start(Stage primaryStage) throws Exception
+ {
+ VBox root = new VBox();
+ root.setAlignment(Pos.CENTER);
+ root.setSpacing(20);
+ Scene sc = new Scene(root, 500, 500);
+ primaryStage.setScene(sc);
+ primaryStage.show();
+
+
+ ToggleButton btn1 = new ToggleButton("Button 1");
+ ToggleButton btn2 = new ToggleButton("Button 2");
+ ToggleButton btn3 = new ToggleButton("Button 3");
+ ToggleButton btn4 = new ToggleButton("Button 4");
+
+ HBox hb1 = new HBox();
+ hb1.setAlignment(Pos.CENTER);
+ hb1.getChildren().addAll(btn1, btn2);
+
+ HBox hb2 = new HBox();
+ hb2.setAlignment(Pos.CENTER);
+ hb2.getChildren().addAll(btn3, btn4);
+
+ root.getChildren().addAll(hb1, hb2);
+
+ hb1.requestFocus();
+ }
+}