fix: add a delete button for saved states
Files are deleted from disk when the game is saved.
This commit is contained in:
parent
7d40e17db5
commit
178f8a0b7e
|
@ -67,6 +67,7 @@ public class SaveStatePanel extends JPanel
|
||||||
|
|
||||||
private FileNameExtensionFilter imagefilter =
|
private FileNameExtensionFilter imagefilter =
|
||||||
new FileNameExtensionFilter("png, gif, jpeg, bmp", "png", "gif", "jpg", "jpeg", "bmp");
|
new FileNameExtensionFilter("png, gif, jpeg, bmp", "png", "gif", "jpg", "jpeg", "bmp");
|
||||||
|
private JButton deleteButton;
|
||||||
|
|
||||||
public SaveStatePanel(MainViewModel model, SAVESTATE saveState)
|
public SaveStatePanel(MainViewModel model, SAVESTATE saveState)
|
||||||
{
|
{
|
||||||
|
@ -83,7 +84,7 @@ public class SaveStatePanel extends JPanel
|
||||||
gbc_screenshotLabel.weighty = 1.0;
|
gbc_screenshotLabel.weighty = 1.0;
|
||||||
gbc_screenshotLabel.gridheight = 3;
|
gbc_screenshotLabel.gridheight = 3;
|
||||||
gbc_screenshotLabel.anchor = GridBagConstraints.NORTHWEST;
|
gbc_screenshotLabel.anchor = GridBagConstraints.NORTHWEST;
|
||||||
gbc_screenshotLabel.insets = new Insets(1, 1, 0, 1);
|
gbc_screenshotLabel.insets = new Insets(1, 1, 0, 5);
|
||||||
gbc_screenshotLabel.gridx = 0;
|
gbc_screenshotLabel.gridx = 0;
|
||||||
gbc_screenshotLabel.gridy = 0;
|
gbc_screenshotLabel.gridy = 0;
|
||||||
add(getScreenshotLabel(), gbc_screenshotLabel);
|
add(getScreenshotLabel(), gbc_screenshotLabel);
|
||||||
|
@ -91,11 +92,12 @@ public class SaveStatePanel extends JPanel
|
||||||
gbc_timeTextField.fill = GridBagConstraints.HORIZONTAL;
|
gbc_timeTextField.fill = GridBagConstraints.HORIZONTAL;
|
||||||
gbc_timeTextField.anchor = GridBagConstraints.NORTHWEST;
|
gbc_timeTextField.anchor = GridBagConstraints.NORTHWEST;
|
||||||
gbc_timeTextField.weighty = 1.0;
|
gbc_timeTextField.weighty = 1.0;
|
||||||
gbc_timeTextField.insets = new Insets(0, 5, 5, 5);
|
gbc_timeTextField.insets = new Insets(0, 0, 5, 5);
|
||||||
gbc_timeTextField.gridx = 3;
|
gbc_timeTextField.gridx = 4;
|
||||||
gbc_timeTextField.gridy = 1;
|
gbc_timeTextField.gridy = 1;
|
||||||
add(getTimeField(), gbc_timeTextField);
|
add(getTimeField(), gbc_timeTextField);
|
||||||
GridBagConstraints gbc_snapshotTextField = new GridBagConstraints();
|
GridBagConstraints gbc_snapshotTextField = new GridBagConstraints();
|
||||||
|
gbc_snapshotTextField.gridwidth = 2;
|
||||||
gbc_snapshotTextField.weightx = 1.0;
|
gbc_snapshotTextField.weightx = 1.0;
|
||||||
gbc_snapshotTextField.anchor = GridBagConstraints.NORTHWEST;
|
gbc_snapshotTextField.anchor = GridBagConstraints.NORTHWEST;
|
||||||
gbc_snapshotTextField.insets = new Insets(0, 0, 5, 5);
|
gbc_snapshotTextField.insets = new Insets(0, 0, 5, 5);
|
||||||
|
@ -105,43 +107,50 @@ public class SaveStatePanel extends JPanel
|
||||||
add(getSnapshotTextField(), gbc_snapshotTextField);
|
add(getSnapshotTextField(), gbc_snapshotTextField);
|
||||||
GridBagConstraints gbc_snapshotButton = new GridBagConstraints();
|
GridBagConstraints gbc_snapshotButton = new GridBagConstraints();
|
||||||
gbc_snapshotButton.insets = new Insets(-1, 0, 5, 5);
|
gbc_snapshotButton.insets = new Insets(-1, 0, 5, 5);
|
||||||
gbc_snapshotButton.anchor = GridBagConstraints.NORTHWEST;
|
gbc_snapshotButton.anchor = GridBagConstraints.NORTHEAST;
|
||||||
gbc_snapshotButton.gridx = 2;
|
gbc_snapshotButton.gridx = 3;
|
||||||
gbc_snapshotButton.gridy = 1;
|
gbc_snapshotButton.gridy = 1;
|
||||||
add(getGameButton(), gbc_snapshotButton);
|
add(getGameButton(), gbc_snapshotButton);
|
||||||
GridBagConstraints gbc_timeLabel = new GridBagConstraints();
|
GridBagConstraints gbc_timeLabel = new GridBagConstraints();
|
||||||
gbc_timeLabel.anchor = GridBagConstraints.NORTHWEST;
|
gbc_timeLabel.anchor = GridBagConstraints.NORTHWEST;
|
||||||
gbc_timeLabel.insets = new Insets(5, 5, 0, 0);
|
gbc_timeLabel.insets = new Insets(5, 5, 5, 0);
|
||||||
gbc_timeLabel.gridx = 3;
|
gbc_timeLabel.gridx = 4;
|
||||||
gbc_timeLabel.gridy = 0;
|
gbc_timeLabel.gridy = 0;
|
||||||
add(getTimeLabel(), gbc_timeLabel);
|
add(getTimeLabel(), gbc_timeLabel);
|
||||||
GridBagConstraints gbc_snapshotLabel = new GridBagConstraints();
|
GridBagConstraints gbc_snapshotLabel = new GridBagConstraints();
|
||||||
|
gbc_snapshotLabel.gridwidth = 2;
|
||||||
gbc_snapshotLabel.weightx = 1.0;
|
gbc_snapshotLabel.weightx = 1.0;
|
||||||
gbc_snapshotLabel.insets = new Insets(5, 0, 0, 5);
|
gbc_snapshotLabel.insets = new Insets(5, 0, 5, 5);
|
||||||
gbc_snapshotLabel.anchor = GridBagConstraints.NORTHWEST;
|
gbc_snapshotLabel.anchor = GridBagConstraints.NORTHWEST;
|
||||||
gbc_snapshotLabel.gridx = 1;
|
gbc_snapshotLabel.gridx = 1;
|
||||||
gbc_snapshotLabel.gridy = 0;
|
gbc_snapshotLabel.gridy = 0;
|
||||||
add(getSnapshotLabel(), gbc_snapshotLabel);
|
add(getSnapshotLabel(), gbc_snapshotLabel);
|
||||||
GridBagConstraints gbc_screenshotButton = new GridBagConstraints();
|
GridBagConstraints gbc_screenshotButton = new GridBagConstraints();
|
||||||
gbc_screenshotButton.weightx = 1.0;
|
|
||||||
gbc_screenshotButton.anchor = GridBagConstraints.SOUTHWEST;
|
gbc_screenshotButton.anchor = GridBagConstraints.SOUTHWEST;
|
||||||
gbc_screenshotButton.insets = new Insets(0, 0, 0, 5);
|
gbc_screenshotButton.insets = new Insets(0, 0, 0, 5);
|
||||||
gbc_screenshotButton.gridx = 1;
|
gbc_screenshotButton.gridx = 1;
|
||||||
gbc_screenshotButton.gridy = 2;
|
gbc_screenshotButton.gridy = 2;
|
||||||
add(getScreenshotButton(), gbc_screenshotButton);
|
add(getScreenshotButton(), gbc_screenshotButton);
|
||||||
|
GridBagConstraints gbc_deleteButton = new GridBagConstraints();
|
||||||
|
gbc_deleteButton.gridwidth = 2;
|
||||||
|
gbc_deleteButton.anchor = GridBagConstraints.SOUTHEAST;
|
||||||
|
gbc_deleteButton.insets = new Insets(0, 0, 0, 5);
|
||||||
|
gbc_deleteButton.gridx = 2;
|
||||||
|
gbc_deleteButton.gridy = 2;
|
||||||
|
add(getDeleteButton(), gbc_deleteButton);
|
||||||
GridBagConstraints gbc_runButton = new GridBagConstraints();
|
GridBagConstraints gbc_runButton = new GridBagConstraints();
|
||||||
gbc_runButton.insets = new Insets(0, 0, 0, 5);
|
gbc_runButton.insets = new Insets(0, 0, 0, 5);
|
||||||
gbc_runButton.weighty = 1.0;
|
gbc_runButton.weighty = 1.0;
|
||||||
gbc_runButton.anchor = GridBagConstraints.SOUTHEAST;
|
gbc_runButton.anchor = GridBagConstraints.SOUTHEAST;
|
||||||
gbc_runButton.gridx = 3;
|
gbc_runButton.gridx = 4;
|
||||||
gbc_runButton.gridy = 2;
|
gbc_runButton.gridy = 2;
|
||||||
add(getRunButton(), gbc_runButton);
|
add(getRunButton(), gbc_runButton);
|
||||||
if (saveState != SAVESTATE.Save3)
|
if (saveState != SAVESTATE.Save3)
|
||||||
{
|
{
|
||||||
GridBagConstraints gbc_separator = new GridBagConstraints();
|
GridBagConstraints gbc_separator = new GridBagConstraints();
|
||||||
gbc_separator.fill = GridBagConstraints.HORIZONTAL;
|
gbc_separator.fill = GridBagConstraints.HORIZONTAL;
|
||||||
gbc_separator.insets = new Insets(5, 20, 0, 20);
|
gbc_separator.insets = new Insets(5, 5, 0, 5);
|
||||||
gbc_separator.gridwidth = 4;
|
gbc_separator.gridwidth = 5;
|
||||||
gbc_separator.gridx = 0;
|
gbc_separator.gridx = 0;
|
||||||
gbc_separator.gridy = 3;
|
gbc_separator.gridy = 3;
|
||||||
add(getSeparator(), gbc_separator);
|
add(getSeparator(), gbc_separator);
|
||||||
|
@ -193,6 +202,7 @@ public class SaveStatePanel extends JPanel
|
||||||
getSnapshotTextField().setText(getSnapshotFileName());
|
getSnapshotTextField().setText(getSnapshotFileName());
|
||||||
reloadScreen();
|
reloadScreen();
|
||||||
getRunButton().setEnabled(!getSnapshotTextField().getText().isEmpty());
|
getRunButton().setEnabled(!getSnapshotTextField().getText().isEmpty());
|
||||||
|
getDeleteButton().setEnabled(!getSnapshotTextField().getText().isEmpty());
|
||||||
getTimeField().setEnabled(!getSnapshotTextField().getText().isEmpty());
|
getTimeField().setEnabled(!getSnapshotTextField().getText().isEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -778,4 +788,44 @@ public class SaveStatePanel extends JPanel
|
||||||
}
|
}
|
||||||
setTimeToModel();
|
setTimeToModel();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private JButton getDeleteButton()
|
||||||
|
{
|
||||||
|
if (deleteButton == null)
|
||||||
|
{
|
||||||
|
deleteButton = new JButton("Delete");
|
||||||
|
deleteButton.addActionListener(new ActionListener()
|
||||||
|
{
|
||||||
|
public void actionPerformed(ActionEvent e)
|
||||||
|
{
|
||||||
|
int value = JOptionPane.showConfirmDialog(SaveStatePanel.this,
|
||||||
|
"Are you sure you want to delete the saved state?",
|
||||||
|
"Delete saved state",
|
||||||
|
JOptionPane.YES_NO_OPTION);
|
||||||
|
if (value == JOptionPane.YES_OPTION)
|
||||||
|
{
|
||||||
|
gamesFileUpdated = false;
|
||||||
|
switch (saveState)
|
||||||
|
{
|
||||||
|
case Save0:
|
||||||
|
stateModel.setState1Deleted(true);
|
||||||
|
break;
|
||||||
|
case Save1:
|
||||||
|
stateModel.setState2Deleted(true);
|
||||||
|
break;
|
||||||
|
case Save2:
|
||||||
|
stateModel.setState3Deleted(true);
|
||||||
|
break;
|
||||||
|
case Save3:
|
||||||
|
stateModel.setState4Deleted(true);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return deleteButton;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,13 +25,14 @@ import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import se.lantz.model.MainViewModel;
|
import se.lantz.model.MainViewModel;
|
||||||
import se.lantz.model.SavedStatesModel;
|
import se.lantz.model.SavedStatesModel;
|
||||||
|
import se.lantz.model.SavedStatesModel.SAVESTATE;
|
||||||
import se.lantz.util.ExceptionHandler;
|
import se.lantz.util.ExceptionHandler;
|
||||||
import se.lantz.util.FileManager;
|
import se.lantz.util.FileManager;
|
||||||
|
|
||||||
public class SavedStatesManager
|
public class SavedStatesManager
|
||||||
{
|
{
|
||||||
private static final Logger logger = LoggerFactory.getLogger(SavedStatesManager.class);
|
private static final Logger logger = LoggerFactory.getLogger(SavedStatesManager.class);
|
||||||
|
|
||||||
public static final String SAVES = "./saves/";
|
public static final String SAVES = "./saves/";
|
||||||
|
|
||||||
private static final String MTA0 = "0.mta";
|
private static final String MTA0 = "0.mta";
|
||||||
|
@ -75,6 +76,24 @@ public class SavedStatesManager
|
||||||
|
|
||||||
public void saveSavedStates()
|
public void saveSavedStates()
|
||||||
{
|
{
|
||||||
|
//First, check if any saved states has been deleted. Delete the corresponding files.
|
||||||
|
if (savedStatesModel.isState1Deleted())
|
||||||
|
{
|
||||||
|
deleteSavedState(SAVESTATE.Save0);
|
||||||
|
}
|
||||||
|
if (savedStatesModel.isState2Deleted())
|
||||||
|
{
|
||||||
|
deleteSavedState(SAVESTATE.Save1);
|
||||||
|
}
|
||||||
|
if (savedStatesModel.isState3Deleted())
|
||||||
|
{
|
||||||
|
deleteSavedState(SAVESTATE.Save2);
|
||||||
|
}
|
||||||
|
if (savedStatesModel.isState4Deleted())
|
||||||
|
{
|
||||||
|
deleteSavedState(SAVESTATE.Save3);
|
||||||
|
}
|
||||||
|
|
||||||
//If the game has been renamed, make sure to rename the saves folder also
|
//If the game has been renamed, make sure to rename the saves folder also
|
||||||
if (model.getInfoModel().isTitleChanged())
|
if (model.getInfoModel().isTitleChanged())
|
||||||
{
|
{
|
||||||
|
@ -306,6 +325,56 @@ public class SavedStatesManager
|
||||||
return this.importOverwrite;
|
return this.importOverwrite;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void deleteSavedState(SAVESTATE state)
|
||||||
|
{
|
||||||
|
String fileName = model.getInfoModel().getGamesFile();
|
||||||
|
Path saveFolder = new File(SAVES + fileName).toPath();
|
||||||
|
try
|
||||||
|
{
|
||||||
|
switch (state)
|
||||||
|
{
|
||||||
|
case Save0:
|
||||||
|
Path mta0Path = saveFolder.resolve(MTA0);
|
||||||
|
Path vsz0Path = saveFolder.resolve(VSZ0);
|
||||||
|
Path png0Path = saveFolder.resolve(PNG0);
|
||||||
|
Files.deleteIfExists(mta0Path);
|
||||||
|
Files.deleteIfExists(vsz0Path);
|
||||||
|
Files.deleteIfExists(png0Path);
|
||||||
|
break;
|
||||||
|
case Save1:
|
||||||
|
Path mta1Path = saveFolder.resolve(MTA1);
|
||||||
|
Path vsz1Path = saveFolder.resolve(VSZ1);
|
||||||
|
Path png1Path = saveFolder.resolve(PNG1);
|
||||||
|
Files.deleteIfExists(mta1Path);
|
||||||
|
Files.deleteIfExists(vsz1Path);
|
||||||
|
Files.deleteIfExists(png1Path);
|
||||||
|
break;
|
||||||
|
case Save2:
|
||||||
|
Path mta2Path = saveFolder.resolve(MTA2);
|
||||||
|
Path vsz2Path = saveFolder.resolve(VSZ2);
|
||||||
|
Path png2Path = saveFolder.resolve(PNG2);
|
||||||
|
Files.deleteIfExists(mta2Path);
|
||||||
|
Files.deleteIfExists(vsz2Path);
|
||||||
|
Files.deleteIfExists(png2Path);
|
||||||
|
break;
|
||||||
|
case Save3:
|
||||||
|
Path mta3Path = saveFolder.resolve(MTA3);
|
||||||
|
Path vsz3Path = saveFolder.resolve(VSZ3);
|
||||||
|
Path png3Path = saveFolder.resolve(PNG3);
|
||||||
|
Files.deleteIfExists(mta3Path);
|
||||||
|
Files.deleteIfExists(vsz3Path);
|
||||||
|
Files.deleteIfExists(png3Path);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch (IOException e)
|
||||||
|
{
|
||||||
|
ExceptionHandler.handleException(e, "Could not delete saved state files.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public void exportSavedStates(StringBuilder infoBuilder)
|
public void exportSavedStates(StringBuilder infoBuilder)
|
||||||
{
|
{
|
||||||
noFilesCopied = 0;
|
noFilesCopied = 0;
|
||||||
|
|
|
@ -4,6 +4,8 @@ import java.awt.image.BufferedImage;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import se.lantz.model.SavedStatesModel.SAVESTATE;
|
||||||
|
|
||||||
public class SavedStatesModel extends AbstractModel
|
public class SavedStatesModel extends AbstractModel
|
||||||
{
|
{
|
||||||
public static enum SAVESTATE {Save0, Save1, Save2, Save3};
|
public static enum SAVESTATE {Save0, Save1, Save2, Save3};
|
||||||
|
@ -32,6 +34,11 @@ public class SavedStatesModel extends AbstractModel
|
||||||
private String state3time = "00:00:00";
|
private String state3time = "00:00:00";
|
||||||
private String state4time = "00:00:00";
|
private String state4time = "00:00:00";
|
||||||
|
|
||||||
|
private boolean state1Deleted = false;
|
||||||
|
private boolean state2Deleted = false;
|
||||||
|
private boolean state3Deleted = false;
|
||||||
|
private boolean state4Deleted = false;
|
||||||
|
|
||||||
public String getState1PngFile()
|
public String getState1PngFile()
|
||||||
{
|
{
|
||||||
return state1PngFile;
|
return state1PngFile;
|
||||||
|
@ -295,6 +302,63 @@ public class SavedStatesModel extends AbstractModel
|
||||||
notifyChange();
|
notifyChange();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
public boolean isState1Deleted()
|
||||||
|
{
|
||||||
|
return state1Deleted;
|
||||||
|
}
|
||||||
|
public void setState1Deleted(boolean state1Deleted)
|
||||||
|
{
|
||||||
|
this.state1Deleted = state1Deleted;
|
||||||
|
state1PngImage = null;
|
||||||
|
state1PngFile = "";
|
||||||
|
state1Path = null;
|
||||||
|
state1time = "00:00:00";
|
||||||
|
state1File = "";
|
||||||
|
notifyChange();
|
||||||
|
}
|
||||||
|
public boolean isState2Deleted()
|
||||||
|
{
|
||||||
|
return state2Deleted;
|
||||||
|
}
|
||||||
|
public void setState2Deleted(boolean state2Deleted)
|
||||||
|
{
|
||||||
|
this.state2Deleted = state2Deleted;
|
||||||
|
state2PngImage = null;
|
||||||
|
state2PngFile = "";
|
||||||
|
state2Path = null;
|
||||||
|
state2time = "00:00:00";
|
||||||
|
state2File = "";
|
||||||
|
notifyChange();
|
||||||
|
}
|
||||||
|
public boolean isState3Deleted()
|
||||||
|
{
|
||||||
|
return state3Deleted;
|
||||||
|
}
|
||||||
|
public void setState3Deleted(boolean state3Deleted)
|
||||||
|
{
|
||||||
|
this.state3Deleted = state3Deleted;
|
||||||
|
state3PngImage = null;
|
||||||
|
state3PngFile = "";
|
||||||
|
state3Path = null;
|
||||||
|
state3time = "00:00:00";
|
||||||
|
state3File = "";
|
||||||
|
notifyChange();
|
||||||
|
}
|
||||||
|
public boolean isState4Deleted()
|
||||||
|
{
|
||||||
|
return state4Deleted;
|
||||||
|
}
|
||||||
|
public void setState4Deleted(boolean state4Deleted)
|
||||||
|
{
|
||||||
|
this.state4Deleted = state4Deleted;
|
||||||
|
state4PngImage = null;
|
||||||
|
state4PngFile = "";
|
||||||
|
state4Path = null;
|
||||||
|
state4time = "00:00:00";
|
||||||
|
state4File = "";
|
||||||
|
notifyChange();
|
||||||
|
}
|
||||||
|
|
||||||
public void resetProperties()
|
public void resetProperties()
|
||||||
{
|
{
|
||||||
state1PngFile = "";
|
state1PngFile = "";
|
||||||
|
@ -317,6 +381,10 @@ public class SavedStatesModel extends AbstractModel
|
||||||
state2File = "";
|
state2File = "";
|
||||||
state3File = "";
|
state3File = "";
|
||||||
state4File = "";
|
state4File = "";
|
||||||
|
state1Deleted = false;
|
||||||
|
state2Deleted = false;
|
||||||
|
state3Deleted = false;
|
||||||
|
state4Deleted = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void notifyChange()
|
public void notifyChange()
|
||||||
|
@ -337,5 +405,5 @@ public class SavedStatesModel extends AbstractModel
|
||||||
timeparts[2] = "00";
|
timeparts[2] = "00";
|
||||||
}
|
}
|
||||||
return timeparts[0] + ":" + timeparts[1] + ":" + timeparts[2];
|
return timeparts[0] + ":" + timeparts[1] + ":" + timeparts[2];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue