maven finally works
parent
f63e15985f
commit
a7eab9a0b3
|
|
@ -1,11 +1,35 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<classpath>
|
<classpath>
|
||||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-17">
|
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-21">
|
||||||
<attributes>
|
<attributes>
|
||||||
<attribute name="module" value="true"/>
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
</attributes>
|
</attributes>
|
||||||
</classpathentry>
|
</classpathentry>
|
||||||
<classpathentry kind="con" path="org.eclipse.jdt.junit.JUNIT_CONTAINER/5"/>
|
<classpathentry exported="true" kind="con" path="org.eclipse.jdt.junit.JUNIT_CONTAINER/5"/>
|
||||||
<classpathentry kind="lib" path="src/main/java/de/hs_mannheim/informatik/mvn/domain/HitoriMain.java"/>
|
<classpathentry kind="src" output="target/classes" path="src/main/java">
|
||||||
<classpathentry kind="output" path="bin"/>
|
<attributes>
|
||||||
|
<attribute name="optional" value="true"/>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry kind="src" output="target/test-classes" path="src/test/java">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="optional" value="true"/>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
<attribute name="test" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry excluding="**" kind="src" output="target/test-classes" path="src/test/resources">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
<attribute name="test" value="true"/>
|
||||||
|
<attribute name="optional" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry kind="con" path="org.eclipse.m2e.MAVEN2_CLASSPATH_CONTAINER">
|
||||||
|
<attributes>
|
||||||
|
<attribute name="maven.pomderived" value="true"/>
|
||||||
|
</attributes>
|
||||||
|
</classpathentry>
|
||||||
|
<classpathentry kind="output" path="target/classes"/>
|
||||||
</classpath>
|
</classpath>
|
||||||
|
|
|
||||||
|
|
@ -10,8 +10,14 @@
|
||||||
<arguments>
|
<arguments>
|
||||||
</arguments>
|
</arguments>
|
||||||
</buildCommand>
|
</buildCommand>
|
||||||
|
<buildCommand>
|
||||||
|
<name>org.eclipse.m2e.core.maven2Builder</name>
|
||||||
|
<arguments>
|
||||||
|
</arguments>
|
||||||
|
</buildCommand>
|
||||||
</buildSpec>
|
</buildSpec>
|
||||||
<natures>
|
<natures>
|
||||||
|
<nature>org.eclipse.m2e.core.maven2Nature</nature>
|
||||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||||
</natures>
|
</natures>
|
||||||
</projectDescription>
|
</projectDescription>
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,235 @@
|
||||||
|
package de.hs_mannheim.informatik.mvn.domain;
|
||||||
|
|
||||||
|
import java.awt.CardLayout;
|
||||||
|
import java.awt.event.ActionEvent;
|
||||||
|
import java.awt.event.ActionListener;
|
||||||
|
import java.io.BufferedReader;
|
||||||
|
import java.io.BufferedWriter;
|
||||||
|
import java.io.FileNotFoundException;
|
||||||
|
import java.io.FileReader;
|
||||||
|
import java.io.FileWriter;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.time.LocalTime;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Comparator;
|
||||||
|
import java.util.Scanner;
|
||||||
|
import java.util.Stack;
|
||||||
|
import java.io.File;
|
||||||
|
|
||||||
|
import javax.swing.JButton;
|
||||||
|
import javax.swing.JFrame;
|
||||||
|
import javax.swing.JPanel;
|
||||||
|
|
||||||
|
import de.hs_mannheim.informatik.mvn.gui.GameGUI;
|
||||||
|
import de.hs_mannheim.informatik.mvn.gui.MenuGUI;
|
||||||
|
|
||||||
|
public class HitoriMain extends JFrame implements ActionListener{
|
||||||
|
|
||||||
|
private static String[] filepath = {"", ""};
|
||||||
|
|
||||||
|
public static void main(String[] args) throws FileNotFoundException{
|
||||||
|
new MenuGUI();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ablauf(CardLayout cl, JPanel main, String[] filepath) throws FileNotFoundException {
|
||||||
|
Stack<String> madeMoves = new Stack<>();
|
||||||
|
String[][] data = getData(filepath[0], Integer.parseInt(filepath[1]));
|
||||||
|
String[][] colors = makeColorArray(data.length);
|
||||||
|
JButton[][] buttons = makeButtonArray(data);
|
||||||
|
GameGUI.paintGame(cl, main, filepath, buttons, colors, madeMoves, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> readFromFile(String path){
|
||||||
|
ArrayList<String> lines = new ArrayList<>();
|
||||||
|
try (BufferedReader reader = new BufferedReader(new FileReader(path))) {
|
||||||
|
String line;
|
||||||
|
while ((line = reader.readLine()) != null) {
|
||||||
|
lines.add(line);
|
||||||
|
}
|
||||||
|
} catch (IOException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
return lines;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String[][] getData(String filepath, int rows) throws FileNotFoundException{
|
||||||
|
Scanner sc = new Scanner(new File(filepath));
|
||||||
|
String[][] data = new String[rows][rows];
|
||||||
|
int rowInt = 0;
|
||||||
|
while (sc.hasNextLine() && rowInt < rows) {
|
||||||
|
String line = sc.nextLine();
|
||||||
|
data[rowInt] = line.split(",");
|
||||||
|
rowInt++;
|
||||||
|
}
|
||||||
|
sc.close();
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public static String[][] makeColorArray(int size){
|
||||||
|
String[][] colors = new String[size][size];
|
||||||
|
for(int i=0;i<size;i++){
|
||||||
|
for(int j=0;j<size;j++){
|
||||||
|
colors[i][j] = "W";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return colors;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static JButton[][] makeButtonArray(String[][] data){
|
||||||
|
JButton[][] buttons = new JButton[data.length][data.length];
|
||||||
|
for(int i=0;i<data.length;i++){
|
||||||
|
for(int j=0;j<data.length;j++){
|
||||||
|
String number = data[i][j];
|
||||||
|
JButton b = new JButton(number);
|
||||||
|
buttons[i][j] = b;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return buttons;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean abgabeMöglich(String path, String[][] data, String[][] colors) throws FileNotFoundException{
|
||||||
|
boolean abgabeMöglich = false;
|
||||||
|
String[][] result = getResult(data, colors);
|
||||||
|
ArrayList<String> filteredData = getSolution(path, result);
|
||||||
|
String[][] ergebnis1 = getErgebnisArray(result, filteredData);
|
||||||
|
int count = 0;
|
||||||
|
for(int i=0;i<result.length;i++){
|
||||||
|
for(int j=0;j<result.length;j++){
|
||||||
|
if(result[i][j].equals(ergebnis1[i][j])){
|
||||||
|
} else {
|
||||||
|
count--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(count <0){
|
||||||
|
abgabeMöglich = false;
|
||||||
|
} else {
|
||||||
|
abgabeMöglich = true;
|
||||||
|
}
|
||||||
|
return abgabeMöglich;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String[] getCords(int i, int j){
|
||||||
|
String yKoordinate = String.valueOf(i);
|
||||||
|
String xKoordinate = String.valueOf(j);
|
||||||
|
String[] pos = {yKoordinate, xKoordinate};
|
||||||
|
return pos;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void totalResetButton(CardLayout cl, JPanel main, JButton[][] buttons, String[][] colors,Stack<String> madeMoves,String[][] data) throws FileNotFoundException{
|
||||||
|
madeMoves.clear();
|
||||||
|
for(int i = 0; i<data.length;i++){
|
||||||
|
for(int j = 0; j<data.length;j++){
|
||||||
|
colors[i][j] = "W";
|
||||||
|
buttons[i][j] = null;
|
||||||
|
}
|
||||||
|
JButton[][] buttons0 = makeButtonArray(data);
|
||||||
|
GameGUI.paintGame(cl, main, filepath, buttons0, colors, madeMoves, data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String[][] getResult(String[][] data, String[][] colors){
|
||||||
|
String[][] result = new String[data.length][data.length];
|
||||||
|
for(int i=0;i<data.length;i++){
|
||||||
|
for(int j=0;j<data.length;j++){
|
||||||
|
String farben = colors[i][j];
|
||||||
|
String lastColor = String.valueOf(farben.charAt(farben.length() - 1));
|
||||||
|
if(lastColor.equals("G")){
|
||||||
|
lastColor = "W";
|
||||||
|
}
|
||||||
|
result[i][j] = lastColor;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static ArrayList<String> getSolution(String path, String[][] result) throws FileNotFoundException{
|
||||||
|
Scanner sc = new Scanner(new File(path));
|
||||||
|
ArrayList<String> filteredData = new ArrayList<>();
|
||||||
|
boolean isUnderComment = false;
|
||||||
|
while (sc.hasNextLine()) {
|
||||||
|
String line = sc.nextLine().trim();
|
||||||
|
if (line.equals("//Lösung (schwarze Felder)")) {
|
||||||
|
isUnderComment = true;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (isUnderComment && !line.isEmpty()) {
|
||||||
|
String[] lineArray = line.split(",");
|
||||||
|
int num1 = Integer.parseInt(lineArray[0]);
|
||||||
|
int num2 = Integer.parseInt(lineArray[1]);
|
||||||
|
String newNum1 = String.valueOf(num1-1);
|
||||||
|
String newNum2 = String.valueOf(num2-1);
|
||||||
|
String newLine = newNum1+","+newNum2;
|
||||||
|
filteredData.add(newLine);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sc.close();
|
||||||
|
return filteredData;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String[][] getErgebnisArray(String[][] result, ArrayList<String> filteredData){
|
||||||
|
String[][] ergebnis = new String[result.length][result.length];
|
||||||
|
for(int i=0;i<result.length;i++){
|
||||||
|
for(int j=0;j<result.length;j++){
|
||||||
|
ergebnis[i][j] = "W";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (String index : filteredData) {
|
||||||
|
String[] parts = index.split(",");
|
||||||
|
int row = Integer.parseInt(parts[0].trim());
|
||||||
|
int col = Integer.parseInt(parts[1].trim());
|
||||||
|
if (row >= 0 && row < ergebnis.length && col >= 0 && col < ergebnis[row].length) {
|
||||||
|
ergebnis[row][col] = "B";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return ergebnis;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void sortByTime(String path) throws FileNotFoundException, IOException{
|
||||||
|
File file = new File(path);
|
||||||
|
ArrayList<Entry> entries = new ArrayList<>();
|
||||||
|
|
||||||
|
try (BufferedReader br = new BufferedReader(new FileReader(file))) {
|
||||||
|
String line;
|
||||||
|
while ((line = br.readLine()) != null) {
|
||||||
|
String[] parts = line.split(" ", 2);
|
||||||
|
String timeStr = parts[0];
|
||||||
|
String name = parts.length > 1 ? parts[1] : "";
|
||||||
|
|
||||||
|
String[] timeParts = timeStr.split(":");
|
||||||
|
int hour = Integer.parseInt(timeParts[0]);
|
||||||
|
int minute = Integer.parseInt(timeParts[1]);
|
||||||
|
LocalTime time = LocalTime.of(hour, minute);
|
||||||
|
|
||||||
|
entries.add(new Entry(time, name));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
entries.sort(Comparator.comparing(e -> e.time));
|
||||||
|
|
||||||
|
try (BufferedWriter bw = new BufferedWriter(new FileWriter(file))) {
|
||||||
|
for (Entry e : entries) {
|
||||||
|
String formattedTime = String.format("%02d:%02d", e.time.getHour(), e.time.getMinute());
|
||||||
|
bw.write(formattedTime + " " + e.name);
|
||||||
|
bw.newLine();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void actionPerformed(ActionEvent e) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Entry {
|
||||||
|
LocalTime time;
|
||||||
|
String name;
|
||||||
|
|
||||||
|
Entry(LocalTime time, String name) {
|
||||||
|
this.time = time;
|
||||||
|
this.name = name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,15 +1,15 @@
|
||||||
package src.main.java.de.hs_mannheim.informatik.mvn.domain;
|
package de.hs_mannheim.informatik.mvn.domain;
|
||||||
|
|
||||||
import java.io.BufferedWriter;
|
import java.io.BufferedWriter;
|
||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
import java.io.FileWriter;
|
import java.io.FileWriter;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.lang.System.Logger;
|
||||||
import java.util.Scanner;
|
import java.util.Scanner;
|
||||||
import org.apache.logging.log4j.LogManager;
|
|
||||||
import org.apache.logging.log4j.Logger;
|
|
||||||
|
|
||||||
public class LogHighscores {
|
public class LogHighscores {
|
||||||
private static final Logger logger = LogManager.getLogger(LogHighscore.class);
|
//private static final Logger logger = LogManager.getLogger(LogHighscores.class);
|
||||||
|
|
||||||
public static void newRecord(String path, String username, String time) throws FileNotFoundException {
|
public static void newRecord(String path, String username, String time) throws FileNotFoundException {
|
||||||
String timePart = time.substring("Zeit: ".length()).trim();
|
String timePart = time.substring("Zeit: ".length()).trim();
|
||||||
|
|
@ -26,7 +26,7 @@ public class LogHighscores {
|
||||||
sc.nextLine();
|
sc.nextLine();
|
||||||
}
|
}
|
||||||
sc.close();
|
sc.close();
|
||||||
|
/*
|
||||||
try (BufferedWriter writer = new BufferedWriter(new FileWriter(filepath, true))) {
|
try (BufferedWriter writer = new BufferedWriter(new FileWriter(filepath, true))) {
|
||||||
String eintrag = timePart + " " + username;
|
String eintrag = timePart + " " + username;
|
||||||
logger.info("Neuer Eintrag: {}", eintrag);
|
logger.info("Neuer Eintrag: {}", eintrag);
|
||||||
|
|
@ -36,5 +36,6 @@ public class LogHighscores {
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
logger.error("Fehler beim Schreiben in die Datei: " + filepath, e);
|
logger.error("Fehler beim Schreiben in die Datei: " + filepath, e);
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
package src.test.java.de.hs_mannheim.informatik.mvn.gui;
|
package de.hs_mannheim.informatik.mvn.gui;
|
||||||
|
|
||||||
import java.awt.BorderLayout;
|
import java.awt.BorderLayout;
|
||||||
import java.awt.CardLayout;
|
import java.awt.CardLayout;
|
||||||
|
|
@ -19,8 +19,8 @@ import javax.swing.JPanel;
|
||||||
import javax.swing.JTextField;
|
import javax.swing.JTextField;
|
||||||
import javax.swing.SwingUtilities;
|
import javax.swing.SwingUtilities;
|
||||||
|
|
||||||
import src.main.java.de.hs_mannheim.informatik.mvn.domain.HitoriMain;
|
import de.hs_mannheim.informatik.mvn.domain.HitoriMain;
|
||||||
import src.main.java.de.hs_mannheim.informatik.mvn.domain.LogHighscores;
|
import de.hs_mannheim.informatik.mvn.domain.LogHighscores;
|
||||||
|
|
||||||
public class GameGUI extends JFrame implements ActionListener {
|
public class GameGUI extends JFrame implements ActionListener {
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
package src.test.java.de.hs_mannheim.informatik.mvn.gui;
|
package de.hs_mannheim.informatik.mvn.gui;
|
||||||
|
|
||||||
import java.awt.BorderLayout;
|
import java.awt.BorderLayout;
|
||||||
import java.awt.CardLayout;
|
import java.awt.CardLayout;
|
||||||
|
|
@ -16,7 +16,7 @@ import javax.swing.JButton;
|
||||||
import javax.swing.JFrame;
|
import javax.swing.JFrame;
|
||||||
import javax.swing.JLabel;
|
import javax.swing.JLabel;
|
||||||
import javax.swing.JPanel;
|
import javax.swing.JPanel;
|
||||||
import src.main.java.de.hs_mannheim.informatik.mvn.domain.HitoriMain;
|
import de.hs_mannheim.informatik.mvn.domain.HitoriMain;
|
||||||
|
|
||||||
public class HighscoreGUI extends JFrame implements ActionListener {
|
public class HighscoreGUI extends JFrame implements ActionListener {
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
package src.test.java.de.hs_mannheim.informatik.mvn.gui;
|
package de.hs_mannheim.informatik.mvn.gui;
|
||||||
|
|
||||||
import java.awt.BorderLayout;
|
import java.awt.BorderLayout;
|
||||||
import java.awt.CardLayout;
|
import java.awt.CardLayout;
|
||||||
|
|
@ -13,7 +13,7 @@ import javax.swing.JButton;
|
||||||
import javax.swing.JFrame;
|
import javax.swing.JFrame;
|
||||||
import javax.swing.JLabel;
|
import javax.swing.JLabel;
|
||||||
import javax.swing.JPanel;
|
import javax.swing.JPanel;
|
||||||
import src.main.java.de.hs_mannheim.informatik.mvn.domain.HitoriMain;
|
import de.hs_mannheim.informatik.mvn.domain.HitoriMain;
|
||||||
|
|
||||||
public class MenuGUI extends JFrame implements ActionListener {
|
public class MenuGUI extends JFrame implements ActionListener {
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,12 +1,17 @@
|
||||||
package src.test.java.de.hs_mannheim.informatik.mvn.test;
|
package de.hs_mannheim.informatik.mvn.test;
|
||||||
|
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertEquals;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertFalse;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertTrue;
|
||||||
|
|
||||||
import static org.junit.jupiter.api.Assertions.*;
|
|
||||||
import org.junit.jupiter.api.Test;
|
|
||||||
import src.java.main.de.hs_mannheim.informatik.domain.HitoriMain;
|
|
||||||
import src.java.main.de.hs_mannheim.informatik.gui.GameGUI;
|
|
||||||
import java.io.FileNotFoundException;
|
import java.io.FileNotFoundException;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import de.hs_mannheim.informatik.mvn.domain.HitoriMain;
|
||||||
|
import de.hs_mannheim.informatik.mvn.gui.GameGUI;
|
||||||
|
|
||||||
class HitoriTest{
|
class HitoriTest{
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
Loading…
Reference in New Issue