1
0
mirror of https://github.com/fazo96/AIrium.git synced 2025-01-25 11:54:20 +01:00

fixed settings loading

This commit is contained in:
Enrico Fasoli 2015-08-06 18:23:35 +02:00
parent 28029c2a66
commit 9cbbc7c9b2
4 changed files with 79 additions and 56 deletions

View File

@ -22,13 +22,19 @@ public class Log {
public static void log(int level, String msg) { public static void log(int level, String msg) {
if (level <= logLevel) { if (level <= logLevel) {
String s = "";
if (logListeners == null) { if (logListeners == null) {
logListeners = new ArrayList<LogListener>(); logListeners = new ArrayList<LogListener>();
} }
for (LogListener l : logListeners) { if (level == 0) {
l.onLog(level, msg); s = "[ERROR] ";
} else if (level == 2) {
s = "[DEBUG] ";
} }
System.out.println(msg); for (LogListener l : logListeners) {
l.onLog(level, s + msg);
}
System.out.println(s + msg);
} }
} }
@ -41,6 +47,7 @@ public class Log {
} }
public interface LogListener { public interface LogListener {
public abstract void onLog(int level, String msg); public abstract void onLog(int level, String msg);
} }

View File

@ -2,14 +2,11 @@ package com.mygdx.game;
import java.io.BufferedReader; import java.io.BufferedReader;
import java.io.File; import java.io.File;
import java.io.FileInputStream;
import java.io.FileReader; import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException; import java.io.IOException;
import java.io.PrintWriter; import java.io.PrintWriter;
import java.util.HashMap;
import java.util.Map; import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
/** /**
* Hangles File I/O for AIrium components. * Hangles File I/O for AIrium components.
@ -46,16 +43,19 @@ public class Serializer {
public static String serializeSettings(Map<String, Float> options) { public static String serializeSettings(Map<String, Float> options) {
String a = "# Settings file for use with AIrium.\n" String a = "# Settings file for use with AIrium.\n"
+ "# More information at http://github.com/fazo96/AIrium"; + "# More information at http://github.com/fazo96/AIrium\n";
for (Object o : options.entrySet().toArray()) { for (Object o : options.entrySet().toArray()) {
Map.Entry<String, Float> e = (Map.Entry<String, Float>) o; Map.Entry<String, Float> e = (Map.Entry<String, Float>) o;
a += e.getKey() + " = " + e.getValue() + "\n"; if (!e.getKey().equals("fps_limit")) { // dont save this one
a += e.getKey() + " = " + e.getValue() + "\n";
}
} }
return a; return a;
} }
public static void readSettings(String fileContent, Map<String, Float> m) { public static Map<String,Float> readSettings(String fileContent) {
int line = 0; int line = 0;
Map<String, Float> m = new HashMap<String, Float>();
for (String s : fileContent.split("\n")) { for (String s : fileContent.split("\n")) {
line++; line++;
if (s.startsWith("#")) { if (s.startsWith("#")) {
@ -67,12 +67,13 @@ public class Serializer {
if (ss.length != 2) { if (ss.length != 2) {
throw new Exception("Invalid string at line " + line); throw new Exception("Invalid string at line " + line);
} }
Log.log(Log.DEBUG,"Loading setting \""+ss[0].trim()+"\" with value \""+Float.parseFloat(ss[1].trim())+"\""); Log.log(Log.DEBUG, "Loading setting \"" + ss[0].trim() + "\" with value \"" + Float.parseFloat(ss[1].trim()) + "\"");
m.put(ss[0].trim(), Float.parseFloat(ss[1].trim())); m.put(ss[0].trim(), Float.parseFloat(ss[1].trim()));
} catch (Exception e) { } catch (Exception e) {
Log.log(Log.ERROR, e.getMessage()); Log.log(Log.ERROR, e.getMessage());
} }
} }
return m;
} }
public static String serializeBrain(float brainMap[][][]) { public static String serializeBrain(float brainMap[][][]) {

View File

@ -343,6 +343,7 @@ public class World implements Runnable {
* codes. * codes.
*/ */
public void fire(int eventCode) { public void fire(int eventCode) {
Log.log(Log.DEBUG, "Firing Event. Code: " + eventCode);
for (Listener f : listeners) { for (Listener f : listeners) {
f.on(eventCode); f.on(eventCode);
} }
@ -432,6 +433,11 @@ public class World implements Runnable {
this.multithreading = multithreading; this.multithreading = multithreading;
} }
public void replaceOptions(Map<String, Float> options) {
this.options = options;
reloadOptions();
}
public void restart() { public void restart() {
cmdRestart = true; cmdRestart = true;
} }

View File

@ -36,6 +36,7 @@ public class GUI extends javax.swing.JFrame implements LogListener, Listener {
private boolean shouldUpdateGUI = false; private boolean shouldUpdateGUI = false;
private final Thread guiUpdater; private final Thread guiUpdater;
private Map<String, Float> options; private Map<String, Float> options;
private boolean updatingSliders = false;
/** /**
* Creates new form GUI * Creates new form GUI
@ -876,42 +877,40 @@ public class GUI extends javax.swing.JFrame implements LogListener, Listener {
* Adjusts settings using values from the UI * Adjusts settings using values from the UI
*/ */
private void updateSettings() { private void updateSettings() {
currentFpsLimit.setText("" + fpsLimitSlider.getValue()); if (!updatingSliders) {
if (toggleFPSLimitCheckbox.isSelected()) { options.put("fps_limit", toggleFPSLimitCheckbox.isSelected() ? 0 : (float) fpsLimitSlider.getValue());
options.put("fps_limit", 0f); options.put("enable_multithreading", multithreadingCheckbox.isSelected() ? 1f : 0f);
} else { options.put("number_of_creatures", (float) nCreaturesSlider.getValue());
options.put("fps_limit", (float) fpsLimitSlider.getValue()); options.put("number_of_plants", (float) nPlantsSlider.getValue());
options.put("corpse_decay_rate", corpseDecaySlider.getValue() / 1000f);
options.put("enable_corpses", enableCorpsesCheckbox.isSelected() ? 1f : 0f);
options.put("world_width", (float) worldSizeSlider.getValue());
options.put("world_height", (float) worldSizeSlider.getValue());
topSizeSlider.setMaximum(nCreaturesSlider.getValue());
options.put("parents_count", (float) topSizeSlider.getValue());
options.put("creature_sight_range", (float) sightRangeSlider.getValue());
options.put("creature_hp_decay", (float) hpDecaySlider.getValue() / 1000);
options.put("max_ticks", (float) maxTicksSlider.getValue());
options.put("draw_view_cones", drawViewCones.isSelected() ? 1f : 0);
options.put("draw_sight_lines", drawSightLines.isSelected() ? 1f : 0);
options.put("nMutatedBrains", (float) nMutatedBrainsSlider.getValue() / 100);
options.put("nMutatedNeurons", (float) nMutatedNeuronsSlider.getValue() / 100);
options.put("nMutatedConnections", (float) nMutatedConnectionsSlider.getValue() / 100);
options.put("mutationFactor", (float) mutationFactorSlider.getValue() / 100);
} }
options.put("enable_multithreading", multithreadingCheckbox.isSelected() ? 1f : 0f); currentNMutatedNeurons.setText(String.format("%.2f", (float) nMutatedNeuronsSlider.getValue() / 100) + "%");
options.put("number_of_creatures", (float) nCreaturesSlider.getValue()); currentSightRange.setText(sightRangeSlider.getValue() + "");
options.put("number_of_plants", (float) nPlantsSlider.getValue()); currentNMutatedBrains.setText(String.format("%.2f", (float) nMutatedBrainsSlider.getValue() / 100) + "%");
options.put("corpse_decay_rate", corpseDecaySlider.getValue() / 1000f);
options.put("enable_corpses", enableCorpsesCheckbox.isSelected() ? 1f : 0f);
currentNCreatures.setText(nCreaturesSlider.getValue() + "");
currentNPlants.setText(nPlantsSlider.getValue() + "");
currentCorpseDecay.setText(corpseDecaySlider.getValue() / 1000f + "");
options.put("world_width", (float) worldSizeSlider.getValue());
options.put("world_height", (float) worldSizeSlider.getValue());
currentWorldSize.setText(worldSizeSlider.getValue() + ""); currentWorldSize.setText(worldSizeSlider.getValue() + "");
topSizeSlider.setMaximum(nCreaturesSlider.getValue());
currentTopSize.setText(topSizeSlider.getValue() + (topSizeSlider.getValue() <= 0 ? " (Auto)" : "")); currentTopSize.setText(topSizeSlider.getValue() + (topSizeSlider.getValue() <= 0 ? " (Auto)" : ""));
options.put("parents_count", (float) topSizeSlider.getValue());
options.put("creature_sight_range", (float) sightRangeSlider.getValue());
options.put("creature_hp_decay", (float) hpDecaySlider.getValue() / 1000);
options.put("max_ticks", (float) maxTicksSlider.getValue());
options.put("draw_view_cones", drawViewCones.isSelected() ? 1f : 0);
options.put("draw_sight_lines", drawSightLines.isSelected() ? 1f : 0);
currentMaxTicks.setText(maxTicksSlider.getValue() + ""); currentMaxTicks.setText(maxTicksSlider.getValue() + "");
currentHpDecay.setText(hpDecaySlider.getValue() / 1000f + ""); currentHpDecay.setText(hpDecaySlider.getValue() / 1000f + "");
currentSightRange.setText(sightRangeSlider.getValue() + "");
options.put("nMutatedBrains", (float) nMutatedBrainsSlider.getValue() / 100);
currentNMutatedBrains.setText(String.format("%.2f", (float) nMutatedBrainsSlider.getValue() / 100) + "%");
options.put("nMutatedNeurons", (float) nMutatedNeuronsSlider.getValue() / 100);
currentNMutatedNeurons.setText(String.format("%.2f", (float) nMutatedNeuronsSlider.getValue() / 100) + "%");
options.put("nMutatedConnections", (float) nMutatedConnectionsSlider.getValue() / 100);
currentNMutatedConnections.setText(String.format("%.2f", (float) nMutatedConnectionsSlider.getValue() / 100) + "%");
options.put("mutationFactor", (float) mutationFactorSlider.getValue() / 100);
currentMutationFactor.setText(String.format("%.2f", (float) mutationFactorSlider.getValue() / 100)); currentMutationFactor.setText(String.format("%.2f", (float) mutationFactorSlider.getValue() / 100));
currentFpsLimit.setText("" + fpsLimitSlider.getValue());
currentNCreatures.setText(nCreaturesSlider.getValue() + "");
currentNMutatedConnections.setText(String.format("%.2f", (float) nMutatedConnectionsSlider.getValue() / 100) + "%");
currentNPlants.setText(nPlantsSlider.getValue() + "");
currentCorpseDecay.setText(corpseDecaySlider.getValue() / 1000f + "");
if (game != null) { if (game != null) {
game.getWorld().reloadOptions(); game.getWorld().reloadOptions();
} }
@ -1077,6 +1076,7 @@ public class GUI extends javax.swing.JFrame implements LogListener, Listener {
return; return;
} }
Serializer.saveToFile(f, Serializer.serializeBrain(game.getWorld().getSelectedCreature().getBrain().getMap())); Serializer.saveToFile(f, Serializer.serializeBrain(game.getWorld().getSelectedCreature().getBrain().getMap()));
JOptionPane.showMessageDialog(this, "Done");
}//GEN-LAST:event_saveBrainBtnActionPerformed }//GEN-LAST:event_saveBrainBtnActionPerformed
private void loadBrainBtnActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_loadBrainBtnActionPerformed private void loadBrainBtnActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_loadBrainBtnActionPerformed
@ -1085,6 +1085,9 @@ public class GUI extends javax.swing.JFrame implements LogListener, Listener {
} }
updateGUI(); updateGUI();
File f = loadDialog(); File f = loadDialog();
if (f == null) {
return;
}
float map[][][] = Serializer.loadBrain(Serializer.loadFromFile(f)); float map[][][] = Serializer.loadBrain(Serializer.loadFromFile(f));
Creature c = (Creature) game.getWorld().spawnCreature(map); Creature c = (Creature) game.getWorld().spawnCreature(map);
game.getWorld().selectCreature(c); game.getWorld().selectCreature(c);
@ -1102,6 +1105,7 @@ public class GUI extends javax.swing.JFrame implements LogListener, Listener {
} }
String settings = Serializer.serializeSettings(options); String settings = Serializer.serializeSettings(options);
Serializer.saveToFile(f, settings); Serializer.saveToFile(f, settings);
JOptionPane.showMessageDialog(this, "Done");
}//GEN-LAST:event_saveSettingsBtnActionPerformed }//GEN-LAST:event_saveSettingsBtnActionPerformed
private void loadSettingsBtnActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_loadSettingsBtnActionPerformed private void loadSettingsBtnActionPerformed(java.awt.event.ActionEvent evt) {//GEN-FIRST:event_loadSettingsBtnActionPerformed
@ -1113,32 +1117,37 @@ public class GUI extends javax.swing.JFrame implements LogListener, Listener {
if (f == null) { if (f == null) {
return; return;
} }
Serializer.readSettings(Serializer.loadFromFile(f), options); options.putAll(Serializer.readSettings(Serializer.loadFromFile(f)));
/*if (game != null) {
game.getWorld().replaceOptions(options);
}*/
updateSettingsUI(); updateSettingsUI();
JOptionPane.showMessageDialog(this, "Done");
}//GEN-LAST:event_loadSettingsBtnActionPerformed }//GEN-LAST:event_loadSettingsBtnActionPerformed
/** /**
* Reads settings and adjusts UI sliders. * Reads settings and adjusts UI sliders.
*/ */
private void updateSettingsUI() { private void updateSettingsUI() {
fpsLimitSlider.setValue(options.get("fps_limit").intValue()); updatingSliders = true;
//fpsLimitSlider.setValue(Math.round(options.get("fps_limit")));
multithreadingCheckbox.setSelected(options.get("enable_multithreading") > 0f); multithreadingCheckbox.setSelected(options.get("enable_multithreading") > 0f);
nCreaturesSlider.setValue(options.get("number_of_creatures").intValue()); nCreaturesSlider.setValue(Math.round(options.get("number_of_creatures")));
topSizeSlider.setMaximum(nCreaturesSlider.getValue()); topSizeSlider.setMaximum(nCreaturesSlider.getValue());
nPlantsSlider.setValue(options.get("number_of_plants").intValue()); topSizeSlider.setValue(Math.round(options.get("parents_count")));
corpseDecaySlider.setValue((int) (options.get("corpse_decay_rate") * 1000)); nPlantsSlider.setValue(Math.round(options.get("number_of_plants")));
corpseDecaySlider.setValue(Math.round(options.get("corpse_decay_rate") * 1000));
enableCorpsesCheckbox.setSelected(options.get("enable_corpses") > 0f); enableCorpsesCheckbox.setSelected(options.get("enable_corpses") > 0f);
worldSizeSlider.setValue(options.get("world_height").intValue()); worldSizeSlider.setValue(Math.round(options.get("world_height")));
topSizeSlider.setValue(options.get("parents_count").intValue()); sightRangeSlider.setValue(Math.round(options.get("creature_sight_range")));
sightRangeSlider.setValue(options.get("creature_sight_range").intValue()); hpDecaySlider.setValue(Math.round(options.get("creature_hp_decay") * 1000));
hpDecaySlider.setValue((int) (options.get("creature_hp_decay") * 1000)); maxTicksSlider.setValue(Math.round(options.get("max_ticks")));
maxTicksSlider.setValue(options.get("max_ticks").intValue());
drawViewCones.setSelected(options.get("draw_view_cones") > 0f); drawViewCones.setSelected(options.get("draw_view_cones") > 0f);
drawSightLines.setSelected(options.get("draw_sight_lines") > 0f); drawSightLines.setSelected(options.get("draw_sight_lines") > 0f);
nMutatedBrainsSlider.setValue((int) (options.get("nMutatedBrains").intValue() * 100)); nMutatedBrainsSlider.setValue(Math.round(options.get("nMutatedBrains") * 100));
nMutatedNeuronsSlider.setValue((int) (options.get("nMutatedNeurons").intValue() * 100)); nMutatedNeuronsSlider.setValue(Math.round(options.get("nMutatedNeurons") * 100));
nMutatedConnectionsSlider.setValue((int) (options.get("nMutatedConnections").intValue() * 100)); nMutatedConnectionsSlider.setValue(Math.round(options.get("nMutatedConnections") * 100));
mutationFactorSlider.setValue((int) (options.get("mutationFactor").intValue() * 100)); mutationFactorSlider.setValue(Math.round(options.get("mutationFactor") * 100));
updateSettings(); updatingSliders = false;
} }
// Variables declaration - do not modify//GEN-BEGIN:variables // Variables declaration - do not modify//GEN-BEGIN:variables