get level length
This commit is contained in:
parent
4ccdb53aa0
commit
a80723c695
9 changed files with 73 additions and 107 deletions
20
pom.xml
20
pom.xml
|
@ -17,21 +17,11 @@
|
|||
<artifactId>json</artifactId>
|
||||
<version>20231013</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.google.code.gson</groupId>
|
||||
<artifactId>gson</artifactId>
|
||||
<version>2.8.9</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>commons-io</groupId>
|
||||
<artifactId>commons-io</artifactId>
|
||||
<version>2.7</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.formdev</groupId>
|
||||
<artifactId>flatlaf</artifactId>
|
||||
<version>3.4</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.alex1304.jdash</groupId>
|
||||
<artifactId>jdash-client</artifactId>
|
||||
|
@ -57,15 +47,15 @@
|
|||
<artifactId>commons-codec</artifactId>
|
||||
<version>1.15</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>com.google.guava</groupId>
|
||||
<artifactId>guava</artifactId>
|
||||
<version>31.0.1-jre</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.kohsuke</groupId>
|
||||
<artifactId>github-api</artifactId>
|
||||
<version>1.127</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>io.qtjambi</groupId>
|
||||
<artifactId>qtjambi</artifactId>
|
||||
<version>6.7.0</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
<build>
|
||||
|
|
|
@ -14,6 +14,7 @@ import javax.swing.JTextArea;
|
|||
|
||||
import api.GetApiData;
|
||||
import gui.MainGUI;
|
||||
import readsafefile.SafeFileManager;
|
||||
import settingsfunctions.LoadSettings;
|
||||
import settingsfunctions.MigrateData;
|
||||
|
||||
|
@ -98,9 +99,6 @@ public class DownloadLevels {
|
|||
MigrateData migrate = new MigrateData();
|
||||
migrate.migrateData();
|
||||
|
||||
RequestLevelLength req = new RequestLevelLength();
|
||||
req.request();
|
||||
|
||||
try {
|
||||
gui.build();
|
||||
} catch (IOException e) {
|
||||
|
|
|
@ -1,51 +0,0 @@
|
|||
package data;
|
||||
|
||||
import api.GetApiData;
|
||||
import database.Sqlite;
|
||||
import gui.LoadingStatus;
|
||||
|
||||
public class RequestLevelLength {
|
||||
|
||||
GetApiData data = new GetApiData();
|
||||
FetchData fetch = new FetchData();
|
||||
Sqlite sql = new Sqlite("levels");
|
||||
LoadingStatus status = new LoadingStatus();
|
||||
|
||||
public void request() {
|
||||
|
||||
sql.queryData("levels");
|
||||
|
||||
status.initialize();
|
||||
status.changeState("API wird auf Levellänge abgefragt...");
|
||||
|
||||
Thread thread = new Thread(new Runnable( ) {
|
||||
|
||||
|
||||
@Override
|
||||
public void run() {
|
||||
|
||||
for(int i = 0; i < ManageFiles.getMissinglevels().size(); i++) {
|
||||
status.update(sql.getLevelname().get(sql.getRawLevelNames().indexOf(sql.getRawLevelNames().get(i))), i);
|
||||
|
||||
sql.modifyData(sql.getLevelname().get(sql.getRawLevelNames().indexOf(sql.getRawLevelNames().get(i))),
|
||||
Boolean.parseBoolean(sql.getCompleted().get(i).toString()),
|
||||
sql.getAttempts().get(i).intValue(),
|
||||
sql.getLocked().get(i).booleanValue(),
|
||||
sql.getPbarr().get(i),
|
||||
"" + data.getLevelLength(Integer.parseInt(sql.getLevelID().get(sql.getRawLevelNames().indexOf(ManageFiles.getMissinglevels().get(i)))))
|
||||
);
|
||||
try {
|
||||
Thread.sleep(200);
|
||||
} catch (InterruptedException e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
thread.start();
|
||||
|
||||
|
||||
}
|
||||
|
||||
}
|
|
@ -214,7 +214,7 @@ public class Sqlite {
|
|||
status = LoadingStatus.getInstance(); // Holen der Singleton-Instanz
|
||||
|
||||
status.initialize();
|
||||
status.changeState("Datenbank wird sortiert...");
|
||||
|
||||
|
||||
ArrayList<String> levelnamelocal = new ArrayList<String>();
|
||||
ArrayList<String> levelIDlocal = new ArrayList<String>();
|
||||
|
@ -248,6 +248,8 @@ status = LoadingStatus.getInstance(); // Holen der Singleton-Instanz
|
|||
|
||||
int index = 0;
|
||||
|
||||
status.changeState("Datenbank wird sortiert...", maxPlacement);
|
||||
|
||||
// Durchlaufen Sie die Platzierungen und holen Sie die Daten entsprechend
|
||||
for (int i = 1; i <= maxPlacement; i++) {
|
||||
String sql = "SELECT * FROM " + tablename + " WHERE placement = " + i;
|
||||
|
@ -278,7 +280,7 @@ status = LoadingStatus.getInstance(); // Holen der Singleton-Instanz
|
|||
// Erstelle eine neue Tabelle mit dem ursprünglichen Namen
|
||||
createNewTable(tablename);
|
||||
|
||||
status.changeState("Daten werden in neue Tabelle migriert...");
|
||||
status.changeState("Daten werden in neue Tabelle migriert...", levelnamelocal.size());
|
||||
|
||||
// Füge Daten in die neue Tabelle ein
|
||||
String insert = "INSERT INTO " + tablename + " (placement, levelname, levelnameRaw, levelID, author, creators, verifier, verificationLink, percentToQualify, records, attempts, completed, locked, personalBest, levelLength) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)";
|
||||
|
|
|
@ -70,8 +70,8 @@ public class LoadingStatus {
|
|||
main.dispose();
|
||||
}
|
||||
|
||||
public void changeState(String state) {
|
||||
bar.setMaximum(data.allLevels().size());
|
||||
public void changeState(String state, int arrsize) {
|
||||
bar.setMaximum(arrsize);
|
||||
bar.setValue(0);
|
||||
info.setText(state);
|
||||
area.setText("");
|
||||
|
|
|
@ -36,6 +36,7 @@ import javax.swing.JScrollPane;
|
|||
import javax.swing.JTextField;
|
||||
import javax.swing.SwingConstants;
|
||||
|
||||
import api.GetApiData;
|
||||
import data.SortData;
|
||||
import database.Sqlite;
|
||||
|
||||
|
@ -59,6 +60,7 @@ public class MainGUI {
|
|||
public JLabel idshow = new JLabel("ID");
|
||||
public JLabel qualify = new JLabel("Qualifikation");
|
||||
public JLabel attemptslabel = new JLabel("Attempts");
|
||||
public JLabel lengthLabel = new JLabel("Länge");
|
||||
public JCheckBox filtercompleted = new JCheckBox("Nach geschafft filtern");
|
||||
public Button copyid = new Button("Level ID kopieren");
|
||||
public Button showinfos = new Button("Mehr Infos anzeigen");
|
||||
|
@ -83,6 +85,8 @@ public class MainGUI {
|
|||
Sqlite data = new Sqlite("levels");
|
||||
data.queryData("levels");
|
||||
|
||||
GetApiData api = new GetApiData();
|
||||
|
||||
//sort.sort();
|
||||
|
||||
gridLayout.setRows(data.getLevelname().size());
|
||||
|
@ -117,19 +121,21 @@ public class MainGUI {
|
|||
|
||||
idshow.setBounds(10, 110, 164, 30);
|
||||
|
||||
copyid.setBounds(10, 190, 164, 30);
|
||||
copyid.setBounds(10, 210, 164, 30);
|
||||
|
||||
qualify.setBounds(10, 130, 164, 30);
|
||||
|
||||
attemptslabel.setBounds(10, 150, 164, 30);
|
||||
|
||||
lengthLabel.setBounds(10, 170, 164, 30);
|
||||
|
||||
settings.setBounds(1, 1, 60, 60);
|
||||
settings.setFont(settings.getFont().deriveFont(30f));
|
||||
settings.setBackground(Color.LIGHT_GRAY);
|
||||
|
||||
showinfos.setBounds(12, 237, 160, 30);
|
||||
showinfos.setBounds(12, 257, 160, 30);
|
||||
|
||||
showcalc.setBounds(12, 283, 160, 30);
|
||||
showcalc.setBounds(12, 303, 160, 30);
|
||||
|
||||
startgame.setBounds(12, 560, 160, 30);
|
||||
|
||||
|
@ -143,7 +149,7 @@ public class MainGUI {
|
|||
elements.infopanel().setVisible(false);
|
||||
|
||||
separator.setBounds(0, 30, 300, 30);
|
||||
separator2.setBounds(0 ,160, 400, 30);
|
||||
separator2.setBounds(0 ,180, 400, 30);
|
||||
|
||||
creator.setBounds(10, 50, 164, 30);
|
||||
|
||||
|
@ -310,7 +316,7 @@ public class MainGUI {
|
|||
|
||||
contents.addMouseListener(new MouseListener() {
|
||||
@Override
|
||||
public void mouseClicked(MouseEvent e) {
|
||||
public void mouseClicked(MouseEvent e) {
|
||||
showinfos.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
|
@ -328,14 +334,30 @@ public class MainGUI {
|
|||
attemptslabel.setText("Attempts: " + data.getAttempts().get(index));
|
||||
level.setVerticalAlignment(SwingConstants.CENTER);
|
||||
|
||||
String levellength = data.getLevelLength().get(index);
|
||||
lengthLabel.setText("Länge: lädt...");
|
||||
|
||||
if(data.getLevelLength().get(index).equals("N/A")) {
|
||||
if(req == 0) {
|
||||
levellength = api.getLevelLength(Integer.parseInt(data.getLevelID().get(index)));
|
||||
data.modifyData(data.getLevelname().get(index), comp[index], Integer.parseInt(attempts.getText()), lockbool[index], data.getPbarr().get(index), levellength);
|
||||
System.out.println("request");
|
||||
}
|
||||
}
|
||||
|
||||
lengthLabel.setText("Länge: " + levellength);
|
||||
|
||||
copyid.addActionListener(new ActionListener() {
|
||||
@Override
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
StringSelection stringSelection = new StringSelection(data.getLevelID().get(index));
|
||||
Clipboard clipboard = Toolkit.getDefaultToolkit().getSystemClipboard();
|
||||
clipboard.setContents(stringSelection, null);
|
||||
clipboard.setContents(stringSelection, null);
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
}
|
||||
@Override
|
||||
public void mousePressed(MouseEvent e) {
|
||||
|
@ -556,6 +578,7 @@ public class MainGUI {
|
|||
elements.infopanel().add(showinfos);
|
||||
elements.infopanel().add(attemptslabel);
|
||||
elements.infopanel().add(showcalc);
|
||||
elements.infopanel().add(lengthLabel);
|
||||
// elements.infopanel().add(startgame);
|
||||
|
||||
main.add(search);
|
||||
|
|
|
@ -3,7 +3,6 @@
|
|||
requires org.json;
|
||||
requires org.apache.commons.io;
|
||||
requires java.datatransfer;
|
||||
requires com.formdev.flatlaf;
|
||||
requires jdash.client;
|
||||
requires jdash.common;
|
||||
requires jlayer;
|
||||
|
|
|
@ -17,6 +17,11 @@ public class ReadAttemptsFromXML {
|
|||
public Map<String, String> newbestMap = new HashMap<>();
|
||||
public Map<String, String> lengthMap = new HashMap<>();
|
||||
|
||||
public Map<String, String> getLengthMap() {
|
||||
System.out.println("size getLengthMap in function: " + lengthMap.size());
|
||||
return lengthMap;
|
||||
}
|
||||
|
||||
public void readAttempts() {
|
||||
try {
|
||||
File xmlFile = new File("C:\\ExtremeDemonList\\userdata\\CCGameManager.dat.xml");
|
||||
|
@ -66,20 +71,15 @@ public class ReadAttemptsFromXML {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if(lengthValue != null) {
|
||||
lengthMap.put(currentLevelID, lengthValue);
|
||||
}
|
||||
|
||||
if (attemptsValue != null && percentValue != null) {
|
||||
|
||||
if (attemptsValue != null && percentValue != null && lengthValue != null) {
|
||||
tempAttempts.put(currentLevelID, attemptsValue ); // + "," + percentValue
|
||||
newbestMap.put(currentLevelID, percentValue);
|
||||
|
||||
lengthMap.put(currentLevelID, lengthValue);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
System.out.println("lengthmap size: " + lengthMap.size());
|
||||
attempts.putAll(tempAttempts);
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
|
|
|
@ -1,14 +1,21 @@
|
|||
package readsafefile;
|
||||
|
||||
import java.io.IOException;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import data.FetchData;
|
||||
import data.ManageFiles;
|
||||
import database.Sqlite;
|
||||
import gui.AttemptsProgress;
|
||||
|
||||
public class SafeFileManager {
|
||||
|
||||
private String[] lengthArr = {"Tiny", "Short", "Medium", "Long", "XL", "Platformer", "N/A"};
|
||||
private String[] lengthArr = {"TINY", "SHORT", "MEDIUM", "LONG", "XL", "PLATFORMER", "N/A"};
|
||||
public Map<String, String> lengthComp = new HashMap<>();
|
||||
private Sqlite database = new Sqlite("levels");
|
||||
private ReadAttemptsFromXML read = new ReadAttemptsFromXML();
|
||||
|
||||
public void DecryptSafeFile() throws IOException {
|
||||
DecryptXOR.decryptAndWriteFiles();
|
||||
|
@ -16,14 +23,11 @@ public class SafeFileManager {
|
|||
|
||||
public void ReadIndexAttempts() throws IOException {
|
||||
|
||||
read.readAttempts();
|
||||
|
||||
AttemptsProgress prog = new AttemptsProgress();
|
||||
prog.build();
|
||||
|
||||
Thread thread = new Thread(new Runnable() {
|
||||
|
||||
@Override
|
||||
public void run() {
|
||||
Sqlite database = new Sqlite("levels");
|
||||
database.queryData("levels");
|
||||
FetchData fetch = new FetchData();
|
||||
try {
|
||||
|
@ -32,20 +36,19 @@ public class SafeFileManager {
|
|||
e.printStackTrace();
|
||||
}
|
||||
|
||||
ReadAttemptsFromXML read = new ReadAttemptsFromXML();
|
||||
System.out.println("size lengthMap: " + read.getLengthMap().size());
|
||||
|
||||
lengthComp.putAll(read.lengthMap);
|
||||
|
||||
|
||||
read.readAttempts();
|
||||
|
||||
String attempts;
|
||||
String percent;
|
||||
String length;
|
||||
for(int i = 0; i < database.getLevelID().size(); i++) {
|
||||
attempts = read.attempts.get(database.getLevelID().get(i));
|
||||
percent = read.newbestMap.get(database.getLevelID().get(i));
|
||||
|
||||
if(read.lengthMap.get(database.getLevelID().get(i)) != null) {
|
||||
System.out.println(lengthArr[Integer.parseInt(read.lengthMap.get(database.getLevelID().get(i)))]);
|
||||
}
|
||||
|
||||
length = read.lengthMap.get(database.getLevelID().get(i));
|
||||
|
||||
if(attempts == null) {
|
||||
attempts = 0 + "";
|
||||
|
@ -53,14 +56,16 @@ public class SafeFileManager {
|
|||
if(percent == null) {
|
||||
percent = 0 + "";
|
||||
}
|
||||
if(length == null) {
|
||||
length = 6 + "";
|
||||
}
|
||||
|
||||
prog.update(database.getLevelname().get(i), Integer.parseInt(attempts), Integer.parseInt(percent), i);
|
||||
if(!database.getLocked().get(i)) {
|
||||
database.modifyData(database.getLevelname().get(i), Boolean.parseBoolean(database.getCompleted().get(i)), Integer.parseInt(attempts), database.getLocked().get(i), percent, database.getLevelLength().get(i));
|
||||
database.modifyData(database.getLevelname().get(i), Boolean.parseBoolean(database.getCompleted().get(i)), Integer.parseInt(attempts), database.getLocked().get(i), percent, lengthArr[Integer.parseInt(length)]);
|
||||
}
|
||||
}
|
||||
prog.close();
|
||||
}
|
||||
});
|
||||
thread.start();
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue