From e20739885972d01bc4e9a7acc5d1d2cfde6fae27 Mon Sep 17 00:00:00 2001
From: Max Wittig <max.wittig95@gmail.com>
Date: Sat, 3 Dec 2016 18:01:22 +0100
Subject: [PATCH] refractoring controller

---
 .../game/levels/LevelPackWriter.java          |  5 ++
 src/de/brickedleveleditor/main/Main.java      |  6 +-
 src/de/brickedleveleditor/main/_de.properties |  4 +-
 .../ui/controller/AbstractController.java     | 20 ++++++
 .../controller/LevelPackDialogController.java | 42 +++++++++++
 .../MainController.java}                      | 69 ++++++++++++-------
 .../ui/fxml/level_pack_dialog_controller.fxml | 25 +++++++
 .../{GUI.fxml => fxml/main_controller.fxml}   |  6 +-
 8 files changed, 145 insertions(+), 32 deletions(-)
 create mode 100644 src/de/brickedleveleditor/ui/controller/AbstractController.java
 create mode 100644 src/de/brickedleveleditor/ui/controller/LevelPackDialogController.java
 rename src/de/brickedleveleditor/ui/{Controller.java => controller/MainController.java} (84%)
 create mode 100644 src/de/brickedleveleditor/ui/fxml/level_pack_dialog_controller.fxml
 rename src/de/brickedleveleditor/ui/{GUI.fxml => fxml/main_controller.fxml} (91%)

diff --git a/src/de/brickedleveleditor/game/levels/LevelPackWriter.java b/src/de/brickedleveleditor/game/levels/LevelPackWriter.java
index c242fcb..f07befe 100644
--- a/src/de/brickedleveleditor/game/levels/LevelPackWriter.java
+++ b/src/de/brickedleveleditor/game/levels/LevelPackWriter.java
@@ -49,4 +49,9 @@ public class LevelPackWriter
         Level level = new Level(levelname, author, position, difficulty, startLives, paddleSize, getBoard(bricks));
         levels.add(level);
     }
+
+    public ArrayList<Level> getLevels()
+    {
+        return levels;
+    }
 }
diff --git a/src/de/brickedleveleditor/main/Main.java b/src/de/brickedleveleditor/main/Main.java
index 9eb6bc5..265186d 100644
--- a/src/de/brickedleveleditor/main/Main.java
+++ b/src/de/brickedleveleditor/main/Main.java
@@ -4,7 +4,7 @@ import java.util.Arrays;
 import java.util.Locale;
 import java.util.ResourceBundle;
 
-import de.brickedleveleditor.ui.Controller;
+import de.brickedleveleditor.ui.controller.MainController;
 import javafx.application.Application;
 import javafx.event.EventHandler;
 import javafx.fxml.FXMLLoader;
@@ -25,12 +25,12 @@ public class Main extends Application
 	{
 		try
 		{
-			FXMLLoader loader = new FXMLLoader(getClass().getClassLoader().getResource("de/brickedleveleditor/ui/GUI.fxml"));
+			FXMLLoader loader = new FXMLLoader(getClass().getClassLoader().getResource("de/brickedleveleditor/ui/fxml/main_controller.fxml"));
 			Parent root = (Parent)loader.load();
 
 			Scene scene = new Scene(root, 800, 600);		
 
-			((Controller)loader.getController()).init(stage);
+			((MainController)loader.getController()).init(stage, null);
 
 			stage.setTitle(bundle.getString("app.name"));
 			stage.setScene(scene);
diff --git a/src/de/brickedleveleditor/main/_de.properties b/src/de/brickedleveleditor/main/_de.properties
index 5882f88..824b21f 100644
--- a/src/de/brickedleveleditor/main/_de.properties
+++ b/src/de/brickedleveleditor/main/_de.properties
@@ -2,4 +2,6 @@ app.name=Bricked LevelEditor
 version.code=0
 version.name=0.0.0
 version.date=19.10.16
-author=Max Wittig, Robert Goldmann
\ No newline at end of file
+author=Max Wittig, Robert Goldmann
+
+level.saver=Save Level
diff --git a/src/de/brickedleveleditor/ui/controller/AbstractController.java b/src/de/brickedleveleditor/ui/controller/AbstractController.java
new file mode 100644
index 0000000..2fa8ad7
--- /dev/null
+++ b/src/de/brickedleveleditor/ui/controller/AbstractController.java
@@ -0,0 +1,20 @@
+package de.brickedleveleditor.ui.controller;
+
+import javafx.stage.Stage;
+
+
+public abstract class AbstractController
+{
+    protected AbstractController parentController;
+    protected Stage stage;
+
+    public void init(Stage stage, AbstractController parentController)
+    {
+        this.parentController = parentController;
+        this.stage = stage;
+        initController();
+    }
+
+    protected abstract void initController();
+
+}
diff --git a/src/de/brickedleveleditor/ui/controller/LevelPackDialogController.java b/src/de/brickedleveleditor/ui/controller/LevelPackDialogController.java
new file mode 100644
index 0000000..6afc358
--- /dev/null
+++ b/src/de/brickedleveleditor/ui/controller/LevelPackDialogController.java
@@ -0,0 +1,42 @@
+package de.brickedleveleditor.ui.controller;
+
+
+import de.bricked.game.paddle.PaddleSize;
+import javafx.fxml.FXML;
+import javafx.scene.control.ComboBox;
+import javafx.scene.control.Spinner;
+import javafx.scene.control.TextField;
+
+public class LevelPackDialogController extends AbstractController
+{
+    @FXML private Spinner difficultySpinner;
+    @FXML private ComboBox paddleSizeComboBox;
+    @FXML private Spinner startLivesSpinner;
+    @FXML private TextField authorTextField;
+    @FXML private TextField levelNameTextField;
+
+    @Override
+    protected void initController()
+    {
+
+    }
+
+    @FXML
+    private void onSaveButtonClicked()
+    {
+        String levelName = levelNameTextField.getText();
+        String author = authorTextField.getText();
+        int position = ((MainController)parentController).getLevelPackWriter().getLevels().size();
+        int difficulty = (int)difficultySpinner.getValue();
+        int startLives = (int)startLivesSpinner.getValue();
+        PaddleSize initPadSize = (PaddleSize)paddleSizeComboBox.getSelectionModel().getSelectedItem();
+        ((MainController)parentController).getLevelPackWriter().addLevel(levelName, author, position, difficulty, startLives, initPadSize, ((MainController)parentController).getBrickArrayList());
+    }
+
+    @FXML
+    private void onBackButtonClicked()
+    {
+
+    }
+
+}
diff --git a/src/de/brickedleveleditor/ui/Controller.java b/src/de/brickedleveleditor/ui/controller/MainController.java
similarity index 84%
rename from src/de/brickedleveleditor/ui/Controller.java
rename to src/de/brickedleveleditor/ui/controller/MainController.java
index 017e1e7..c5bbd61 100644
--- a/src/de/brickedleveleditor/ui/Controller.java
+++ b/src/de/brickedleveleditor/ui/controller/MainController.java
@@ -1,4 +1,4 @@
-package de.brickedleveleditor.ui;
+package de.brickedleveleditor.ui.controller;
 
 import java.io.File;
 import java.util.ArrayList;
@@ -11,11 +11,15 @@ import de.bricked.game.bricks.BrickType;
 import de.bricked.game.powerups.PowerUpType;
 import de.brickedleveleditor.game.levels.LevelPackWriter;
 import de.bricked.game.paddle.PaddleSize;
+import de.brickedleveleditor.ui.BrickLabel;
 import javafx.event.ActionEvent;
 import javafx.event.EventHandler;
 import javafx.fxml.FXML;
+import javafx.fxml.FXMLLoader;
 import javafx.geometry.Insets;
 import javafx.geometry.Pos;
+import javafx.scene.Parent;
+import javafx.scene.Scene;
 import javafx.scene.control.Alert;
 import javafx.scene.control.Alert.AlertType;
 import javafx.scene.control.Label;
@@ -31,7 +35,7 @@ import logger.LogLevel;
 import logger.Logger;
 import tools.Worker;
 
-public class Controller
+public class MainController extends AbstractController
 {
     @FXML
     private AnchorPane anchorPane;
@@ -39,7 +43,8 @@ public class Controller
     private VBox sidebarVBox;
     @FXML
     private GridPane gridPane;
-    @FXML private MenuItem saveMenuItem;
+    @FXML
+    private MenuItem saveMenuItem;
     private BrickType[] brickTypes = BrickType.values();
     private Image currentlySelectedBrickImage;
     private Image currentlySelectedPowerupImage;
@@ -52,12 +57,12 @@ public class Controller
     private ArrayList<Image> powerupTextures;
     private LevelPackWriter levelPackWriter;
 
-    public void init(Stage stage)
+    @Override
+    protected void initController()
     {
         powerupTextures = new ArrayList<>();
         levelPackWriter = new LevelPackWriter();
         gridPane.setMaxSize(50, 50);
-        this.stage = stage;
         bricksTextures = new HashMap<>();
         loadPowerupTextures();
         addPowerupsToVBox();
@@ -74,21 +79,30 @@ public class Controller
                 System.exit(0);
             }
         });
+    }
 
-        saveMenuItem.setOnAction(new EventHandler<ActionEvent>()
+    @FXML
+    private void onSaveMenuItemClicked()
+    {
+        try
         {
-            @Override
-            public void handle(ActionEvent event)
-            {
-                String levelName = "";
-                String author = "";
-                int position = 0;
-                int difficulty = 1;
-                int startLives = 1;
-                PaddleSize initPadSize = PaddleSize.EXTRA_LARGE;
-                levelPackWriter.addLevel(levelName, author, position, difficulty, startLives, initPadSize, getBrickArrayList());
-            }
-        });
+            FXMLLoader loader = new FXMLLoader(getClass().getClassLoader().getResource("de/brickedleveleditor/ui/fxml/level_pack_dialog_controller.fxml"));
+            Parent root = (Parent) loader.load();
+
+            Scene scene = new Scene(root);
+
+            Stage dialogControllerStage = new Stage();
+
+            dialogControllerStage.setTitle(bundle.getString("level.saver"));
+            dialogControllerStage.setScene(scene);
+            dialogControllerStage.setResizable(true);
+            dialogControllerStage.show();
+            ((LevelPackDialogController) loader.getController()).init(dialogControllerStage,this);
+        }
+        catch (Exception e)
+        {
+            Logger.log(LogLevel.ERROR, Logger.exceptionToString(e));
+        }
     }
 
     private void loadPowerupTextures()
@@ -97,7 +111,7 @@ public class Controller
         String rootPath = "de/bricked/resources/textures/powerups/";
         //powerup[0] means no powerup --> set to null
         powerupTextures.add(null);
-        for (int i=1; i < PowerUpType.types.length; i++)
+        for (int i = 1; i < PowerUpType.types.length; i++)
         {
             File powerupPath = new File(rootPath + PowerUpType.types[i].getId() + fileExt);
             try
@@ -146,11 +160,11 @@ public class Controller
     {
         ArrayList<Brick> bricks = new ArrayList<>();
         Object[] gridPaneChildren = gridPane.getChildren().toArray();
-        for(int i = 0; i < gridPaneChildren.length; i++)
+        for (int i = 0; i < gridPaneChildren.length; i++)
         {
-            if(gridPaneChildren[i] instanceof BrickLabel)
+            if (gridPaneChildren[i] instanceof BrickLabel)
             {
-                BrickLabel currentLabel = (BrickLabel)gridPaneChildren[i];
+                BrickLabel currentLabel = (BrickLabel) gridPaneChildren[i];
                 Brick brick = new Brick(currentLabel.getBrickType(),
                         PowerUpType.getInstance(currentLabel.getPowerUpType()));
                 bricks.add(brick);
@@ -181,7 +195,7 @@ public class Controller
 
     private void addPowerupsToVBox()
     {
-        for(int i=1; i < powerupTextures.size(); i++)
+        for (int i = 1; i < powerupTextures.size(); i++)
         {
             Image powerupImage = powerupTextures.get(i);
             Label powerupLabel = new Label(PowerUpType.types[i].toString());
@@ -203,8 +217,8 @@ public class Controller
     private Background getBackGroundFromImage(Image image)
     {
         BackgroundImage backgroundImage = new BackgroundImage(image,
-                BackgroundRepeat.NO_REPEAT,BackgroundRepeat.NO_REPEAT,
-                BackgroundPosition.CENTER,BackgroundSize.DEFAULT);
+                BackgroundRepeat.NO_REPEAT, BackgroundRepeat.NO_REPEAT,
+                BackgroundPosition.CENTER, BackgroundSize.DEFAULT);
         Background background = new Background(backgroundImage);
         return background;
     }
@@ -262,6 +276,11 @@ public class Controller
         }
     }
 
+    public LevelPackWriter getLevelPackWriter()
+    {
+        return levelPackWriter;
+    }
+
     public void about()
     {
         Alert alert = new Alert(AlertType.INFORMATION);
diff --git a/src/de/brickedleveleditor/ui/fxml/level_pack_dialog_controller.fxml b/src/de/brickedleveleditor/ui/fxml/level_pack_dialog_controller.fxml
new file mode 100644
index 0000000..5d82abf
--- /dev/null
+++ b/src/de/brickedleveleditor/ui/fxml/level_pack_dialog_controller.fxml
@@ -0,0 +1,25 @@
+<?xml version="1.0" encoding="UTF-8"?>
+
+<?import javafx.scene.control.Button?>
+<?import javafx.scene.control.ComboBox?>
+<?import javafx.scene.control.Label?>
+<?import javafx.scene.control.Spinner?>
+<?import javafx.scene.control.TextField?>
+<?import javafx.scene.layout.AnchorPane?>
+
+<AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="317.0" prefWidth="397.0" xmlns="http://javafx.com/javafx/8.0.65" xmlns:fx="http://javafx.com/fxml/1" fx:controller="de.brickedleveleditor.ui.controller.LevelPackDialogController">
+   <children>
+      <Label layoutX="14.0" layoutY="22.0" prefHeight="16.0" prefWidth="112.0" text="Levelname:" AnchorPane.leftAnchor="14.0" />
+      <Label layoutX="14.0" layoutY="61.0" prefHeight="16.0" prefWidth="112.0" text="Author:" AnchorPane.leftAnchor="14.0" />
+      <TextField fx:id="authorTextField" layoutX="212.0" layoutY="56.0" AnchorPane.rightAnchor="14.0" />
+      <TextField fx:id="levelNameTextField" layoutX="212.0" layoutY="17.0" AnchorPane.rightAnchor="14.0" />
+      <Label layoutX="14.0" layoutY="99.0" prefHeight="16.0" prefWidth="112.0" text="Difficulty:" AnchorPane.leftAnchor="14.0" />
+      <Spinner fx:id="difficultySpinner" layoutX="212.0" layoutY="94.0" prefHeight="26.0" prefWidth="171.0" AnchorPane.rightAnchor="14.0" />
+      <Label layoutX="14.0" layoutY="138.0" prefHeight="16.0" prefWidth="112.0" text="Start-Lives:" AnchorPane.leftAnchor="14.0" />
+      <Label layoutX="14.0" layoutY="174.0" prefHeight="16.0" prefWidth="112.0" text="Paddle-Size" AnchorPane.leftAnchor="14.0" />
+      <ComboBox fx:id="paddleSizeComboBox" layoutX="212.0" layoutY="169.0" prefHeight="26.0" prefWidth="171.0" AnchorPane.rightAnchor="14.0" />
+      <Button layoutX="126.0" layoutY="277.0" mnemonicParsing="false" onAction="#onSaveButtonClicked" text="Save" AnchorPane.bottomAnchor="14.0" />
+      <Button layoutX="212.0" layoutY="277.0" mnemonicParsing="false" onAction="#onBackButtonClicked" text="Back" AnchorPane.bottomAnchor="14.0" />
+      <Spinner fx:id="startLivesSpinner" layoutX="212.0" layoutY="133.0" />
+   </children>
+</AnchorPane>
diff --git a/src/de/brickedleveleditor/ui/GUI.fxml b/src/de/brickedleveleditor/ui/fxml/main_controller.fxml
similarity index 91%
rename from src/de/brickedleveleditor/ui/GUI.fxml
rename to src/de/brickedleveleditor/ui/fxml/main_controller.fxml
index 23f129a..7cb5639 100644
--- a/src/de/brickedleveleditor/ui/GUI.fxml
+++ b/src/de/brickedleveleditor/ui/fxml/main_controller.fxml
@@ -9,17 +9,17 @@
 <?import javafx.scene.layout.RowConstraints?>
 <?import javafx.scene.layout.VBox?>
 
-<AnchorPane fx:id="anchorPane" prefHeight="600.0" prefWidth="800.0" xmlns="http://javafx.com/javafx/8.0.65" xmlns:fx="http://javafx.com/fxml/1" fx:controller="de.brickedleveleditor.ui.Controller">
+<AnchorPane fx:id="anchorPane" prefHeight="600.0" prefWidth="800.0" xmlns="http://javafx.com/javafx/8.0.65" xmlns:fx="http://javafx.com/fxml/1" fx:controller="de.brickedleveleditor.ui.controller.MainController">
    <children>
       <MenuBar layoutX="40.0" AnchorPane.leftAnchor="0.0" AnchorPane.rightAnchor="0.0" AnchorPane.topAnchor="0.0">
         <menus>
             <Menu mnemonicParsing="false" text="File">
               <items>
-                <MenuItem fx:id="saveMenuItem" mnemonicParsing="false" text="Save" />
+                <MenuItem fx:id="saveMenuItem" mnemonicParsing="false" onAction="#onSaveMenuItemClicked" text="Save" />
                   <MenuItem mnemonicParsing="false" text="Unspecified Action" />
               </items>
             </Menu>
-          <Menu mnemonicParsing="false" text="Hilfe">
+          <Menu mnemonicParsing="false" text="Help">
             <items>
               <MenuItem mnemonicParsing="false" onAction="#about" text="Über" />
             </items>
-- 
GitLab