From 5446859dee2d38faecc2b83c054e8f011f6e5a06 Mon Sep 17 00:00:00 2001 From: loic <git-account@loicguegan.fr> Date: Thu, 22 Sep 2016 20:00:51 +0200 Subject: [PATCH] Begin javafx --- .idea/compiler.xml | 2 +- .idea/misc.xml | 95 ----------- .idea/uiDesigner.xml | 124 +++++++++++++++ 2048.iml | 2 +- pom.xml | 12 ++ src/main/java/adapter/IModelAdapter.java | 12 ++ src/main/java/adapter/ModelAdapter.java | 80 ++++++++++ src/main/java/app/Application.java | 42 ++++- .../java/controller/ConsoleController.java | 50 ++++++ src/main/java/model/Board.java | 147 ++++++++++++++++++ src/main/java/model/IModel.java | 8 + src/main/java/model/LineAlgorithm.java | 91 +++++++++++ src/main/java/observer/IObservable.java | 10 ++ src/main/java/observer/IObserver.java | 8 + src/main/java/view/ConsoleView.java | 68 ++++++++ src/main/java/view/IView.java | 13 ++ src/main/resources/JavafxView/MainWindow.fxml | 20 +++ 17 files changed, 681 insertions(+), 103 deletions(-) create mode 100644 .idea/uiDesigner.xml create mode 100644 src/main/java/adapter/IModelAdapter.java create mode 100644 src/main/java/adapter/ModelAdapter.java create mode 100644 src/main/java/controller/ConsoleController.java create mode 100644 src/main/java/model/Board.java create mode 100644 src/main/java/model/IModel.java create mode 100644 src/main/java/model/LineAlgorithm.java create mode 100644 src/main/java/observer/IObservable.java create mode 100644 src/main/java/observer/IObserver.java create mode 100644 src/main/java/view/ConsoleView.java create mode 100644 src/main/java/view/IView.java create mode 100644 src/main/resources/JavafxView/MainWindow.fxml diff --git a/.idea/compiler.xml b/.idea/compiler.xml index 9565642..f8cbea7 100644 --- a/.idea/compiler.xml +++ b/.idea/compiler.xml @@ -26,7 +26,7 @@ </profile> </annotationProcessing> <bytecodeTargetLevel> - <module name="2048" target="1.5" /> + <module name="2048" target="1.6" /> </bytecodeTargetLevel> </component> </project> \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml index cd1cc97..233a7f0 100644 --- a/.idea/misc.xml +++ b/.idea/misc.xml @@ -10,85 +10,6 @@ </list> </option> </component> - <component name="ProjectInspectionProfilesVisibleTreeState"> - <entry key="Project Default"> - <profile-state> - <expanded-state> - <State> - <id /> - </State> - <State> - <id>Android > Lint > Correctness</id> - </State> - <State> - <id>Android > Lint > Security</id> - </State> - <State> - <id>Android Lint for Kotlin</id> - </State> - <State> - <id>CFML</id> - </State> - <State> - <id>GPath inspectionsGroovy</id> - </State> - <State> - <id>GeneralJavaScript</id> - </State> - <State> - <id>Google Web Toolkit issues</id> - </State> - <State> - <id>Groovy</id> - </State> - <State> - <id>JPA issues</id> - </State> - <State> - <id>JSP Inspections</id> - </State> - <State> - <id>Java</id> - </State> - <State> - <id>Java EE issues</id> - </State> - <State> - <id>JavaScript</id> - </State> - <State> - <id>Probable bugsJava</id> - </State> - <State> - <id>RESTful Web Service</id> - </State> - <State> - <id>Security issuesJava</id> - </State> - <State> - <id>Spring</id> - </State> - <State> - <id>Spring MVCSpring</id> - </State> - <State> - <id>WebSocket issues</id> - </State> - <State> - <id>XML</id> - </State> - <State> - <id>XPath</id> - </State> - </expanded-state> - <selected-state> - <State> - <id>JpaQlInspection</id> - </State> - </selected-state> - </profile-state> - </entry> - </component> <component name="ProjectLevelVcsManager" settingsEditedManually="false"> <OptionsSetting value="true" id="Add" /> <OptionsSetting value="true" id="Remove" /> @@ -102,20 +23,4 @@ <component name="ProjectRootManager" version="2" languageLevel="JDK_1_8" default="true" assert-keyword="true" jdk-15="true" project-jdk-name="1.8" project-jdk-type="JavaSDK"> <output url="file://$PROJECT_DIR$/out" /> </component> - <component name="masterDetails"> - <states> - <state key="ProjectJDKs.UI"> - <settings> - <last-edited>1.8</last-edited> - <splitter-proportions> - <option name="proportions"> - <list> - <option value="0.2" /> - </list> - </option> - </splitter-proportions> - </settings> - </state> - </states> - </component> </project> \ No newline at end of file diff --git a/.idea/uiDesigner.xml b/.idea/uiDesigner.xml new file mode 100644 index 0000000..e96534f --- /dev/null +++ b/.idea/uiDesigner.xml @@ -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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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.png" 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> \ No newline at end of file diff --git a/2048.iml b/2048.iml index 73f608b..d932926 100644 --- a/2048.iml +++ b/2048.iml @@ -1,6 +1,6 @@ <?xml version="1.0" encoding="UTF-8"?> <module org.jetbrains.idea.maven.project.MavenProjectsManager.isMavenModule="true" type="JAVA_MODULE" version="4"> - <component name="NewModuleRootManager" LANGUAGE_LEVEL="JDK_1_5" inherit-compiler-output="false"> + <component name="NewModuleRootManager" LANGUAGE_LEVEL="JDK_1_6" inherit-compiler-output="false"> <output url="file://$MODULE_DIR$/target/classes" /> <output-test url="file://$MODULE_DIR$/target/test-classes" /> <content url="file://$MODULE_DIR$"> diff --git a/pom.xml b/pom.xml index 4a01981..9ccd366 100644 --- a/pom.xml +++ b/pom.xml @@ -7,6 +7,18 @@ <groupId>manzerbredes</groupId> <artifactId>2048</artifactId> <version>1.0-SNAPSHOT</version> + <build> + <plugins> + <plugin> + <groupId>org.apache.maven.plugins</groupId> + <artifactId>maven-compiler-plugin</artifactId> + <configuration> + <source>1.6</source> + <target>1.6</target> + </configuration> + </plugin> + </plugins> + </build> </project> diff --git a/src/main/java/adapter/IModelAdapter.java b/src/main/java/adapter/IModelAdapter.java new file mode 100644 index 0000000..86139ee --- /dev/null +++ b/src/main/java/adapter/IModelAdapter.java @@ -0,0 +1,12 @@ +package adapter; + +/** + * Created by loic on 21/09/16. + */ +public interface IModelAdapter { + void goUp(); + void goDown(); + void goLeft(); + void goRight(); + boolean isLoosed(); +} diff --git a/src/main/java/adapter/ModelAdapter.java b/src/main/java/adapter/ModelAdapter.java new file mode 100644 index 0000000..1eac58a --- /dev/null +++ b/src/main/java/adapter/ModelAdapter.java @@ -0,0 +1,80 @@ +package adapter; + +import model.Board; +import observer.IObservable; +import observer.IObserver; + +import java.util.ArrayList; +import java.util.Collection; +import java.util.Iterator; + +/** + * Created by loic on 21/09/16. + */ +public class ModelAdapter implements IModelAdapter, IObservable{ + + private Board model; + private Collection<IObserver> observers; + + public ModelAdapter(Board model){ + this.model=model; + observers = new ArrayList<IObserver>(); + } + + @Override + public void goUp() { + model.goUp(); + model.addRandomNumber(); + this.notifyObservers(); + } + + @Override + public void goDown() { + model.goDown(); + model.addRandomNumber(); + this.notifyObservers(); + } + + @Override + public void goLeft() { + model.goLeft(); + model.addRandomNumber(); + this.notifyObservers(); + } + + @Override + public void goRight() { + model.goRight(); + model.addRandomNumber(); + this.notifyObservers(); + } + + + @Override + public boolean isLoosed() { + return this.model.isLoosed(); + } + + public void addRandomNumber() { + this.model.addRandomNumber(); + this.notifyObservers(); + } + + @Override + public void addObserver(IObserver observer) { + this.observers.add(observer); + } + + @Override + public void removeObserver(IObserver observer) { + this.observers.remove(observer); + } + + @Override + public void notifyObservers() { + Iterator<IObserver> i=this.observers.iterator(); + while(i.hasNext()){ + i.next().update(); + } + } +} diff --git a/src/main/java/app/Application.java b/src/main/java/app/Application.java index 7034373..9efd5e3 100644 --- a/src/main/java/app/Application.java +++ b/src/main/java/app/Application.java @@ -1,14 +1,44 @@ package app; -/** - * Created by loic on 21/09/16. - */ -public class Application { +import adapter.ModelAdapter; +import controller.MainWindowController; +import javafx.event.EventHandler; +import javafx.fxml.FXMLLoader; +import javafx.scene.Parent; +import javafx.scene.Scene; +import javafx.scene.input.KeyEvent; +import javafx.stage.Stage; +import model.Board; +import model.IModel; +import observer.IObserver; + +import java.awt.*; + +public class Application extends javafx.application.Application{ + + public static void main(String[] args) { + launch(args); + } + + @Override + public void start(Stage primaryStage) throws Exception { + + FXMLLoader fxmlLoader = new FXMLLoader(Application.class.getClassLoader().getResource("JavafxView/MainWindow.fxml")); + Scene scene=new Scene((Parent)fxmlLoader.load()); + + primaryStage.setTitle("2048"); + primaryStage.setScene(scene); + // COnfigure controller + IModel model=new Board(4,4); + ModelAdapter adapter=new ModelAdapter((Board) model); + adapter.addRandomNumber(); + MainWindowController controller=fxmlLoader.getController(); + adapter.addObserver((IObserver)controller); + controller.loadComponent(adapter,model,scene); - public static void main(String[] args){ - System.out.println("Test"); + primaryStage.show(); } } diff --git a/src/main/java/controller/ConsoleController.java b/src/main/java/controller/ConsoleController.java new file mode 100644 index 0000000..95b1821 --- /dev/null +++ b/src/main/java/controller/ConsoleController.java @@ -0,0 +1,50 @@ +package controller; + +import adapter.IModelAdapter; +import adapter.ModelAdapter; +import model.Board; + +/** + * Created by loic on 21/09/16. + */ +public class ConsoleController implements IModelAdapter { + + private ModelAdapter adapter; + + public ConsoleController(ModelAdapter model){ + this.adapter=model; + } + + public void startGame(){ + this.adapter.addRandomNumber(); + } + + @Override + public void goUp() { + adapter.goUp(); + } + + @Override + public void goDown() { + adapter.goDown(); + } + + @Override + public void goLeft() { + adapter.goLeft(); + } + + @Override + public void goRight() { + adapter.goRight(); + } + + @Override + public boolean isLoosed() { + return this.adapter.isLoosed(); + } + + + + +} diff --git a/src/main/java/model/Board.java b/src/main/java/model/Board.java new file mode 100644 index 0000000..7ed60a7 --- /dev/null +++ b/src/main/java/model/Board.java @@ -0,0 +1,147 @@ +package model; + +import java.util.ArrayList; +import java.util.Collection; +import java.util.Random; + +/** + * Created by loic on 21/09/16. + */ +public class Board implements IModel{ + + private int[][] board; + private Random rand = new Random(); + private LineAlgorithm lineAlgorithm; + + + public Board(int sizeX, int sizeY){ + board=new int[sizeY][sizeX]; + this.cleanBoard(); + } + + public void goUp() { + for(int i=0;i<this.board[0].length;i++){ + + int[] column=this.lineAlgorithm.reverseLine(this.getColumn(i)); + + + this.setColumn(this.lineAlgorithm.reverseLine(this.lineAlgorithm.mergeRight(column)), i); + + } + + } + + public void goDown() { + for(int i=0;i<this.board[0].length;i++){ + int[] column=this.getColumn(i); + this.setColumn(this.lineAlgorithm.mergeRight(column), i); + } + } + + public void goLeft() { + for(int i=0;i<this.board.length;i++){ + int[] tmp=this.lineAlgorithm.reverseLine(board[i]); + tmp=this.lineAlgorithm.mergeRight(tmp); + tmp=this.lineAlgorithm.reverseLine(tmp); + this.board[i]=tmp; + } + } + + + public void goRight() { + for(int i=0;i<this.board.length;i++){ + this.board[i]=this.lineAlgorithm.mergeRight(board[i]); + } + } + + + private void cleanBoard(){ + for(int i=0;i<this.board.length;i++) { + this.board[i]=this.lineAlgorithm.clearLine(this.board[i]); + } + } + + private int[] getColumn(int index){ + int[] column=new int[this.board.length]; + for(int i=0;i<this.board.length;i++){ + column[i]=this.board[i][index]; + } + return column; + } + + private void setColumn(int[] column, int index){ + for(int i=0;i<this.board[index].length;i++){ + this.board[i][index]=column[i]; + } + } + + + public void addRandomNumber(){ + Collection<Integer[]> choices=new ArrayList<Integer[]>(); + for(int i=0;i<this.board.length;i++) { + for (int j = 0; j < this.board[i].length; j++) { + if(this.board[i][j]==-1){ + choices.add(new Integer[]{i,j}); + } + } + } + if(choices.size()>0){ + int index=0; + if(choices.size()>1){ + index=rand.nextInt(choices.size()-1) + 0; + } + Integer[] xy=(Integer[])choices.toArray()[index]; + this.board[xy[0]][xy[1]]=2; + } + } + + private boolean boardsIsEquals(int[][] board1, int[][] board2){ + if(board1.length!=board1.length){ + return false; + } + else { + for (int i=0;i<board1.length;i++){ + if(!this.lineAlgorithm.linesIsEquals(board1[i],board2[i])){ + return false; + } + } + } + return true; + } + + @Override + public int[][] getBoard() { + return this.getCloneOfBoard(); + } + + + public boolean isLoosed() { + int[][] copyBoard=this.getCloneOfBoard(); + + this.goDown(); + if(boardsIsEquals(copyBoard, this.board)) { + this.goUp(); + if (boardsIsEquals(copyBoard, this.board)) { + this.goRight(); + if (boardsIsEquals(copyBoard, this.board)) { + this.goLeft(); + if (boardsIsEquals(copyBoard, this.board)) { + return true; + } + } + } + } + this.board=copyBoard; + + return false; + } + + + private int[][] getCloneOfBoard(){ + int[][] copyBoard=new int[this.board.length][this.board[0].length]; + for(int i=0;i<this.board.length;i++){ + copyBoard[i]=this.board[i].clone(); + } + return copyBoard; + } +} diff --git a/src/main/java/model/IModel.java b/src/main/java/model/IModel.java new file mode 100644 index 0000000..4db2146 --- /dev/null +++ b/src/main/java/model/IModel.java @@ -0,0 +1,8 @@ +package model; + +/** + * Created by loic on 21/09/16. + */ +public interface IModel { + int[][] getBoard(); +} diff --git a/src/main/java/model/LineAlgorithm.java b/src/main/java/model/LineAlgorithm.java new file mode 100644 index 0000000..024db5c --- /dev/null +++ b/src/main/java/model/LineAlgorithm.java @@ -0,0 +1,91 @@ +package model; + +/** + * Created by loic on 21/09/16. + */ +public class LineAlgorithm { + + + + public static int[] mergeRight(int[] line){ + + line=gravityRight(line); + + for(int i=(line.length-1);i>=0;i--){ + if(i>0){ + int a=line[i]; + int b=line[i-1]; + if(a==b && a!=-1){ + line[i]=a+b; + line[i-1]=-1; + i--; + } + } + } + + line=gravityRight(line); + + return line; + } + + + private static int[] gravityRight(int[] line){ + for(int i=0;i<line.length;i++) { + for (int j = (line.length - 1); j >= 0; j--) { + int a = line[j]; + if (j > 0) { + int b = line[j - 1]; + if (a == -1) { + line[j] = b; + line[j - 1] = -1; + } + } + } + } + return line; + } + + + public static int[] clearLine(int[] line){ + for(int i=0;i<line.length;i++){ + line[i]=-1; + } + return line; + } + + public static int[] reverseLine(int[] line){ + int[] reversedLine=new int[line.length]; + + int j=0; + for(int i=(line.length-1);i>=0;i--){ + reversedLine[j]=line[i]; + j++; + } + + return reversedLine; + } + + public static boolean linesIsEquals(int[] line1, int[] line2){ + if(line1.length!=line2.length){ + return false; + } + else { + for (int i=0;i<line1.length;i++){ + if(line1[i]!=line2[i]){ + return false; + } + } + } + return true; + + } + + public static void printLine(int[] line){ + System.out.println("----------"); + for(int i=0;i<line.length;i++){ + System.out.print(line[i]); + } + System.out.println("\n----------"); + + } +} diff --git a/src/main/java/observer/IObservable.java b/src/main/java/observer/IObservable.java new file mode 100644 index 0000000..2dadc60 --- /dev/null +++ b/src/main/java/observer/IObservable.java @@ -0,0 +1,10 @@ +package observer; + +/** + * Created by loic on 21/09/16. + */ +public interface IObservable { + void addObserver(IObserver object); + void removeObserver(IObserver object); + void notifyObservers(); +} diff --git a/src/main/java/observer/IObserver.java b/src/main/java/observer/IObserver.java new file mode 100644 index 0000000..3bd1626 --- /dev/null +++ b/src/main/java/observer/IObserver.java @@ -0,0 +1,8 @@ +package observer; + +/** + * Created by loic on 21/09/16. + */ +public interface IObserver { + void update(); +} diff --git a/src/main/java/view/ConsoleView.java b/src/main/java/view/ConsoleView.java new file mode 100644 index 0000000..68e25f3 --- /dev/null +++ b/src/main/java/view/ConsoleView.java @@ -0,0 +1,68 @@ +package view; + +import controller.ConsoleController; +import adapter.IModelAdapter; +import model.IModel; +import observer.IObserver; + +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStreamReader; + +/** + * Created by loic on 21/09/16. + */ +public class ConsoleView implements IView, IObserver{ + + private ConsoleController controller; + private IModel model; + + + @Override + public void loadComponent(IModelAdapter controller, IModel model) { + this.controller= (ConsoleController) controller; + this.model=model; + } + + + + @Override + public void show() { + this.controller.startGame(); + } + + @Override + public void update() { + BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); + int[][] board; + board = this.model.getBoard(); + + for (int i = 0; i < board.length; i++) { + for (int j = 0; j < board[i].length; j++) { + System.out.print(board[i][j] + " "); + } + System.out.println(); + } + System.out.println(); + + System.out.print("Enter U or D or L or R :"); + String input = null; + try { + input = br.readLine(); + } catch (IOException e) { + e.printStackTrace(); + } + if(input.equals("U")){ + controller.goUp(); + } + else if(input.equals("D")){ + controller.goDown(); + } + else if(input.equals("L")){ + controller.goLeft(); + } + else if(input.equals("R")){ + controller.goRight(); + } + } +} diff --git a/src/main/java/view/IView.java b/src/main/java/view/IView.java new file mode 100644 index 0000000..e0c3671 --- /dev/null +++ b/src/main/java/view/IView.java @@ -0,0 +1,13 @@ +package view; + +import adapter.IModelAdapter; +import model.IModel; + +/** + * Created by loic on 21/09/16. + */ +public interface IView { + + void loadComponent(IModelAdapter controller, IModel model); + void show(); +} diff --git a/src/main/resources/JavafxView/MainWindow.fxml b/src/main/resources/JavafxView/MainWindow.fxml new file mode 100644 index 0000000..5cf18e2 --- /dev/null +++ b/src/main/resources/JavafxView/MainWindow.fxml @@ -0,0 +1,20 @@ +<?xml version="1.0" encoding="UTF-8"?> + +<?import java.net.*?> +<?import javafx.geometry.*?> +<?import javafx.scene.control.*?> +<?import javafx.scene.layout.*?> +<?import javafx.scene.text.*?> + +<?import javafx.scene.canvas.Canvas?> +<BorderPane fx:controller="controller.MainWindowController" + xmlns:fx="http://javafx.com/fxml" prefWidth="800" prefHeight="800"> + + <top> + </top> + <center> + <Canvas fx:id="boardCanvas" height="500" width="500" /> + </center> + + +</BorderPane> \ No newline at end of file