mirror of https://github.com/stella-emu/stella.git
add HighScoresDialog to LauncherDialog
remove high scores debug events add Dragster data to stella.pro
This commit is contained in:
parent
23ec31110b
commit
bac7b0552e
|
@ -347,7 +347,7 @@ uInt32 HighScoresManager::numAddrBytes(const Properties& props) const
|
||||||
Int32 HighScoresManager::player(uInt16 addr, uInt32 numPlayers, bool zeroBased) const
|
Int32 HighScoresManager::player(uInt16 addr, uInt32 numPlayers, bool zeroBased) const
|
||||||
{
|
{
|
||||||
if (!myOSystem.hasConsole())
|
if (!myOSystem.hasConsole())
|
||||||
return -1;
|
return DEFAULT_PLAYER;
|
||||||
|
|
||||||
Int32 player = peek(addr);
|
Int32 player = peek(addr);
|
||||||
Int32 bits = ceil(log(numPlayers + (!zeroBased ? 1 : 0))/log(2));
|
Int32 bits = ceil(log(numPlayers + (!zeroBased ? 1 : 0))/log(2));
|
||||||
|
@ -393,7 +393,7 @@ Int32 HighScoresManager::variation(uInt16 addr, bool varBCD, bool zeroBased,
|
||||||
uInt32 numVariations) const
|
uInt32 numVariations) const
|
||||||
{
|
{
|
||||||
if (!myOSystem.hasConsole())
|
if (!myOSystem.hasConsole())
|
||||||
return -1;
|
return DEFAULT_VARIATION;
|
||||||
|
|
||||||
Int32 var = peek(addr);
|
Int32 var = peek(addr);
|
||||||
Int32 bits = ceil(log(numVariations + (!zeroBased ? 1 : 0))/log(2));
|
Int32 bits = ceil(log(numVariations + (!zeroBased ? 1 : 0))/log(2));
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
|
|
||||||
class OSystem;
|
class OSystem;
|
||||||
|
|
||||||
|
#include "Props.hxx"
|
||||||
|
|
||||||
namespace HSM {
|
namespace HSM {
|
||||||
static const uInt32 MAX_PLAYERS = 4;
|
static const uInt32 MAX_PLAYERS = 4;
|
||||||
static const uInt32 MAX_ADDR_CHARS = 4;
|
static const uInt32 MAX_ADDR_CHARS = 4;
|
||||||
|
@ -62,8 +64,6 @@ using namespace HSM;
|
||||||
This class provides an interface to define, load and save scores. It is meant
|
This class provides an interface to define, load and save scores. It is meant
|
||||||
for games which do not support saving highscores.
|
for games which do not support saving highscores.
|
||||||
|
|
||||||
TODO: load and saves scores
|
|
||||||
|
|
||||||
@author Thomas Jentzsch
|
@author Thomas Jentzsch
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
|
@ -505,8 +505,6 @@ PhysicalKeyboardHandler::EventMappingArray PhysicalKeyboardHandler::DefaultCommo
|
||||||
{Event::Unwind1Menu, KBDK_RIGHT, MOD3},
|
{Event::Unwind1Menu, KBDK_RIGHT, MOD3},
|
||||||
{Event::Unwind10Menu, KBDK_RIGHT, KBDM_SHIFT | MOD3},
|
{Event::Unwind10Menu, KBDK_RIGHT, KBDM_SHIFT | MOD3},
|
||||||
{Event::UnwindAllMenu, KBDK_UP, MOD3},
|
{Event::UnwindAllMenu, KBDK_UP, MOD3},
|
||||||
{Event::ShowScore, KBDK_S, KBDM_SHIFT | KBDM_CTRL},
|
|
||||||
{Event::ShowVariation, KBDK_V, KBDM_SHIFT | KBDM_CTRL},
|
|
||||||
{Event::HighScoresMenuMode, KBDK_INSERT},
|
{Event::HighScoresMenuMode, KBDK_INSERT},
|
||||||
|
|
||||||
#if defined(RETRON77)
|
#if defined(RETRON77)
|
||||||
|
|
|
@ -27,6 +27,16 @@
|
||||||
"Cart.Addresses" "E6,E8,DC"
|
"Cart.Addresses" "E6,E8,DC"
|
||||||
""
|
""
|
||||||
|
|
||||||
|
"Cart.MD5" "77057d9d14b99e465ea9e29783af0ae3"
|
||||||
|
"Cart.Manufacturer" "Activision, David Crane"
|
||||||
|
"Cart.ModelNo" "AG-001"
|
||||||
|
"Cart.Name" "Dragster (1980) (Activision)"
|
||||||
|
"Cart.Note" "AKA Drag Strip"
|
||||||
|
"Cart.Players" "2"
|
||||||
|
"Cart.Formats" "4,0,B,B,1,-,D,0,1"
|
||||||
|
"Cart.Addresses" "B3,B5,B4,B6,80,80,0"
|
||||||
|
""
|
||||||
|
|
||||||
"Cart.MD5" "91c2098e88a6b13f977af8c003e0bca5"
|
"Cart.MD5" "91c2098e88a6b13f977af8c003e0bca5"
|
||||||
"Cart.Manufacturer" "Atari - GCC"
|
"Cart.Manufacturer" "Atari - GCC"
|
||||||
"Cart.ModelNo" "CX2676"
|
"Cart.ModelNo" "CX2676"
|
||||||
|
|
|
@ -120,7 +120,7 @@ class Event
|
||||||
ToggleFrameStats, ToggleSAPortOrder, ExitGame,
|
ToggleFrameStats, ToggleSAPortOrder, ExitGame,
|
||||||
|
|
||||||
// add new events from here to avoid that user remapped events get overwritten
|
// add new events from here to avoid that user remapped events get overwritten
|
||||||
ShowScore, ShowVariation, HighScoresMenuMode,
|
HighScoresMenuMode,
|
||||||
|
|
||||||
LastType
|
LastType
|
||||||
};
|
};
|
||||||
|
|
|
@ -721,27 +721,6 @@ void EventHandler::handleEvent(Event::Type event, Int32 value, bool repeated)
|
||||||
if(pressed && !repeated) myOSystem.frameBuffer().tiaSurface().saveSnapShot();
|
if(pressed && !repeated) myOSystem.frameBuffer().tiaSurface().saveSnapShot();
|
||||||
return;
|
return;
|
||||||
|
|
||||||
#ifdef GUI_SUPPORT
|
|
||||||
// Debug only, TODO: remove!
|
|
||||||
case Event::ShowScore:
|
|
||||||
if (pressed)
|
|
||||||
{
|
|
||||||
ostringstream msg;
|
|
||||||
msg << "Score: " << myOSystem.highScores().score();
|
|
||||||
myOSystem.frameBuffer().showMessage(msg.str());
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
|
|
||||||
case Event::ShowVariation:
|
|
||||||
if (pressed)
|
|
||||||
{
|
|
||||||
ostringstream msg;
|
|
||||||
msg << "Variation: " << myOSystem.highScores().variation();
|
|
||||||
myOSystem.frameBuffer().showMessage(msg.str());
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
case Event::ExitMode:
|
case Event::ExitMode:
|
||||||
// Special handling for Escape key
|
// Special handling for Escape key
|
||||||
// Basically, exit whichever mode we're currently in
|
// Basically, exit whichever mode we're currently in
|
||||||
|
@ -1857,6 +1836,7 @@ EventHandler::EmulActionList EventHandler::ourEmulActionList = { {
|
||||||
{ Event::ExitMode, "Exit current Stella menu/mode", "" },
|
{ Event::ExitMode, "Exit current Stella menu/mode", "" },
|
||||||
{ Event::OptionsMenuMode, "Enter Options menu UI", "" },
|
{ Event::OptionsMenuMode, "Enter Options menu UI", "" },
|
||||||
{ Event::CmdMenuMode, "Toggle Commands menu UI", "" },
|
{ Event::CmdMenuMode, "Toggle Commands menu UI", "" },
|
||||||
|
{ Event::HighScoresMenuMode, "Toggle High Scores UI", "" },
|
||||||
{ Event::TogglePauseMode, "Toggle Pause mode", "" },
|
{ Event::TogglePauseMode, "Toggle Pause mode", "" },
|
||||||
{ Event::StartPauseMode, "Start Pause mode", "" },
|
{ Event::StartPauseMode, "Start Pause mode", "" },
|
||||||
{ Event::Fry, "Fry cartridge", "" },
|
{ Event::Fry, "Fry cartridge", "" },
|
||||||
|
@ -2035,9 +2015,6 @@ EventHandler::EmulActionList EventHandler::ourEmulActionList = { {
|
||||||
{ Event::Combo14, "Combo 14", "" },
|
{ Event::Combo14, "Combo 14", "" },
|
||||||
{ Event::Combo15, "Combo 15", "" },
|
{ Event::Combo15, "Combo 15", "" },
|
||||||
{ Event::Combo16, "Combo 16", "" },
|
{ Event::Combo16, "Combo 16", "" },
|
||||||
{ Event::ShowScore, "Display current score", "" },
|
|
||||||
{ Event::ShowVariation, "Display current variation", "" },
|
|
||||||
{ Event::HighScoresMenuMode, "Toggle High Scores UI", "" },
|
|
||||||
} };
|
} };
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -2076,7 +2053,7 @@ const Event::EventSet EventHandler::MiscEvents = {
|
||||||
// Event::MouseButtonLeftValue, Event::MouseButtonRightValue,
|
// Event::MouseButtonLeftValue, Event::MouseButtonRightValue,
|
||||||
Event::HandleMouseControl, Event::ToggleGrabMouse,
|
Event::HandleMouseControl, Event::ToggleGrabMouse,
|
||||||
Event::ToggleSAPortOrder,
|
Event::ToggleSAPortOrder,
|
||||||
Event::ShowScore, Event::ShowVariation,
|
Event::HighScoresMenuMode
|
||||||
};
|
};
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
|
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "Console.hxx"
|
#include "Console.hxx"
|
||||||
|
#include "Launcher.hxx"
|
||||||
#include "EventHandler.hxx"
|
#include "EventHandler.hxx"
|
||||||
#include "Font.hxx"
|
#include "Font.hxx"
|
||||||
#include "FBSurface.hxx"
|
#include "FBSurface.hxx"
|
||||||
|
@ -30,16 +31,18 @@
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
HighScoresDialog::HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
HighScoresDialog::HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
const GUI::Font& font, int max_w, int max_h)
|
int max_w, int max_h,
|
||||||
: Dialog(osystem, parent, font, "High Scores"),
|
Menu::AppMode mode)
|
||||||
|
: Dialog(osystem, parent, osystem.frameBuffer().font(), "High Scores"),
|
||||||
|
myMode(mode),
|
||||||
_max_w(max_w),
|
_max_w(max_w),
|
||||||
_max_h(max_h),
|
_max_h(max_h),
|
||||||
myInitials(""),
|
myInitials(""),
|
||||||
myDirty(false)
|
myDirty(false)
|
||||||
{
|
{
|
||||||
const GUI::Font& ifont = instance().frameBuffer().infoFont();
|
const GUI::Font& ifont = instance().frameBuffer().infoFont();
|
||||||
const int lineHeight = font.getLineHeight(),
|
const int lineHeight = _font.getLineHeight(),
|
||||||
fontWidth = font.getMaxCharWidth();
|
fontWidth = _font.getMaxCharWidth();
|
||||||
const int VBORDER = 8;
|
const int VBORDER = 8;
|
||||||
const int HBORDER = 10;
|
const int HBORDER = 10;
|
||||||
const int VGAP = 4;
|
const int VGAP = 4;
|
||||||
|
@ -56,43 +59,43 @@ HighScoresDialog::HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
|
|
||||||
//items.clear();
|
//items.clear();
|
||||||
|
|
||||||
StaticTextWidget* s = new StaticTextWidget(this, font, xpos, ypos + 1, "Variation ");
|
StaticTextWidget* s = new StaticTextWidget(this, _font, xpos, ypos + 1, "Variation ");
|
||||||
myVariationWidget = new PopUpWidget(this, font, s->getRight(), ypos,
|
myVariationWidget = new PopUpWidget(this, _font, s->getRight(), ypos,
|
||||||
font.getStringWidth("256") - 4, lineHeight, items, "", 0,
|
_font.getStringWidth("256") - 4, lineHeight, items, "", 0,
|
||||||
kVariationChanged);
|
kVariationChanged);
|
||||||
wid.push_back(myVariationWidget);
|
wid.push_back(myVariationWidget);
|
||||||
|
|
||||||
ypos += lineHeight + VGAP * 4;
|
ypos += lineHeight + VGAP * 4;
|
||||||
|
|
||||||
int xposRank = HBORDER;
|
int xposRank = HBORDER;
|
||||||
int xposScore = xposRank + font.getStringWidth("Rank") + 16;
|
int xposScore = xposRank + _font.getStringWidth("Rank") + 16;
|
||||||
int xposSpecial = xposScore + font.getStringWidth("Score") + 24;
|
int xposSpecial = xposScore + _font.getStringWidth("Score") + 24;
|
||||||
int xposName = xposSpecial + font.getStringWidth("Round") + 16;
|
int xposName = xposSpecial + _font.getStringWidth("Round") + 16;
|
||||||
int xposDate = xposName + font.getStringWidth("Name") + 16;
|
int xposDate = xposName + _font.getStringWidth("Name") + 16;
|
||||||
int xposDelete = xposDate + font.getStringWidth("YY-MM-DD HH:MM") + 16;
|
int xposDelete = xposDate + _font.getStringWidth("YY-MM-DD HH:MM") + 16;
|
||||||
int nWidth = font.getStringWidth("ABC") + 4;
|
int nWidth = _font.getStringWidth("ABC") + 4;
|
||||||
|
|
||||||
new StaticTextWidget(this, font, xposRank, ypos + 1, "Rank");
|
new StaticTextWidget(this, _font, xposRank, ypos + 1, "Rank");
|
||||||
new StaticTextWidget(this, font, xposScore, ypos + 1, " Score");
|
new StaticTextWidget(this, _font, xposScore, ypos + 1, " Score");
|
||||||
mySpecialLabelWidget = new StaticTextWidget(this, font, xposSpecial, ypos + 1, "Round");
|
mySpecialLabelWidget = new StaticTextWidget(this, _font, xposSpecial, ypos + 1, "Round");
|
||||||
new StaticTextWidget(this, font, xposName - 2, ypos + 1, "Name");
|
new StaticTextWidget(this, _font, xposName - 2, ypos + 1, "Name");
|
||||||
new StaticTextWidget(this, font, xposDate+16, ypos + 1, "Date Time");
|
new StaticTextWidget(this, _font, xposDate+16, ypos + 1, "Date Time");
|
||||||
|
|
||||||
ypos += lineHeight + VGAP;
|
ypos += lineHeight + VGAP;
|
||||||
|
|
||||||
for (uInt32 p = 0; p < NUM_POSITIONS; ++p)
|
for (uInt32 p = 0; p < NUM_POSITIONS; ++p)
|
||||||
{
|
{
|
||||||
myPositionsWidget[p] = new StaticTextWidget(this, font, xposRank + 8, ypos + 1,
|
myPositionsWidget[p] = new StaticTextWidget(this, _font, xposRank + 8, ypos + 1,
|
||||||
(p < 9 ? " " : "") + std::to_string(p + 1));
|
(p < 9 ? " " : "") + std::to_string(p + 1));
|
||||||
myScoresWidget[p] = new StaticTextWidget(this, font, xposScore, ypos + 1, "123456");
|
myScoresWidget[p] = new StaticTextWidget(this, _font, xposScore, ypos + 1, "123456");
|
||||||
mySpecialsWidget[p] = new StaticTextWidget(this, font, xposSpecial + 8, ypos + 1, "123");
|
mySpecialsWidget[p] = new StaticTextWidget(this, _font, xposSpecial + 8, ypos + 1, "123");
|
||||||
myNamesWidget[p] = new StaticTextWidget(this, font, xposName + 2, ypos + 1, " ");
|
myNamesWidget[p] = new StaticTextWidget(this, _font, xposName + 2, ypos + 1, " ");
|
||||||
myEditNamesWidget[p] = new EditTextWidget(this, font, xposName, ypos - 1, nWidth, lineHeight);
|
myEditNamesWidget[p] = new EditTextWidget(this, _font, xposName, ypos - 1, nWidth, lineHeight);
|
||||||
myEditNamesWidget[p]->setFlags(EditTextWidget::FLAG_INVISIBLE);
|
myEditNamesWidget[p]->setFlags(EditTextWidget::FLAG_INVISIBLE);
|
||||||
myEditNamesWidget[p]->setEnabled(false);
|
myEditNamesWidget[p]->setEnabled(false);
|
||||||
wid.push_back(myEditNamesWidget[p]);
|
wid.push_back(myEditNamesWidget[p]);
|
||||||
myDatesWidget[p] = new StaticTextWidget(this, font, xposDate, ypos + 1, "12-02-20 17:15");
|
myDatesWidget[p] = new StaticTextWidget(this, _font, xposDate, ypos + 1, "12-02-20 17:15");
|
||||||
myDeleteButtons[p] = new ButtonWidget(this, font, xposDelete, ypos + 1, 18, 18, "X",
|
myDeleteButtons[p] = new ButtonWidget(this, _font, xposDelete, ypos + 1, 18, 18, "X",
|
||||||
kDeleteSingle);
|
kDeleteSingle);
|
||||||
myDeleteButtons[p]->setID(p);
|
myDeleteButtons[p]->setID(p);
|
||||||
wid.push_back(myDeleteButtons[p]);
|
wid.push_back(myDeleteButtons[p]);
|
||||||
|
@ -103,9 +106,8 @@ HighScoresDialog::HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
|
|
||||||
myMD5Widget = new StaticTextWidget(this, ifont, xpos, ypos + 1, "MD5: 12345678901234567890123456789012");
|
myMD5Widget = new StaticTextWidget(this, ifont, xpos, ypos + 1, "MD5: 12345678901234567890123456789012");
|
||||||
|
|
||||||
addDefaultsOKCancelBGroup(wid, font, "Save", "Cancel", " Reset ");
|
addDefaultsOKCancelBGroup(wid, _font, "Save", "Cancel", " Reset ");
|
||||||
addToFocusList(wid);
|
addToFocusList(wid); }
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
HighScoresDialog::~HighScoresDialog()
|
HighScoresDialog::~HighScoresDialog()
|
||||||
|
@ -142,7 +144,11 @@ void HighScoresDialog::loadConfig()
|
||||||
label = label.substr(label.length() - 5);
|
label = label.substr(label.length() - 5);
|
||||||
mySpecialLabelWidget->setLabel(label);
|
mySpecialLabelWidget->setLabel(label);
|
||||||
|
|
||||||
|
if (instance().hasConsole())
|
||||||
myMD5 = instance().console().properties().get(PropType::Cart_MD5);
|
myMD5 = instance().console().properties().get(PropType::Cart_MD5);
|
||||||
|
else
|
||||||
|
myMD5 = instance().launcher().selectedRomMD5();
|
||||||
|
|
||||||
myMD5Widget->setLabel("MD5: " + myMD5);
|
myMD5Widget->setLabel("MD5: " + myMD5);
|
||||||
|
|
||||||
myEditPos = myHighScorePos = -1;
|
myEditPos = myHighScorePos = -1;
|
||||||
|
@ -173,6 +179,9 @@ void HighScoresDialog::handleCommand(CommandSender* sender, int cmd, int data, i
|
||||||
saveConfig();
|
saveConfig();
|
||||||
[[fallthrough]];
|
[[fallthrough]];
|
||||||
case kCloseCmd:
|
case kCloseCmd:
|
||||||
|
if(myMode != Menu::AppMode::emulator)
|
||||||
|
close();
|
||||||
|
else
|
||||||
instance().eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -269,7 +278,6 @@ void HighScoresDialog::updateWidgets(bool init)
|
||||||
myEditNamesWidget[p]->setEditable(false);
|
myEditNamesWidget[p]->setEditable(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -363,14 +371,20 @@ bool HighScoresDialog::handleDirty()
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void HighScoresDialog::saveHighScores(Int32 variation) const
|
string HighScoresDialog::cartName() const
|
||||||
{
|
{
|
||||||
if(instance().hasConsole())
|
if(instance().hasConsole())
|
||||||
|
return instance().console().properties().get(PropType::Cart_Name);
|
||||||
|
else
|
||||||
|
return instance().launcher().currentNode().getNameWithExt("");
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void HighScoresDialog::saveHighScores(Int32 variation) const
|
||||||
{
|
{
|
||||||
ostringstream buf;
|
ostringstream buf;
|
||||||
buf << instance().stateDir()
|
|
||||||
<< instance().console().properties().get(PropType::Cart_Name)
|
buf << instance().stateDir() << cartName() << ".hs" << variation;
|
||||||
<< ".hs" << variation;
|
|
||||||
|
|
||||||
// Make sure the file can be opened for writing
|
// Make sure the file can be opened for writing
|
||||||
Serializer out(buf.str());
|
Serializer out(buf.str());
|
||||||
|
@ -389,7 +403,7 @@ void HighScoresDialog::saveHighScores(Int32 variation) const
|
||||||
buf << "Error saving high scores for variation" << variation;
|
buf << "Error saving high scores for variation" << variation;
|
||||||
instance().frameBuffer().showMessage(buf.str());
|
instance().frameBuffer().showMessage(buf.str());
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -403,12 +417,9 @@ void HighScoresDialog::loadHighScores(Int32 variation)
|
||||||
myDates[p] = "";
|
myDates[p] = "";
|
||||||
}
|
}
|
||||||
|
|
||||||
if(instance().hasConsole())
|
|
||||||
{
|
|
||||||
ostringstream buf;
|
ostringstream buf;
|
||||||
buf << instance().stateDir()
|
|
||||||
<< instance().console().properties().get(PropType::Cart_Name)
|
buf << instance().stateDir() << cartName() << ".hs" << variation;
|
||||||
<< ".hs" << variation;
|
|
||||||
|
|
||||||
// Make sure the file can be opened in read-only mode
|
// Make sure the file can be opened in read-only mode
|
||||||
Serializer in(buf.str(), Serializer::Mode::ReadOnly);
|
Serializer in(buf.str(), Serializer::Mode::ReadOnly);
|
||||||
|
@ -438,7 +449,6 @@ void HighScoresDialog::loadHighScores(Int32 variation)
|
||||||
|
|
||||||
instance().frameBuffer().showMessage(buf.str());
|
instance().frameBuffer().showMessage(buf.str());
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool HighScoresDialog::save(Serializer& out, Int32 variation) const
|
bool HighScoresDialog::save(Serializer& out, Int32 variation) const
|
||||||
|
|
|
@ -31,6 +31,7 @@ namespace GUI {
|
||||||
}
|
}
|
||||||
class Serializer;
|
class Serializer;
|
||||||
|
|
||||||
|
#include "Menu.hxx"
|
||||||
#include "Dialog.hxx"
|
#include "Dialog.hxx"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -45,7 +46,7 @@ class HighScoresDialog : public Dialog
|
||||||
static const uInt32 NUM_POSITIONS = 10;
|
static const uInt32 NUM_POSITIONS = 10;
|
||||||
|
|
||||||
HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
const GUI::Font& font, int max_w, int max_h);
|
int max_w, int max_h, Menu::AppMode mode);
|
||||||
virtual ~HighScoresDialog();
|
virtual ~HighScoresDialog();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
@ -60,6 +61,7 @@ class HighScoresDialog : public Dialog
|
||||||
void deletePos(int pos);
|
void deletePos(int pos);
|
||||||
bool handleDirty();
|
bool handleDirty();
|
||||||
|
|
||||||
|
string cartName() const;
|
||||||
void saveHighScores(Int32 variation) const;
|
void saveHighScores(Int32 variation) const;
|
||||||
void loadHighScores(Int32 variation);
|
void loadHighScores(Int32 variation);
|
||||||
|
|
||||||
|
@ -119,6 +121,8 @@ class HighScoresDialog : public Dialog
|
||||||
|
|
||||||
StaticTextWidget* myMD5Widget{nullptr};
|
StaticTextWidget* myMD5Widget{nullptr};
|
||||||
|
|
||||||
|
Menu::AppMode myMode{Menu::AppMode::emulator};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Following constructors and assignment operators not supported
|
// Following constructors and assignment operators not supported
|
||||||
HighScoresDialog() = delete;
|
HighScoresDialog() = delete;
|
||||||
|
|
|
@ -36,8 +36,9 @@ HighScoresMenu::~HighScoresMenu()
|
||||||
Dialog* HighScoresMenu::baseDialog()
|
Dialog* HighScoresMenu::baseDialog()
|
||||||
{
|
{
|
||||||
if (myHighScoresDialog == nullptr)
|
if (myHighScoresDialog == nullptr)
|
||||||
myHighScoresDialog = new HighScoresDialog(myOSystem, *this, myOSystem.frameBuffer().font(),
|
myHighScoresDialog = new HighScoresDialog(myOSystem, *this,
|
||||||
FBMinimum::Width, FBMinimum::Height);
|
FBMinimum::Width, FBMinimum::Height,
|
||||||
|
Menu::AppMode::emulator);
|
||||||
|
|
||||||
return myHighScoresDialog;
|
return myHighScoresDialog;
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,6 +26,8 @@
|
||||||
#include "FSNode.hxx"
|
#include "FSNode.hxx"
|
||||||
#include "MD5.hxx"
|
#include "MD5.hxx"
|
||||||
#include "OptionsDialog.hxx"
|
#include "OptionsDialog.hxx"
|
||||||
|
#include "HighScoresDialog.hxx"
|
||||||
|
#include "HighScoresManager.hxx"
|
||||||
#include "GlobalPropsDialog.hxx"
|
#include "GlobalPropsDialog.hxx"
|
||||||
#include "StellaSettingsDialog.hxx"
|
#include "StellaSettingsDialog.hxx"
|
||||||
#include "MessageBox.hxx"
|
#include "MessageBox.hxx"
|
||||||
|
@ -204,11 +206,8 @@ LauncherDialog::LauncherDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
|
|
||||||
addToFocusList(wid);
|
addToFocusList(wid);
|
||||||
|
|
||||||
// Create context menu for ROM list options
|
// Create (empty) context menu for ROM list options
|
||||||
VariantList l;
|
myMenu = make_unique<ContextMenu>(this, osystem.frameBuffer().font(), EmptyVarList);
|
||||||
VarList::push_back(l, "Power-on options" + ELLIPSIS, "override");
|
|
||||||
VarList::push_back(l, "Reload listing", "reload");
|
|
||||||
myMenu = make_unique<ContextMenu>(this, osystem.frameBuffer().font(), l);
|
|
||||||
|
|
||||||
// Create global props dialog, which is used to temporarily overrride
|
// Create global props dialog, which is used to temporarily overrride
|
||||||
// ROM properties
|
// ROM properties
|
||||||
|
@ -353,6 +352,8 @@ void LauncherDialog::handleContextMenu()
|
||||||
myGlobalProps->open();
|
myGlobalProps->open();
|
||||||
else if(cmd == "reload")
|
else if(cmd == "reload")
|
||||||
reload();
|
reload();
|
||||||
|
else if(cmd == "highscores")
|
||||||
|
openHighScores();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -460,6 +461,15 @@ void LauncherDialog::handleMouseDown(int x, int y, MouseButton b, int clickCount
|
||||||
// Grab right mouse button for context menu, send left to base class
|
// Grab right mouse button for context menu, send left to base class
|
||||||
if(b == MouseButton::RIGHT)
|
if(b == MouseButton::RIGHT)
|
||||||
{
|
{
|
||||||
|
// Dynamically create context menu for ROM list options
|
||||||
|
VariantList items;
|
||||||
|
|
||||||
|
VarList::push_back(items, "Power-on options" + ELLIPSIS, "override");
|
||||||
|
if(instance().highScores().enabled())
|
||||||
|
VarList::push_back(items, "High scores" + ELLIPSIS, "highscores");
|
||||||
|
VarList::push_back(items, "Reload listing", "reload");
|
||||||
|
myMenu->addItems(items);
|
||||||
|
|
||||||
// Add menu at current x,y mouse location
|
// Add menu at current x,y mouse location
|
||||||
myMenu->show(x + getAbsX(), y + getAbsY(), surface().dstRect());
|
myMenu->show(x + getAbsX(), y + getAbsY(), surface().dstRect());
|
||||||
}
|
}
|
||||||
|
@ -565,3 +575,14 @@ void LauncherDialog::openSettings()
|
||||||
myOptionsDialog->open();
|
myOptionsDialog->open();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void LauncherDialog::openHighScores()
|
||||||
|
{
|
||||||
|
// Create an options dialog, similar to the in-game one
|
||||||
|
if(myHighScoresDialog == nullptr)
|
||||||
|
myHighScoresDialog = make_unique<HighScoresDialog>(instance(), parent(), _w, _h,
|
||||||
|
Menu::AppMode::launcher);
|
||||||
|
|
||||||
|
myHighScoresDialog->open();
|
||||||
|
}
|
||||||
|
|
|
@ -24,6 +24,7 @@ class ContextMenu;
|
||||||
class DialogContainer;
|
class DialogContainer;
|
||||||
class BrowserDialog;
|
class BrowserDialog;
|
||||||
class OptionsDialog;
|
class OptionsDialog;
|
||||||
|
class HighScoresDialog;
|
||||||
class GlobalPropsDialog;
|
class GlobalPropsDialog;
|
||||||
class StellaSettingsDialog;
|
class StellaSettingsDialog;
|
||||||
class OSystem;
|
class OSystem;
|
||||||
|
@ -103,9 +104,11 @@ class LauncherDialog : public Dialog
|
||||||
void handleContextMenu();
|
void handleContextMenu();
|
||||||
void showOnlyROMs(bool state);
|
void showOnlyROMs(bool state);
|
||||||
void openSettings();
|
void openSettings();
|
||||||
|
void openHighScores();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
unique_ptr<OptionsDialog> myOptionsDialog;
|
unique_ptr<OptionsDialog> myOptionsDialog;
|
||||||
|
unique_ptr<HighScoresDialog> myHighScoresDialog;
|
||||||
unique_ptr<StellaSettingsDialog> myStellaSettingsDialog;
|
unique_ptr<StellaSettingsDialog> myStellaSettingsDialog;
|
||||||
unique_ptr<ContextMenu> myMenu;
|
unique_ptr<ContextMenu> myMenu;
|
||||||
unique_ptr<GlobalPropsDialog> myGlobalProps;
|
unique_ptr<GlobalPropsDialog> myGlobalProps;
|
||||||
|
|
Loading…
Reference in New Issue