From 9568ea5118b9100b3375a6bd2153042506b0d5d1 Mon Sep 17 00:00:00 2001 From: sowgro Date: Sun, 14 May 2023 01:46:56 -0400 Subject: Finish css and menus --- src/gui/LevelSelector.java | 62 ++++++++++++++++++++++++++++++++++++++++++---- 1 file changed, 57 insertions(+), 5 deletions(-) (limited to 'src/gui/LevelSelector.java') diff --git a/src/gui/LevelSelector.java b/src/gui/LevelSelector.java index a84444b..e0ad663 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,60 @@ public class LevelSelector extends Pane ListView levels = new ListView(); ObservableList 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); + + Text title = new Text(); + title.setText("Test level 1"); + title.setFill(Color.WHITE); + title.setFont(new Font(50)); + title.wrappingWidthProperty().bind(super.widthProperty().multiply(0.37)); + + 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().multiply(0.37)); + + ImageView previewView = new ImageView(); + Image preview = new Image("assets/pico.png"); + previewView.setImage(preview); + //previewView.setFitHeight(100); + previewView.fitWidthProperty().bind(super.widthProperty().multiply(0.25)); + previewView.setPreserveRatio(true); + + VBox details = new VBox(); + details.minWidthProperty().bind(super.widthProperty().multiply(0.37)); + details.minHeightProperty().bind(super.heightProperty().multiply(0.75)); + details.maxWidthProperty().bind(super.widthProperty().multiply(0.37)); + details.maxHeightProperty().bind(super.heightProperty().multiply(0.75)); + details.getStyleClass().add("textBox"); + details.getChildren().addAll(title,desc,previewView); + + Button play = new Button(); + play.setText("Play"); + + VBox rightBox = new VBox(); + rightBox.setAlignment(Pos.CENTER_RIGHT); + rightBox.setSpacing(10); + rightBox.getChildren().addAll(details,play); + + 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); - super.getChildren().addAll(levels,exit); + super.getChildren().add(rootBox); } } -- cgit v1.2.3 From 4a1f4a98116b5c59efe0606375b833a722a0d281 Mon Sep 17 00:00:00 2001 From: sowgro Date: Sun, 14 May 2023 17:34:40 -0400 Subject: add levelselector gui, move some files around --- src/gui/LevelSelector.java | 49 ++++++++++++++++------------------------------ 1 file changed, 17 insertions(+), 32 deletions(-) (limited to 'src/gui/LevelSelector.java') diff --git a/src/gui/LevelSelector.java b/src/gui/LevelSelector.java index e0ad663..5600b07 100644 --- a/src/gui/LevelSelector.java +++ b/src/gui/LevelSelector.java @@ -33,39 +33,9 @@ public class LevelSelector extends Pane leftBox.setSpacing(10); leftBox.getChildren().addAll(levels,exit); - Text title = new Text(); - title.setText("Test level 1"); - title.setFill(Color.WHITE); - title.setFont(new Font(50)); - title.wrappingWidthProperty().bind(super.widthProperty().multiply(0.37)); + Pane rightBox = new Pane(); + addDetails(rightBox, levels); - 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().multiply(0.37)); - - ImageView previewView = new ImageView(); - Image preview = new Image("assets/pico.png"); - previewView.setImage(preview); - //previewView.setFitHeight(100); - previewView.fitWidthProperty().bind(super.widthProperty().multiply(0.25)); - previewView.setPreserveRatio(true); - - VBox details = new VBox(); - details.minWidthProperty().bind(super.widthProperty().multiply(0.37)); - details.minHeightProperty().bind(super.heightProperty().multiply(0.75)); - details.maxWidthProperty().bind(super.widthProperty().multiply(0.37)); - details.maxHeightProperty().bind(super.heightProperty().multiply(0.75)); - details.getStyleClass().add("textBox"); - details.getChildren().addAll(title,desc,previewView); - - Button play = new Button(); - play.setText("Play"); - - VBox rightBox = new VBox(); - rightBox.setAlignment(Pos.CENTER_RIGHT); - rightBox.setSpacing(10); - rightBox.getChildren().addAll(details,play); HBox rootBox = new HBox(); rootBox.minWidthProperty().bind(super.widthProperty()); @@ -74,7 +44,22 @@ public class LevelSelector extends Pane rootBox.setAlignment(Pos.CENTER); rootBox.setSpacing(10); + levels.setOnMouseClicked(e -> addDetails(rightBox, levels)); super.getChildren().add(rootBox); } + private void addDetails(Pane rightBox, ListView 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()); + } + } -- cgit v1.2.3