feat: Configure Carousel version for saved states

The saved states folders differ in name for different carousels, an option to configure which version to show saved states for has been added to the preferences dialog.
This commit is contained in:
lantzelot-swe 2022-01-14 22:14:53 +01:00
parent 5f3e9b7e25
commit af69512a6f
11 changed files with 257 additions and 33 deletions

View File

@ -44,6 +44,7 @@ import se.lantz.manager.ScraperManager;
import se.lantz.model.MainViewModel;
import se.lantz.model.data.GameListData;
import se.lantz.model.data.ScraperFields;
import se.lantz.util.FileManager;
public class GameDetailsBackgroundPanel extends JPanel
{
@ -188,6 +189,7 @@ public class GameDetailsBackgroundPanel extends JPanel
systemSavesTabbedPane = new JTabbedPane();
systemSavesTabbedPane.addTab("System Settings", getSystemPanel());
systemSavesTabbedPane.addTab("Saved states", getSavesBackgroundPanel());
updateSavedStatesTabTitle();
}
return systemSavesTabbedPane;
}
@ -500,4 +502,11 @@ public class GameDetailsBackgroundPanel extends JPanel
return false;
}
}
public void updateSavedStatesTabTitle()
{
String carouselVersion = FileManager.getConfiguredSavedStatesCarouselVersion();
getSystemSavesTabbedPane().setTitleAt(1, "Saved States (Carousel " + carouselVersion + ")");
getSavesBackgroundPanel().resetCurrentGameReference();
}
}

View File

@ -260,4 +260,9 @@ public class MainPanel extends JPanel
{
getListPanel().reloadCurrentGameView();
}
public void updateSavedStatesTabTitle()
{
getGameDetailsBackgroundPanel().updateSavedStatesTabTitle();
}
}

View File

@ -99,14 +99,16 @@ public final class MainWindow extends JFrame
return menuBar;
}
public void refreshFavoritesLists()
public void refreshAfterPreferencesSave()
{
getJMenuBar().removeAll();
for (JMenu menu : menuManager.getMenues())
{
menuBar.add(menu);
}
getMainPanel().reloadCurrentGameView();
getMainPanel().updateSavedStatesTabTitle();
SwingUtilities.updateComponentTreeUI(this);
repaintAfterModifications();
}

View File

@ -1109,7 +1109,7 @@ public class MenuManager
prefDialog.savePreferences();
//Update favorites menu
setupEditMenu();
MainWindow.getInstance().refreshFavoritesLists();
MainWindow.getInstance().refreshAfterPreferencesSave();
//Refresh game views
uiModel.reloadGameViews();
//Set all games as selected

View File

@ -80,4 +80,12 @@ public class SaveStateBackgroundPanel extends JPanel
getSaveStatePanel3().commitEdits();
getSaveStatePanel4().commitEdits();
}
void resetCurrentGameReference()
{
getSaveStatePanel1().resetCurrentGameReference();
getSaveStatePanel2().resetCurrentGameReference();
getSaveStatePanel3().resetCurrentGameReference();
getSaveStatePanel4().resetCurrentGameReference();
}
}

View File

@ -311,7 +311,7 @@ public class SaveStatePanel extends JPanel
BufferedImage image = null;
if (!filename.isEmpty())
{
String fileName = model.getInfoModel().getGamesFile();
String fileName = SavedStatesManager.getGameFolderName(model.getInfoModel().getGamesFile());
logger.debug(fileName.toString());
Path saveFolderPath = new File("./saves/" + fileName).toPath();
@ -857,4 +857,9 @@ public class SaveStatePanel extends JPanel
}
return deleteButton;
}
void resetCurrentGameReference()
{
this.currentGameFile = "";
}
}

View File

@ -31,15 +31,18 @@ public class MiscPanel extends JPanel
private JPanel favoritesPanel;
private JLabel numberOfFavoritesLabel;
private JSpinner favoritesSpinner;
private SaveStatePrefPanel saveStatePrefPanel;
public MiscPanel(PreferencesModel model)
{
this.model = model;
GridBagLayout gridBagLayout = new GridBagLayout();
gridBagLayout.rowWeights = new double[]{0.0, 0.0, 1.0};
gridBagLayout.columnWeights = new double[]{1.0};
setLayout(gridBagLayout);
GridBagConstraints gbc_startupPanel = new GridBagConstraints();
gbc_startupPanel.insets = new Insets(5, 5, 5, 5);
gbc_startupPanel.insets = new Insets(5, 5, 5, 3);
gbc_startupPanel.weightx = 1.0;
gbc_startupPanel.anchor = GridBagConstraints.NORTHWEST;
gbc_startupPanel.fill = GridBagConstraints.BOTH;
@ -47,14 +50,21 @@ public class MiscPanel extends JPanel
gbc_startupPanel.gridy = 0;
add(getStartupPanel(), gbc_startupPanel);
GridBagConstraints gbc_favoritesPanel = new GridBagConstraints();
gbc_favoritesPanel.weighty = 1.0;
gbc_favoritesPanel.anchor = GridBagConstraints.NORTHWEST;
gbc_favoritesPanel.weightx = 1.0;
gbc_favoritesPanel.insets = new Insets(5, 5, 5, 5);
gbc_favoritesPanel.insets = new Insets(5, 5, 5, 3);
gbc_favoritesPanel.fill = GridBagConstraints.HORIZONTAL;
gbc_favoritesPanel.gridx = 0;
gbc_favoritesPanel.gridy = 1;
add(getFavoritesPanel(), gbc_favoritesPanel);
GridBagConstraints gbc_saveStatePrefPanel = new GridBagConstraints();
gbc_saveStatePrefPanel.insets = new Insets(5, 5, 5, 3);
gbc_saveStatePrefPanel.weighty = 1.0;
gbc_saveStatePrefPanel.anchor = GridBagConstraints.NORTHWEST;
gbc_saveStatePrefPanel.fill = GridBagConstraints.HORIZONTAL;
gbc_saveStatePrefPanel.gridx = 0;
gbc_saveStatePrefPanel.gridy = 2;
add(getSaveStatePrefPanel(), gbc_saveStatePrefPanel);
if (!Beans.isDesignTime())
{
model.addPropertyChangeListener(e -> modelChanged());
@ -195,4 +205,12 @@ public class MiscPanel extends JPanel
}
return favoritesSpinner;
}
private SaveStatePrefPanel getSaveStatePrefPanel() {
if (saveStatePrefPanel == null) {
saveStatePrefPanel = new SaveStatePrefPanel(this.model);
saveStatePrefPanel
.setBorder(new TitledBorder(null, "Saved states preferences", TitledBorder.LEADING, TitledBorder.TOP, null, null));
}
return saveStatePrefPanel;
}
}

View File

@ -0,0 +1,118 @@
package se.lantz.gui.preferences;
import java.awt.GridBagConstraints;
import java.awt.GridBagLayout;
import java.awt.Insets;
import java.awt.event.ItemEvent;
import java.awt.event.ItemListener;
import java.beans.Beans;
import javax.swing.ButtonGroup;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JRadioButton;
import se.lantz.model.PreferencesModel;
public class SaveStatePrefPanel extends JPanel
{
private JLabel infoLabel;
private JRadioButton v132RadioButton;
private JRadioButton v152RadioButton;
private final ButtonGroup buttonGroup = new ButtonGroup();
private PreferencesModel model;
public SaveStatePrefPanel(PreferencesModel model)
{
this.model = model;
GridBagLayout gridBagLayout = new GridBagLayout();
setLayout(gridBagLayout);
GridBagConstraints gbc_infoLabel = new GridBagConstraints();
gbc_infoLabel.insets = new Insets(10, 10, 10, 10);
gbc_infoLabel.weightx = 1.0;
gbc_infoLabel.fill = GridBagConstraints.HORIZONTAL;
gbc_infoLabel.anchor = GridBagConstraints.NORTHWEST;
gbc_infoLabel.gridx = 0;
gbc_infoLabel.gridy = 0;
add(getInfoLabel(), gbc_infoLabel);
GridBagConstraints gbc_v132RadioButton = new GridBagConstraints();
gbc_v132RadioButton.anchor = GridBagConstraints.WEST;
gbc_v132RadioButton.weightx = 1.0;
gbc_v132RadioButton.insets = new Insets(0, 40, 0, 0);
gbc_v132RadioButton.gridx = 0;
gbc_v132RadioButton.gridy = 1;
add(getV132RadioButton(), gbc_v132RadioButton);
GridBagConstraints gbc_v152RadioButton = new GridBagConstraints();
gbc_v152RadioButton.weighty = 1.0;
gbc_v152RadioButton.insets = new Insets(0, 40, 10, 0);
gbc_v152RadioButton.anchor = GridBagConstraints.NORTHWEST;
gbc_v152RadioButton.weightx = 1.0;
gbc_v152RadioButton.gridx = 0;
gbc_v152RadioButton.gridy = 2;
add(getV152RadioButton(), gbc_v152RadioButton);
if (!Beans.isDesignTime())
{
model.addPropertyChangeListener(e -> modelChanged());
//Trigger an initial read from the model
modelChanged();
}
}
private JLabel getInfoLabel()
{
if (infoLabel == null)
{
String info = "<html>Different versions of the Carousel adds the saved states in different folders. " +
"You have to choose which verison of the Carousel you want the manager to read the saved states for. " +
"Only saved states for one carousel version at a time is shown for the games in the game list views.</html>";
infoLabel = new JLabel(info);
}
return infoLabel;
}
private JRadioButton getV132RadioButton()
{
if (v132RadioButton == null)
{
v132RadioButton = new JRadioButton("Carousel version 1.3.2 and earlier.");
v132RadioButton.addItemListener(new ItemListener()
{
public void itemStateChanged(ItemEvent e)
{
if (v132RadioButton.isSelected())
{
model.setSavedStatesCarouselVersion(PreferencesModel.CAROUSEL_132);
}
}
});
buttonGroup.add(v132RadioButton);
}
return v132RadioButton;
}
private JRadioButton getV152RadioButton()
{
if (v152RadioButton == null)
{
v152RadioButton = new JRadioButton("Carousel version 1.5.2 and later.");
v152RadioButton.setSelected(true);
v152RadioButton.addItemListener(new ItemListener()
{
public void itemStateChanged(ItemEvent e)
{
if (v152RadioButton.isSelected())
{
model.setSavedStatesCarouselVersion(PreferencesModel.CAROUSEL_152);
}
}
});
buttonGroup.add(v152RadioButton);
}
return v152RadioButton;
}
private void modelChanged()
{
getV132RadioButton().setSelected(model.getSavedStatesCarouselVersion().equals(PreferencesModel.CAROUSEL_132));
}
}

View File

@ -26,6 +26,7 @@ import org.slf4j.LoggerFactory;
import se.lantz.gui.exports.PublishWorker;
import se.lantz.model.MainViewModel;
import se.lantz.model.PreferencesModel;
import se.lantz.model.SavedStatesModel;
import se.lantz.model.SavedStatesModel.SAVESTATE;
import se.lantz.util.ExceptionHandler;
@ -102,15 +103,15 @@ public class SavedStatesManager
//If the game has been renamed, make sure to rename the saves folder also
String oldFileName = model.getInfoModel().getOldGamesFile();
String newFileName = model.getInfoModel().getGamesFile();
File oldSaveFolder = new File(SAVES + oldFileName);
File oldSaveFolder = new File(SAVES + getGameFolderName(oldFileName));
if (!oldFileName.equals(newFileName) && oldSaveFolder.exists())
{
//Rename old folder to new name
oldSaveFolder.renameTo(new File(SAVES + model.getInfoModel().getGamesFile()));
oldSaveFolder.renameTo(new File(SAVES + getGameFolderName(model.getInfoModel().getGamesFile())));
}
String fileName = model.getInfoModel().getGamesFile();
Path saveFolder = new File(SAVES + fileName).toPath();
Path saveFolder = new File(SAVES + getGameFolderName(fileName)).toPath();
int numberofSaves = 0;
//Check which ones are available
Path mta0Path = saveFolder.resolve(MTA0);
@ -161,7 +162,7 @@ public class SavedStatesManager
{
savedStatesModel.resetProperties();
//Read from state directory, update model
String fileName = model.getInfoModel().getGamesFile();
String fileName = getGameFolderName(model.getInfoModel().getGamesFile());
if (!fileName.isEmpty())
{
//Check if folder is available
@ -330,7 +331,7 @@ public class SavedStatesManager
private void deleteSavedState(SAVESTATE state)
{
String fileName = model.getInfoModel().getGamesFile();
String fileName = getGameFolderName(model.getInfoModel().getGamesFile());
Path saveFolder = new File(SAVES + fileName).toPath();
try
{
@ -554,7 +555,8 @@ public class SavedStatesManager
public int getNumberOfSavedStatesForGame(String gameFileName)
{
return savedStatesMap.get(gameFileName) != null ? savedStatesMap.get(gameFileName) : 0;
String fileName = getGameFolderName(gameFileName);
return savedStatesMap.get(fileName) != null ? savedStatesMap.get(fileName) : 0;
}
public void checkEnablementOfPalNtscMenuItem(boolean check)
@ -568,7 +570,7 @@ public class SavedStatesManager
if (!fileName.isEmpty() && fileName.contains(".vsf"))
{
//Check if folder is available
Path saveFolder = new File(SAVES + fileName).toPath();
Path saveFolder = new File(SAVES + getGameFolderName(fileName)).toPath();
if (Files.exists(saveFolder))
{
//Check which ones are available
@ -587,7 +589,7 @@ public class SavedStatesManager
{
String gamesFile = model.getInfoModel().getGamesFile();
Path gameFilePath = new File(FileManager.GAMES + gamesFile).toPath();
Path firstSavedStatePath = new File(SAVES + gamesFile).toPath().resolve(VSZ0);
Path firstSavedStatePath = new File(SAVES + getGameFolderName(gamesFile)).toPath().resolve(VSZ0);
Path tempFilePath = new File(FileManager.GAMES + "temp.gz").toPath();
try
@ -613,4 +615,24 @@ public class SavedStatesManager
}
return false;
}
public static String getGameFolderName(String fileName)
{
String returnValue = "";
switch (FileManager.getConfiguredSavedStatesCarouselVersion())
{
case PreferencesModel.CAROUSEL_132:
returnValue = fileName;
break;
case PreferencesModel.CAROUSEL_152:
if (fileName.indexOf(".") > -1)
{
returnValue = fileName.substring(0, fileName.indexOf("."));
}
break;
default:
break;
}
return returnValue;
}
}

View File

@ -7,6 +7,9 @@ import se.lantz.util.FileManager;
public class PreferencesModel extends AbstractModel implements CommonInfoModel
{
public static final String CAROUSEL_132 = "1.3.2";
public static final String CAROUSEL_152 = "1.5.2";
public static final String PCUAE_VERSION_CHECK = "checkForPCUAEVersion";
public static final String MANGER_VERSION_CHECK = "checkForManagerVersion";
public static final String GENRE = "infoSlotGenre";
@ -20,12 +23,13 @@ public class PreferencesModel extends AbstractModel implements CommonInfoModel
public static final String DESCRIPTION_IT = "infoSlotdescriptionIt";
public static final String FAVORITESCOUNT = "favoritesCount";
public static final String JOYSTICK = "joystick";
public static final String SAVED_STATES_CAROUSEL = "savedStatesCarousel";
private boolean checkPCUAEVersionAtStartup = true;
private boolean checkManagerVersionAtStartup = true;
private String description = "For more Info on PCUAE look in The Help Menu. Main keys are CTRL + F1 for The Help Menu, CTRL + F3 for Carousel Version Changer, CTRL + F5 for Mode Changer, CTRL + F7 for PCUAE Option Menu, CTRL + SHIFT + F7 for Carousel Gamelist Changer.";
private String description =
"For more Info on PCUAE look in The Help Menu. Main keys are CTRL + F1 for The Help Menu, CTRL + F3 for Carousel Version Changer, CTRL + F5 for Mode Changer, CTRL + F7 for PCUAE Option Menu, CTRL + SHIFT + F7 for Carousel Gamelist Changer.";
private String descriptionDe = "";
private String descriptionFr = "";
private String descriptionEs = "";
@ -37,11 +41,13 @@ public class PreferencesModel extends AbstractModel implements CommonInfoModel
private int favoritesCount = 10;
private String joystickConfig = "J:2*:" + JoystickModel.DEFAULT_CONFIG;
private String savedStatesCarouselVersion = CAROUSEL_152;
public PreferencesModel()
{
Properties configuredProperties = FileManager.getConfiguredProperties();
setCheckManagerVersionAtStartup(Boolean.parseBoolean(configuredProperties.getProperty(MANGER_VERSION_CHECK, "true")));
setCheckManagerVersionAtStartup(Boolean
.parseBoolean(configuredProperties.getProperty(MANGER_VERSION_CHECK, "true")));
setCheckPCUAEVersionAtStartup(Boolean.parseBoolean(configuredProperties.getProperty(PCUAE_VERSION_CHECK, "true")));
setGenre(configuredProperties.getProperty(GENRE, genre));
setAuthor(configuredProperties.getProperty(AUTHOR, author));
@ -52,8 +58,10 @@ public class PreferencesModel extends AbstractModel implements CommonInfoModel
setDescriptionEs(configuredProperties.getProperty(DESCRIPTION_ES, descriptionEs));
setDescriptionIt(configuredProperties.getProperty(DESCRIPTION_IT, descriptionIt));
setYear(Integer.parseInt(configuredProperties.getProperty(YEAR, Integer.toString(year))));
setFavoritesCount(Integer.parseInt(configuredProperties.getProperty(FAVORITESCOUNT, Integer.toString(favoritesCount))));
setFavoritesCount(Integer
.parseInt(configuredProperties.getProperty(FAVORITESCOUNT, Integer.toString(favoritesCount))));
setJoystickConfig(configuredProperties.getProperty(JOYSTICK, joystickConfig));
setSavedStatesCarouselVersion(configuredProperties.getProperty(SAVED_STATES_CAROUSEL, CAROUSEL_152));
}
public boolean isCheckPCUAEVersionAtStartup()
@ -105,7 +113,6 @@ public class PreferencesModel extends AbstractModel implements CommonInfoModel
}
}
public String getDescriptionDe()
{
return descriptionDe;
@ -272,6 +279,21 @@ public class PreferencesModel extends AbstractModel implements CommonInfoModel
}
}
public String getSavedStatesCarouselVersion()
{
return savedStatesCarouselVersion;
}
public void setSavedStatesCarouselVersion(String savedStatesCarouselVersion)
{
String old = getSavedStatesCarouselVersion();
this.savedStatesCarouselVersion = savedStatesCarouselVersion;
if (!Objects.equals(old, savedStatesCarouselVersion))
{
notifyChange();
}
}
public void savePreferences()
{
Properties configuredProperties = FileManager.getConfiguredProperties();
@ -289,6 +311,7 @@ public class PreferencesModel extends AbstractModel implements CommonInfoModel
configuredProperties.put(YEAR, Integer.toString(year));
configuredProperties.put(FAVORITESCOUNT, Integer.toString(favoritesCount));
configuredProperties.put(JOYSTICK, joystickConfig);
configuredProperties.put(SAVED_STATES_CAROUSEL, savedStatesCarouselVersion);
FileManager.storeProperties();
}
}

View File

@ -80,6 +80,7 @@ public class FileManager
private static Properties fileProperties;
private static int currentNoOfFavorites = -1;
private static String currentJoystickConfig = "";
private static String currentSavedStatesCarouselVersion = "";
private MainViewModel model;
private InfoModel infoModel;
@ -625,7 +626,7 @@ public class FileManager
}
else
{
gamePathString = SavedStatesManager.SAVES + infoModel.getGamesFile() + "/" + savedStatesModel.getState1File();
gamePathString = SavedStatesManager.SAVES + SavedStatesManager.getGameFolderName(infoModel.getGamesFile()) + "/" + savedStatesModel.getState1File();
}
}
break;
@ -638,7 +639,7 @@ public class FileManager
}
else
{
gamePathString = SavedStatesManager.SAVES + infoModel.getGamesFile() + "/" + savedStatesModel.getState2File();
gamePathString = SavedStatesManager.SAVES + SavedStatesManager.getGameFolderName(infoModel.getGamesFile()) + "/" + savedStatesModel.getState2File();
}
break;
case Save2:
@ -650,7 +651,7 @@ public class FileManager
}
else
{
gamePathString = SavedStatesManager.SAVES + infoModel.getGamesFile() + "/" + savedStatesModel.getState3File();
gamePathString = SavedStatesManager.SAVES + SavedStatesManager.getGameFolderName(infoModel.getGamesFile()) + "/" + savedStatesModel.getState3File();
}
break;
case Save3:
@ -662,7 +663,7 @@ public class FileManager
}
else
{
gamePathString = SavedStatesManager.SAVES + infoModel.getGamesFile() + "/" + savedStatesModel.getState4File();
gamePathString = SavedStatesManager.SAVES + SavedStatesManager.getGameFolderName(infoModel.getGamesFile()) + "/" + savedStatesModel.getState4File();
}
break;
default:
@ -918,6 +919,7 @@ public class FileManager
//Reset to load again in getConfiguredNumberOfFavorites()
currentNoOfFavorites = -1;
currentJoystickConfig = "";
currentSavedStatesCarouselVersion = "";
try (OutputStream output = new FileOutputStream("./pcu.properties"))
{
// save properties to project root folder
@ -954,7 +956,8 @@ public class FileManager
//Only load once if not initialised. currentNoOfFavorites is reset when properties are stored.
if (currentNoOfFavorites == -1)
{
currentNoOfFavorites = Integer.parseInt(FileManager.getConfiguredProperties().getProperty(PreferencesModel.FAVORITESCOUNT, Integer.toString(10)));
currentNoOfFavorites = Integer.parseInt(FileManager.getConfiguredProperties()
.getProperty(PreferencesModel.FAVORITESCOUNT, Integer.toString(10)));
}
return currentNoOfFavorites;
}
@ -963,11 +966,22 @@ public class FileManager
{
if (currentJoystickConfig.isEmpty())
{
currentJoystickConfig = FileManager.getConfiguredProperties().getProperty(PreferencesModel.JOYSTICK, "J:2*:" + JoystickModel.DEFAULT_CONFIG);
currentJoystickConfig = FileManager.getConfiguredProperties().getProperty(PreferencesModel.JOYSTICK,
"J:2*:" + JoystickModel.DEFAULT_CONFIG);
}
return currentJoystickConfig;
}
public static String getConfiguredSavedStatesCarouselVersion()
{
if (currentSavedStatesCarouselVersion.isEmpty())
{
currentSavedStatesCarouselVersion = FileManager.getConfiguredProperties()
.getProperty(PreferencesModel.SAVED_STATES_CAROUSEL, PreferencesModel.CAROUSEL_152);
}
return currentSavedStatesCarouselVersion;
}
public static void backupDb(String targetFolderName)
{
File outputFolder = new File(BACKUP + "/" + targetFolderName + "/");