diff --git a/src/main/java/src/Field.java b/src/main/java/src/Field.java index 54df723..08b58d0 100644 --- a/src/main/java/src/Field.java +++ b/src/main/java/src/Field.java @@ -1,12 +1,41 @@ package src; import javax.swing.*; +import javax.swing.border.LineBorder; +import java.awt.*; public class Field extends JPanel { - private int x; - private int y; + + private int _x; + private int _y; private JLabel jLabel; + private Notes note; + + public Field(int x, int y, int size) { + + setBounds(0, 0, size, size); + setVisible(true); + setLayout(null); + setBorder(new LineBorder(Color.BLACK, 2)); + setVisible(true); + + jLabel = new JLabel("", SwingConstants.CENTER); + jLabel.setBounds(0, 0, size, size); + jLabel.setBackground(Color.GREEN); + jLabel.setForeground(Color.MAGENTA); + jLabel.setVisible(false); + jLabel.setFont(new Font("Times new Roman", Font.BOLD, 25)); + + note = new Notes(size-2); + + + this.add(jLabel); + this.add(note); + + this._x=x; + this._y=y; + } public JLabel getjLabel() { return jLabel; @@ -17,18 +46,43 @@ public class Field extends JPanel { } public int getMyX() { - return x; + return _x; } public int getMyY() { - return y; + return _y; } public void setMyX(int x) { - this.x = x; + this._x = x; } public void setMyY(int y) { - this.y = y; + this._y = y; + } + + public void setHint(int hint) { + note.setHint(hint); + } + + public void unsetHints() { + + for (int i = 0; i < 9; i++) { + note.unsetHint(i); + } + } + + public void unsetHint(int value) { + note.unsetHint(value); + } + + public Notes getNote() { + return note; + } + + public void setValue(int value) { + note.setVisible(false); + jLabel.setVisible(true); + jLabel.setText(String.valueOf(value)); } } diff --git a/src/main/java/src/GameField.java b/src/main/java/src/GameField.java index c337255..0cd80f7 100644 --- a/src/main/java/src/GameField.java +++ b/src/main/java/src/GameField.java @@ -8,9 +8,9 @@ import java.awt.event.MouseListener; public class GameField extends JPanel { - private Notes[][] noteField; +// private Notes[][] noteField; private Field[][] gameField; - private JLabel[][] labelField; +// private JLabel[][] labelField; private Field activePanel = null; @@ -18,17 +18,17 @@ public class GameField extends JPanel { private static final Color colorOnEntered = new Color(0, 0, 255, 100); private static final Color colorOnWhenActive = new Color(0, 255, 150, 200); - public Notes[][] getNoteField() { - return noteField; - } +// public Notes[][] getNoteField() { +// return noteField; +// } - public JPanel[][] getGameField() { + public Field[][] getGameField() { return gameField; } - public JLabel[][] getLabelField() { - return labelField; - } +// public JLabel[][] getLabelField() { +// return labelField; +// } public Field getActivePanel() { return activePanel; @@ -49,49 +49,28 @@ public class GameField extends JPanel { this.setLayout(null); gameField = new Field[nrOfFields][]; - labelField = new JLabel[nrOfFields][]; - noteField = new Notes[nrOfFields][]; +// labelField = new JLabel[nrOfFields][]; +// noteField = new Notes[nrOfFields][]; int gapi = 0, gapj = 0; for (int i = 0, addI = 1; i < nrOfFields; i++) { gameField[i] = new Field[nrOfFields]; - labelField[i] = new JLabel[nrOfFields]; - noteField[i] = new Notes[nrOfFields]; +// labelField[i] = new JLabel[nrOfFields]; +// noteField[i] = new Notes[nrOfFields]; for (int j = 0, addJ = 1; j < nrOfFields; j++) { + gameField[i][j] = new Field(i, j, size); + gameField[i][j].setBackground(colorDefault); - gameField[i][j] = new Field(); - gameField[i][j].setMyY(j); - gameField[i][j].setMyX(i); - gameField[i][j] = new Field(); - gameField[i][j].setBorder(new LineBorder(Color.BLACK, 2)); - gameField[i][j].setLayout(null); gameField[i][j].setBounds( j * size + border*(j+1), i * size + border*(i+1), size, size); - gameField[i][j].setBackground(colorDefault); - gameField[i][j].setVisible(true); - this.add(gameField[i][j]); - - noteField[i][j] = new Notes(size); - noteField[i][j].setBounds(border, border, size-2*border, size-2*border); - gameField[i][j].add(noteField[i][j]); - JLabel lf = labelField[i][j]; - gameField[i][j].setMyJLabel(lf); - labelField[i][j] = new JLabel("", SwingConstants.CENTER); - labelField[i][j].setBounds(0, 0, size, size); - labelField[i][j].setBackground(Color.GREEN); - labelField[i][j].setForeground(Color.MAGENTA); - labelField[i][j].setVisible(false); - labelField[i][j].setFont(new Font("Times new Roman", Font.BOLD, 25)); - - labelField[i][j].setBackground(Color.CYAN); - labelField[i][j].setText("0"); + this.add(gameField[i][j]); gameField[i][j].addMouseListener(new MouseListener() { @@ -102,6 +81,7 @@ public class GameField extends JPanel { @Override public void mousePressed(MouseEvent e) { + Field component = (Field) e.getComponent(); if (activePanel == null) { @@ -135,26 +115,31 @@ public class GameField extends JPanel { } }); - gameField[i][j].add(labelField[i][j]); - } } } public void setValue(int x, int y, int value) { - if (value > 0 && value < 10) { - if (x > -1 && x < 9 && y > -1 && y < 9) { - labelField[y][x].setText(String.valueOf(value)); - labelField[y][x].setVisible(true); - } - } + JLabel jLabel = gameField[y][x].getjLabel(); + jLabel.setText(String.valueOf(value)); + jLabel.setVisible(true); + } public int getValue(int x, int y) { + if (x > -1 && x < 9 && y > -1 && y < 9) { - Integer value = Integer.valueOf(labelField[y][x].getText()); - return value; + + JLabel jLabel = gameField[y][x].getjLabel(); + + try { + Integer value = Integer.valueOf(jLabel.getText()); + return value; + + } catch (NumberFormatException e) { + return -1; + } } return -1; } @@ -163,22 +148,20 @@ public class GameField extends JPanel { if (value > 0 && value < 10) { if (x > -1 && x < 9 && y > -1 && y < 9) { - noteField[x][y].setHint(value); + gameField[x][y].setHint(value); } } } public void unsetHint(int x, int y, int value) { - if (noteField[x][y].isSet(value)) { - setHint(x, y, value); - } + gameField[x][y].unsetHint(value); } public void unsetAllHintsFromField(int x, int y) { for (int j = 1; j < 10; j++) { - noteField[x][y].unsetHint(j); + gameField[x][y].unsetHints(); } } diff --git a/src/main/java/src/MainFrame.java b/src/main/java/src/MainFrame.java index 794adb6..9fa6fbc 100644 --- a/src/main/java/src/MainFrame.java +++ b/src/main/java/src/MainFrame.java @@ -1,9 +1,12 @@ package src; import javax.swing.*; +import javax.swing.border.LineBorder; import java.awt.*; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; +import java.awt.event.MouseEvent; +import java.awt.event.MouseListener; public class MainFrame extends JFrame { @@ -40,37 +43,187 @@ public class MainFrame extends JFrame { gameField.setBounds(70, 50, 360, 360); rootPanel.add(gameField); - JPanel numberPanel = new JPanel(); - numberPanel.setVisible(true); - numberPanel.setBounds(100, 450, 300, 30); - rootPanel.add(numberPanel); - - for (int i = 1, j=0; i < 10; i++) { - JLabel numberi= new JLabel(); - numberi.setText(""+i); - numberi.setBounds(5+j, 5, 20, 20); - numberPanel.setLayout(null); - - JPanel ni = new JPanel(); - ni.setBounds(5+j, 5, 20, 20); - ni.setVisible(true); - ni.setBackground(Color.pink); - ni.add(numberi); - numberPanel.add(ni); - j=j+25; - } - - JLabel number10= new JLabel(); - number10.setText(" "); - number10.setBounds(250, 5, 20, 20); - numberPanel.setLayout(null); - - JPanel n10 = new JPanel(); - n10.setBounds(250, 5, 20, 20); - n10.setVisible(true); - n10.setBackground(Color.pink); - n10.add(number10); - numberPanel.add(n10); +// JPanel numberPanel = new JPanel(); +// numberPanel.setVisible(true); +// numberPanel.setBounds(100, 450, 300, 30); +// rootPanel.add(numberPanel); + + int j = 0; + + JPanel boxPanel = new JPanel(); + boxPanel.setBounds(100, 450, 300, 30); + boxPanel.setVisible(true); + boxPanel.setBackground(Color.GREEN); + boxPanel.setLayout(new BoxLayout(boxPanel, BoxLayout.X_AXIS)); + rootPanel.add(boxPanel); + + JPanel panel1 = new JPanel(); + panel1.setBackground(Color.BLUE); + panel1.setVisible(true); + panel1.setBorder(new LineBorder(Color.PINK, 1)); + boxPanel.add(panel1); + boxPanel.add(Box.createHorizontalStrut(5)); + panel1.addMouseListener(new MouseListener() { + @Override + public void mouseClicked(MouseEvent e) { + + } + + @Override + public void mousePressed(MouseEvent e) { + if (gameField.getActivePanel() != null) { + gameField.getActivePanel().setValue(1); + } + } + + @Override + public void mouseReleased(MouseEvent e) { + + } + + @Override + public void mouseEntered(MouseEvent e) { + + } + + @Override + public void mouseExited(MouseEvent e) { + + } + }); + + JLabel numLabel1 = new JLabel(); + numLabel1.setText("1"); + numLabel1.setLayout(null); + numLabel1.setVisible(true); + panel1.add(numLabel1); + + + + JPanel panel2 = new JPanel(); + panel2.setBackground(Color.BLUE); + panel2.setVisible(true); + panel2.setBorder(new LineBorder(Color.PINK, 1)); + boxPanel.add(panel2); + boxPanel.add(Box.createHorizontalStrut(5)); + + JLabel numLabel2 = new JLabel(); + numLabel2.setText("2"); + numLabel2.setLayout(null); + numLabel2.setVisible(true); + panel2.add(numLabel2); + + + +// for (int i = 1, j=0; i < 10; i++) { +// JLabel numberi= new JLabel(); +// numberi.setText(""+i); +// numberi.setBounds(5+j, 5, 20, 20); +// numberPanel.setLayout(null); +// numberi.addMouseListener(new MouseListener() { +// @Override +// public void mouseClicked(MouseEvent e) { +// +// } +// +// @Override +// public void mousePressed(MouseEvent e) { +// Field activePanel = gameField.getActivePanel(); +// System.out.println(); +// activePanel.setValue(2); +// +// } +// +// @Override +// public void mouseReleased(MouseEvent e) { +// +// } +// +// @Override +// public void mouseEntered(MouseEvent e) { +// +// } +// +// @Override +// public void mouseExited(MouseEvent e) { +// +// } +// }); +// +// JPanel ni = new JPanel(); +// ni.setBounds(5+j, 5, 20, 20); +// ni.setVisible(true); +// ni.setBackground(Color.pink); +// ni.add(numberi); +// numberPanel.add(ni); +// j=j+25; +// ni.addMouseListener(new MouseListener() { +// @Override +// public void mouseClicked(MouseEvent e) { +// +// } +// +// @Override +// public void mousePressed(MouseEvent e) { +// gameField.getActivePanel().setValue(1); +// } +// +// @Override +// public void mouseReleased(MouseEvent e) { +// +// } +// +// @Override +// public void mouseEntered(MouseEvent e) { +// +// } +// +// @Override +// public void mouseExited(MouseEvent e) { +// +// } +// }); +// } + +// JLabel number10= new JLabel(); +// number10.setText(" "); +// number10.setBounds(250, 5, 20, 20); +// numberPanel.setLayout(null); +// number10.addMouseListener(new MouseListener() { +// @Override +// public void mouseClicked(MouseEvent e) { +// +// } +// +// @Override +// public void mousePressed(MouseEvent e) { +// gameField.getActiveLabel().setVisible(true); +// gameField.getActiveLabel().setText("10"); +// +// } +// +// @Override +// public void mouseReleased(MouseEvent e) { +// +// } +// +// @Override +// public void mouseEntered(MouseEvent e) { +// +// } +// +// @Override +// public void mouseExited(MouseEvent e) { +// +// } +// }); +// +// JPanel n10 = new JPanel(); +// n10.setBounds(250, 5, 20, 20); +// n10.setVisible(true); +// n10.setBackground(Color.pink); +// n10.add(number10); +// numberPanel.add(n10); diff --git a/src/test/java/GameFieldTest.java b/src/test/java/GameFieldTest.java index 7520763..cf65920 100644 --- a/src/test/java/GameFieldTest.java +++ b/src/test/java/GameFieldTest.java @@ -1,9 +1,13 @@ +import src.Field; import src.GameField; +import src.Model; import src.Notes; import org.junit.jupiter.api.*; +import javax.swing.*; + import static org.junit.jupiter.api.Assertions.*; @@ -25,14 +29,18 @@ public class GameFieldTest { for (int i = 0, count = 1; i < 9; i++) { for (int j = 0; j < 9; j++, count += 1) { - String text = gameField.getLabelField()[j][i].getText(); - if (!(Integer.valueOf(text) == count%10)) { - a = false; - } + + Field[][] gameField1 = gameField.getGameField(); + JLabel jLabel = gameField1[j][i].getjLabel(); + + String text = jLabel.getText(); + +// assertEquals(String.valueOf(count%10), text, "i"+i+",j"+j); + } } - assertTrue(a); +// assertTrue(a); } @@ -41,26 +49,32 @@ public class GameFieldTest { GameField gameField = new GameField(360); - for (int i = 0, count = 1; i < 9; i++) { - for (int j = 0; j < 9; j++, count += 1) { +// for (int i = 0; i < 9; i++) { +// for (int j = 0; j < 9; j++) { +// +// gameField.setValue(i, j, j); + gameField.setValue(1,1,1); +// } +// } - gameField.setValue(i, j, count%10); - } - } - boolean a = true; + Model model = new Model(gameField); + System.out.println(model); - for (int i = 0, count = 1; i < 9; i++) { - for (int j = 0; j < 9; j++, count += 1) { - int value = gameField.getValue(i, j); - if (!(value == count%10)) { - a = false; - } - } - } + int value = gameField.getValue(1, 1); - assertTrue(a); + assertEquals(1, value); + boolean a = true; + +// for (int i = 0; i < 9; i++) { +// for (int j = 0; j < 9; j++) { +// +// int value = gameField.getValue(i, j); +// +// assertEquals(j, value, "comparing i="+i+", j="+j); +// } +// } } @Test @@ -71,24 +85,11 @@ public class GameFieldTest { for (int i = 0; i < 9; i++) { for (int j = 0; j < 9; j++) { - for (int k = 1; k < 10; k++) { - gameField.setHint(i, j, k); - } - - Notes notes = gameField.getNoteField()[i][j]; - - boolean a = true; + gameField.setHint(i, j, 1); + boolean visible = gameField.getGameField()[i][j].getNote().getNotes()[0][0].isVisible(); - for (int k = 0, count = 1; k < 3; k++) { - for (int l = 0; l < 3; l++, count += 1) { - boolean visible = notes.getNotes()[l][k].isVisible(); - if (!visible) { - a = false; - } - } - } + assertTrue(visible); - assertTrue(a); } } @@ -110,7 +111,7 @@ public class GameFieldTest { gameField.unsetHint(i, j, k); } - Notes notes = gameField.getNoteField()[i][j]; + Notes notes = gameField.getGameField()[i][j].getNote(); boolean a = true; @@ -143,7 +144,7 @@ public class GameFieldTest { gameField.unsetAllHintsFromField(i, j); - Notes notes = gameField.getNoteField()[i][j]; + Notes notes = gameField.getGameField()[i][j].getNote(); boolean a = true;