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 &gt; Lint &gt; Correctness</id>
-          </State>
-          <State>
-            <id>Android &gt; Lint &gt; 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