mirror of https://github.com/stella-emu/stella.git
get current data for HighScoresDialog
define, load and store "special" value
This commit is contained in:
parent
542c22fbfd
commit
aa0dc0b9ff
|
@ -130,12 +130,14 @@ bool HighScoresManager::get(const Properties& props, uInt32& numPlayersR, uInt32
|
||||||
info.scoreBCD = scoreBCD(props);
|
info.scoreBCD = scoreBCD(props);
|
||||||
info.varsBCD = varBCD(props);
|
info.varsBCD = varBCD(props);
|
||||||
info.varsZeroBased = varZeroBased(props);
|
info.varsZeroBased = varZeroBased(props);
|
||||||
info.specialBCD = false; // TODO
|
info.special = specialLabel(props);
|
||||||
info.specialZeroBased = true; // TODO
|
info.specialBCD = specialBCD(props);
|
||||||
|
info.specialZeroBased = specialZeroBased(props);
|
||||||
|
|
||||||
info.playersAddr = playerAddress(props);
|
info.playersAddr = playerAddress(props);
|
||||||
info.varsAddr = varAddress(props);
|
info.varsAddr = varAddress(props);
|
||||||
info.specialAddr = 0; // TODO
|
info.specialAddr = specialAddress(props);
|
||||||
|
|
||||||
for (uInt32 p = 0; p < MAX_PLAYERS; ++p)
|
for (uInt32 p = 0; p < MAX_PLAYERS; ++p)
|
||||||
{
|
{
|
||||||
if (p < numPlayersR)
|
if (p < numPlayersR)
|
||||||
|
@ -167,12 +169,20 @@ void HighScoresManager::set(Properties& props, uInt32 numPlayers, uInt32 numVari
|
||||||
props.set(PropType::Cart_Variations, to_string(min(numVariations, MAX_VARIATIONS)));
|
props.set(PropType::Cart_Variations, to_string(min(numVariations, MAX_VARIATIONS)));
|
||||||
|
|
||||||
// fill from the back to skip default values
|
// fill from the back to skip default values
|
||||||
if (info.varsZeroBased != DEFAULT_VARS_ZERO_BASED)
|
if (output.length() || info.specialZeroBased != DEFAULT_SPECIAL_ZERO_BASED)
|
||||||
output = info.varsZeroBased ? ",1" : ",0";
|
output = info.specialZeroBased ? ",1" : ",0";
|
||||||
|
if (output.length() || info.specialBCD != DEFAULT_SPECIAL_BCD)
|
||||||
|
output.insert(0, info.specialBCD ? ",B" : ",D");
|
||||||
|
if (output.length() || !info.special.empty())
|
||||||
|
output.insert(0, "," + info.special);
|
||||||
|
|
||||||
|
if (output.length() || info.varsZeroBased != DEFAULT_VARS_ZERO_BASED)
|
||||||
|
output.insert(0, info.varsZeroBased ? ",1" : ",0");
|
||||||
if (output.length() || info.varsBCD != DEFAULT_VARS_BCD)
|
if (output.length() || info.varsBCD != DEFAULT_VARS_BCD)
|
||||||
output.insert(0, info.varsBCD ? ",B" : ",D");
|
output.insert(0, info.varsBCD ? ",B" : ",D");
|
||||||
if (output.length() || info.scoreBCD != DEFAULT_SCORE_BCD)
|
if (output.length() || info.scoreBCD != DEFAULT_SCORE_BCD)
|
||||||
output.insert(0, info.scoreBCD ? ",B" : ",H");
|
output.insert(0, info.scoreBCD ? ",B" : ",H");
|
||||||
|
|
||||||
if (output.length() || info.trailingZeroes != DEFAULT_TRAILING)
|
if (output.length() || info.trailingZeroes != DEFAULT_TRAILING)
|
||||||
output.insert(0, "," + to_string(info.trailingZeroes));
|
output.insert(0, "," + to_string(info.trailingZeroes));
|
||||||
if (output.length() || info.numDigits != DEFAULT_DIGITS)
|
if (output.length() || info.numDigits != DEFAULT_DIGITS)
|
||||||
|
@ -187,10 +197,12 @@ void HighScoresManager::set(Properties& props, uInt32 numPlayers, uInt32 numVari
|
||||||
}
|
}
|
||||||
|
|
||||||
// add optional addresses
|
// add optional addresses
|
||||||
if (numVariations != DEFAULT_VARIATION || numPlayers != DEFAULT_PLAYER)
|
if (numVariations != DEFAULT_VARIATION || numPlayers != DEFAULT_PLAYER || !info.special.empty())
|
||||||
buf << info.varsAddr << "," ;
|
buf << info.varsAddr << "," ;
|
||||||
if (numPlayers != DEFAULT_PLAYER)
|
if (numPlayers != DEFAULT_PLAYER || !info.special.empty())
|
||||||
buf << info.playersAddr << "," ;
|
buf << info.playersAddr << "," ;
|
||||||
|
if (!info.special.empty())
|
||||||
|
buf << info.specialAddr << "," ;
|
||||||
|
|
||||||
output = buf.str();
|
output = buf.str();
|
||||||
output.pop_back();
|
output.pop_back();
|
||||||
|
@ -202,7 +214,7 @@ uInt32 HighScoresManager::numDigits(const Properties& props) const
|
||||||
{
|
{
|
||||||
string digits = getPropIdx(props, PropType::Cart_Formats, 0);
|
string digits = getPropIdx(props, PropType::Cart_Formats, 0);
|
||||||
|
|
||||||
return min(uInt32(stringToInt(digits, DEFAULT_DIGITS)), MAX_DIGITS);
|
return min(uInt32(stringToInt(digits, DEFAULT_DIGITS)), MAX_SCORE_DIGITS);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -237,6 +249,36 @@ bool HighScoresManager::varZeroBased(const Properties& props) const
|
||||||
return zeroBased == EmptyString ? DEFAULT_VARS_ZERO_BASED : zeroBased != "0";
|
return zeroBased == EmptyString ? DEFAULT_VARS_ZERO_BASED : zeroBased != "0";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
string HighScoresManager::specialLabel(const Properties& props) const
|
||||||
|
{
|
||||||
|
string orgLabel, label;
|
||||||
|
|
||||||
|
// some ugly formatting
|
||||||
|
orgLabel = label = getPropIdx(props, PropType::Cart_Formats, 5);
|
||||||
|
label = BSPF::toLowerCase(label);
|
||||||
|
label[0] = orgLabel[0];
|
||||||
|
|
||||||
|
return label;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
bool HighScoresManager::specialBCD(const Properties& props) const
|
||||||
|
{
|
||||||
|
string bcd = getPropIdx(props, PropType::Cart_Formats, 6);
|
||||||
|
|
||||||
|
return bcd == EmptyString ? DEFAULT_SPECIAL_BCD : bcd == "B";
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
bool HighScoresManager::specialZeroBased(const Properties& props) const
|
||||||
|
{
|
||||||
|
string zeroBased = getPropIdx(props, PropType::Cart_Formats, 7);
|
||||||
|
|
||||||
|
return zeroBased == EmptyString ? DEFAULT_SPECIAL_ZERO_BASED : zeroBased != "0";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool HighScoresManager::playerZeroBased(const Properties& props) const
|
bool HighScoresManager::playerZeroBased(const Properties& props) const
|
||||||
{
|
{
|
||||||
|
@ -262,6 +304,16 @@ uInt16 HighScoresManager::varAddress(const Properties& props) const
|
||||||
return stringToIntBase16(addr, DEFAULT_ADDRESS);
|
return stringToIntBase16(addr, DEFAULT_ADDRESS);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
uInt16 HighScoresManager::specialAddress(const Properties& props) const
|
||||||
|
{
|
||||||
|
uInt32 idx = numAddrBytes(props) * numPlayers(props) + 2;
|
||||||
|
string addr = getPropIdx(props, PropType::Cart_Addresses, idx);
|
||||||
|
|
||||||
|
return stringToIntBase16(addr, DEFAULT_ADDRESS);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
uInt32 HighScoresManager::numAddrBytes(Int32 digits, Int32 trailing) const
|
uInt32 HighScoresManager::numAddrBytes(Int32 digits, Int32 trailing) const
|
||||||
{
|
{
|
||||||
|
@ -311,6 +363,14 @@ Int32 HighScoresManager::player() const
|
||||||
return player(addr, numPlayers(props), playerZeroBased(props));
|
return player(addr, numPlayers(props), playerZeroBased(props));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
string HighScoresManager::specialLabel() const
|
||||||
|
{
|
||||||
|
Properties props;
|
||||||
|
|
||||||
|
return specialLabel(properties(props));
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
Int32 HighScoresManager::variation(uInt16 addr, bool varBCD, bool zeroBased,
|
Int32 HighScoresManager::variation(uInt16 addr, bool varBCD, bool zeroBased,
|
||||||
uInt32 numVariations) const
|
uInt32 numVariations) const
|
||||||
|
@ -398,6 +458,34 @@ Int32 HighScoresManager::score() const
|
||||||
return score(currentPlayer, numBytes, trailingZeroes(props), scoreBCD(props), scoreAddr);
|
return score(currentPlayer, numBytes, trailingZeroes(props), scoreBCD(props), scoreAddr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
Int32 HighScoresManager::special() const
|
||||||
|
{
|
||||||
|
Properties props;
|
||||||
|
uInt16 addr = specialAddress(properties(props));
|
||||||
|
|
||||||
|
if (addr == DEFAULT_ADDRESS)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return special(addr, specialBCD(props), specialZeroBased(props));
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
Int32 HighScoresManager::special(uInt16 addr, bool varBCD, bool zeroBased) const
|
||||||
|
{
|
||||||
|
if (!myOSystem.hasConsole())
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
Int32 var = peek(addr);
|
||||||
|
|
||||||
|
if (varBCD)
|
||||||
|
var = fromBCD(var);
|
||||||
|
|
||||||
|
var += zeroBased ? 1 : 0;
|
||||||
|
|
||||||
|
return var;
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
Int32 HighScoresManager::fromBCD(uInt8 bcd) const
|
Int32 HighScoresManager::fromBCD(uInt8 bcd) const
|
||||||
{
|
{
|
||||||
|
|
|
@ -22,8 +22,11 @@ class OSystem;
|
||||||
|
|
||||||
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_SCORE_DIGITS = 6;
|
||||||
static const uInt32 MAX_SCORE_ADDR = 3;
|
static const uInt32 MAX_SCORE_ADDR = 3;
|
||||||
static const uInt32 MAX_SPECIAL = 5;
|
static const uInt32 MAX_SPECIAL_NAME = 5;
|
||||||
|
static const uInt32 MAX_SPECIAL_DIGITS = 3;
|
||||||
|
|
||||||
static const uInt32 DEFAULT_PLAYER = 1;
|
static const uInt32 DEFAULT_PLAYER = 1;
|
||||||
static const uInt32 DEFAULT_VARIATION = 1;
|
static const uInt32 DEFAULT_VARIATION = 1;
|
||||||
|
@ -100,16 +103,19 @@ class HighScoresManager
|
||||||
Int32 score(uInt32 player, uInt32 numAddrBytes, uInt32 trailingZeroes, bool isBCD,
|
Int32 score(uInt32 player, uInt32 numAddrBytes, uInt32 trailingZeroes, bool isBCD,
|
||||||
const ScoreAddresses& scoreAddr) const;
|
const ScoreAddresses& scoreAddr) const;
|
||||||
|
|
||||||
|
Int32 special(uInt16 addr, bool varBCD, bool zeroBased) const;
|
||||||
|
|
||||||
// Retrieve current values (using game's properties)
|
// Retrieve current values (using game's properties)
|
||||||
Int32 numVariations() const;
|
Int32 numVariations() const;
|
||||||
Int32 player() const;
|
Int32 player() const;
|
||||||
|
string specialLabel() const;
|
||||||
Int32 variation() const;
|
Int32 variation() const;
|
||||||
Int32 score() const;
|
Int32 score() const;
|
||||||
|
Int32 special() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static const uInt32 MAX_VARIATIONS = 256;
|
static const uInt32 MAX_VARIATIONS = 256;
|
||||||
|
|
||||||
static const uInt32 MAX_DIGITS = 6;
|
|
||||||
static const uInt32 MAX_TRAILING = 3;
|
static const uInt32 MAX_TRAILING = 3;
|
||||||
static const uInt32 DEFAULT_DIGITS = 4;
|
static const uInt32 DEFAULT_DIGITS = 4;
|
||||||
static const uInt32 DEFAULT_TRAILING = 0;
|
static const uInt32 DEFAULT_TRAILING = 0;
|
||||||
|
@ -117,6 +123,8 @@ class HighScoresManager
|
||||||
static const bool DEFAULT_VARS_BCD = true;
|
static const bool DEFAULT_VARS_BCD = true;
|
||||||
static const bool DEFAULT_VARS_ZERO_BASED = false;
|
static const bool DEFAULT_VARS_ZERO_BASED = false;
|
||||||
static const bool DEFAULT_PLAYERS_ZERO_BASED = true;
|
static const bool DEFAULT_PLAYERS_ZERO_BASED = true;
|
||||||
|
static const bool DEFAULT_SPECIAL_BCD = true;
|
||||||
|
static const bool DEFAULT_SPECIAL_ZERO_BASED = false;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Get individual highscore info from properties
|
// Get individual highscore info from properties
|
||||||
|
@ -124,11 +132,15 @@ class HighScoresManager
|
||||||
uInt32 numPlayers(const Properties& props) const;
|
uInt32 numPlayers(const Properties& props) const;
|
||||||
uInt16 varAddress(const Properties& props) const;
|
uInt16 varAddress(const Properties& props) const;
|
||||||
uInt16 playerAddress(const Properties& props) const;
|
uInt16 playerAddress(const Properties& props) const;
|
||||||
|
uInt16 specialAddress(const Properties& props) const;
|
||||||
uInt32 numDigits(const Properties& props) const;
|
uInt32 numDigits(const Properties& props) const;
|
||||||
uInt32 trailingZeroes(const Properties& props) const;
|
uInt32 trailingZeroes(const Properties& props) const;
|
||||||
bool scoreBCD(const Properties& props) const;
|
bool scoreBCD(const Properties& props) const;
|
||||||
bool varBCD(const Properties& props) const;
|
bool varBCD(const Properties& props) const;
|
||||||
bool varZeroBased(const Properties& props) const;
|
bool varZeroBased(const Properties& props) const;
|
||||||
|
string specialLabel(const Properties& props) const;
|
||||||
|
bool specialBCD(const Properties& props) const;
|
||||||
|
bool specialZeroBased(const Properties& props) const;
|
||||||
bool playerZeroBased(const Properties& props) const;
|
bool playerZeroBased(const Properties& props) const;
|
||||||
|
|
||||||
// Calculate the number of bytes for one player's score from property parameters
|
// Calculate the number of bytes for one player's score from property parameters
|
||||||
|
|
|
@ -95,7 +95,7 @@
|
||||||
"Cart.ModelNo" "AZ-036-04"
|
"Cart.ModelNo" "AZ-036-04"
|
||||||
"Cart.Name" "H.E.R.O. (1984) (Activision)"
|
"Cart.Name" "H.E.R.O. (1984) (Activision)"
|
||||||
"Cart.Variations" "5"
|
"Cart.Variations" "5"
|
||||||
"Cart.Formats" "6,0,B,B,1"
|
"Cart.Formats" "6,0,B,B,1,LEVEL,B,1"
|
||||||
"Cart.Addresses" "B7,B8,B9,B4"
|
"Cart.Addresses" "B7,B8,B9,B4,0,F5"
|
||||||
""
|
""
|
||||||
|
|
||||||
|
|
|
@ -372,17 +372,15 @@ GameInfoDialog::GameInfoDialog(
|
||||||
xpos += 20; ypos += lineHeight + VGAP;
|
xpos += 20; ypos += lineHeight + VGAP;
|
||||||
|
|
||||||
items.clear();
|
items.clear();
|
||||||
VarList::push_back(items, "1", "1");
|
for (int i = 1; i <= HSM::MAX_PLAYERS; ++i)
|
||||||
VarList::push_back(items, "2", "2");
|
VarList::push_back(items, std::to_string(i), std::to_string(i));
|
||||||
VarList::push_back(items, "3", "3");
|
|
||||||
VarList::push_back(items, "4", "4");
|
|
||||||
pwidth = font.getStringWidth("4");
|
pwidth = font.getStringWidth("4");
|
||||||
|
|
||||||
myPlayersLabel = new StaticTextWidget(myTab, font, xpos, ypos + 1, lwidth, fontHeight, "Players");
|
myPlayersLabel = new StaticTextWidget(myTab, font, xpos, ypos + 1, lwidth, fontHeight, "Players");
|
||||||
myPlayers = new PopUpWidget(myTab, font, xpos + lwidth, ypos, pwidth, lineHeight, items, "", 0, kHiScoresChanged);
|
myPlayers = new PopUpWidget(myTab, font, xpos + lwidth, ypos, pwidth, lineHeight, items, "", 0, kHiScoresChanged);
|
||||||
wid.push_back(myPlayers);
|
wid.push_back(myPlayers);
|
||||||
|
|
||||||
int awidth = font.getStringWidth("FFFF") + 4;
|
int awidth = font.getMaxCharWidth() * HSM::MAX_ADDR_CHARS + 4;
|
||||||
int vwidth = font.getStringWidth("123") + 4;
|
int vwidth = font.getStringWidth("123") + 4;
|
||||||
|
|
||||||
myPlayersAddressLabel = new StaticTextWidget(myTab, font, myPlayers->getRight() + 16, ypos + 1, "Address ");
|
myPlayersAddressLabel = new StaticTextWidget(myTab, font, myPlayers->getRight() + 16, ypos + 1, "Address ");
|
||||||
|
@ -418,9 +416,9 @@ GameInfoDialog::GameInfoDialog(
|
||||||
ypos += lineHeight + VGAP;
|
ypos += lineHeight + VGAP;
|
||||||
|
|
||||||
mySpecialLabel = new StaticTextWidget(myTab, font, xpos, ypos + 1, "Special ");
|
mySpecialLabel = new StaticTextWidget(myTab, font, xpos, ypos + 1, "Special ");
|
||||||
mySpecial = new EditTextWidget(myTab, font, mySpecialLabel->getRight(), ypos - 1, swidth, lineHeight);
|
mySpecialName = new EditTextWidget(myTab, font, mySpecialLabel->getRight(), ypos - 1, swidth, lineHeight);
|
||||||
mySpecial->setTextFilter(fSpecial);
|
mySpecialName->setTextFilter(fSpecial);
|
||||||
wid.push_back(mySpecial);
|
wid.push_back(mySpecialName);
|
||||||
|
|
||||||
mySpecialAddressLabel = new StaticTextWidget(myTab, font, myPlayersAddressLabel->getLeft(), ypos + 1, "Address ");
|
mySpecialAddressLabel = new StaticTextWidget(myTab, font, myPlayersAddressLabel->getLeft(), ypos + 1, "Address ");
|
||||||
mySpecialAddress = new EditTextWidget(myTab, font, mySpecialAddressLabel->getRight(), ypos - 1, awidth, lineHeight);
|
mySpecialAddress = new EditTextWidget(myTab, font, mySpecialAddressLabel->getRight(), ypos - 1, awidth, lineHeight);
|
||||||
|
@ -440,12 +438,8 @@ GameInfoDialog::GameInfoDialog(
|
||||||
|
|
||||||
vwidth = font.getStringWidth("AB") + 4;
|
vwidth = font.getStringWidth("AB") + 4;
|
||||||
items.clear();
|
items.clear();
|
||||||
VarList::push_back(items, "1", "1");
|
for (int i = 1; i <= HSM::MAX_SCORE_DIGITS; ++i)
|
||||||
VarList::push_back(items, "2", "2");
|
VarList::push_back(items, std::to_string(i), std::to_string(i));
|
||||||
VarList::push_back(items, "3", "3");
|
|
||||||
VarList::push_back(items, "4", "4");
|
|
||||||
VarList::push_back(items, "5", "5");
|
|
||||||
VarList::push_back(items, "6", "6");
|
|
||||||
|
|
||||||
myScoreDigitsLabel = new StaticTextWidget(myTab, font, xpos, ypos + 1, "Score digits ");
|
myScoreDigitsLabel = new StaticTextWidget(myTab, font, xpos, ypos + 1, "Score digits ");
|
||||||
myScoreDigits = new PopUpWidget(myTab, font, myScoreDigitsLabel->getRight(), ypos, pwidth, lineHeight,
|
myScoreDigits = new PopUpWidget(myTab, font, myScoreDigitsLabel->getRight(), ypos, pwidth, lineHeight,
|
||||||
|
@ -453,10 +447,8 @@ GameInfoDialog::GameInfoDialog(
|
||||||
wid.push_back(myScoreDigits);
|
wid.push_back(myScoreDigits);
|
||||||
|
|
||||||
items.clear();
|
items.clear();
|
||||||
VarList::push_back(items, "0", "0");
|
for (int i = 0; i <= HSM::MAX_SCORE_DIGITS - 3; ++i)
|
||||||
VarList::push_back(items, "1", "1");
|
VarList::push_back(items, std::to_string(i), std::to_string(i));
|
||||||
VarList::push_back(items, "2", "2");
|
|
||||||
VarList::push_back(items, "3", "3");
|
|
||||||
pwidth = font.getStringWidth("0");
|
pwidth = font.getStringWidth("0");
|
||||||
|
|
||||||
myTrailingZeroesLabel = new StaticTextWidget(myTab, font, myScoreDigits->getRight() + 30, ypos + 1, "0-digits ");
|
myTrailingZeroesLabel = new StaticTextWidget(myTab, font, myScoreDigits->getRight() + 30, ypos + 1, "0-digits ");
|
||||||
|
@ -699,22 +691,22 @@ void GameInfoDialog::loadHighScoresProperties(const Properties& props)
|
||||||
myScoreBCD->setState(info.scoreBCD);
|
myScoreBCD->setState(info.scoreBCD);
|
||||||
myVarsBCD->setState(info.varsBCD);
|
myVarsBCD->setState(info.varsBCD);
|
||||||
myVarsZeroBased->setState(info.varsZeroBased);
|
myVarsZeroBased->setState(info.varsZeroBased);
|
||||||
mySpecial->setText(info.special);
|
mySpecialName->setText(info.special);
|
||||||
mySpecialBCD->setState(info.specialBCD);
|
mySpecialBCD->setState(info.specialBCD);
|
||||||
mySpecialZeroBased->setState(info.specialZeroBased);
|
mySpecialZeroBased->setState(info.specialZeroBased);
|
||||||
|
|
||||||
ss.str("");
|
ss.str("");
|
||||||
ss << hex << right << setw(4) << setfill(' ')
|
ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ')
|
||||||
<< uppercase << info.playersAddr;
|
<< uppercase << info.playersAddr;
|
||||||
myPlayersAddress->setText(ss.str());
|
myPlayersAddress->setText(ss.str());
|
||||||
|
|
||||||
ss.str("");
|
ss.str("");
|
||||||
ss << hex << right << setw(4) << setfill(' ')
|
ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ')
|
||||||
<< uppercase << info.varsAddr;
|
<< uppercase << info.varsAddr;
|
||||||
myVarAddress->setText(ss.str());
|
myVarAddress->setText(ss.str());
|
||||||
|
|
||||||
ss.str("");
|
ss.str("");
|
||||||
ss << hex << right << setw(4) << setfill(' ')
|
ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ')
|
||||||
<< uppercase << info.specialAddr;
|
<< uppercase << info.specialAddr;
|
||||||
mySpecialAddress->setText(ss.str());
|
mySpecialAddress->setText(ss.str());
|
||||||
|
|
||||||
|
@ -726,7 +718,7 @@ void GameInfoDialog::loadHighScoresProperties(const Properties& props)
|
||||||
if (p < numPlayers)
|
if (p < numPlayers)
|
||||||
{
|
{
|
||||||
ss.str("");
|
ss.str("");
|
||||||
ss << hex << right << setw(4) << setfill('0')
|
ss << hex << right //<< setw(HSM::MAX_ADDR_CHARS) << setfill(' ')
|
||||||
<< uppercase << info.scoresAddr[p][a];
|
<< uppercase << info.scoresAddr[p][a];
|
||||||
myScoreAddress[p][a]->setText(ss.str());
|
myScoreAddress[p][a]->setText(ss.str());
|
||||||
}
|
}
|
||||||
|
@ -814,11 +806,22 @@ void GameInfoDialog::saveHighScoresProperties()
|
||||||
|
|
||||||
if (myHighScores->getState())
|
if (myHighScores->getState())
|
||||||
{
|
{
|
||||||
|
string strText;
|
||||||
|
|
||||||
|
// limit variants and special size
|
||||||
|
strText = myVariations->getText();
|
||||||
|
strText = strText.substr(0, 3);
|
||||||
|
myVariations->setText(strText);
|
||||||
|
|
||||||
|
strText = mySpecialName->getText();
|
||||||
|
strText = strText.substr(0, HSM::MAX_SPECIAL_NAME);
|
||||||
|
mySpecialName->setText(strText);
|
||||||
|
|
||||||
// fill format
|
// fill format
|
||||||
info.varsZeroBased = myVarsZeroBased->getState();
|
info.varsZeroBased = myVarsZeroBased->getState();
|
||||||
info.varsBCD = myVarsBCD->getState();
|
info.varsBCD = myVarsBCD->getState();
|
||||||
|
|
||||||
info.special = mySpecial->getText();
|
info.special = mySpecialName->getText();
|
||||||
info.specialZeroBased = mySpecialZeroBased->getState();
|
info.specialZeroBased = mySpecialZeroBased->getState();
|
||||||
info.specialBCD = mySpecialBCD->getState();
|
info.specialBCD = mySpecialBCD->getState();
|
||||||
|
|
||||||
|
@ -1007,19 +1010,9 @@ void GameInfoDialog::updateHighScoresWidgets()
|
||||||
uInt32 players = myPlayers->getSelected() + 1;
|
uInt32 players = myPlayers->getSelected() + 1;
|
||||||
bool enablePlayers = enable && players > 1;
|
bool enablePlayers = enable && players > 1;
|
||||||
bool enableVars = enable && myVariations->getText() > "1";
|
bool enableVars = enable && myVariations->getText() > "1";
|
||||||
bool enableSpecial = enable && !mySpecial->getText().empty();
|
bool enableSpecial = enable && !mySpecialName->getText().empty();
|
||||||
uInt32 numAddr = instance().highScores().numAddrBytes(myScoreDigits->getSelected() + 1,
|
uInt32 numAddr = instance().highScores().numAddrBytes(myScoreDigits->getSelected() + 1,
|
||||||
myTrailingZeroes->getSelected());
|
myTrailingZeroes->getSelected());
|
||||||
string strText;
|
|
||||||
|
|
||||||
// limit variants and special size
|
|
||||||
strText = myVariations->getText();
|
|
||||||
strText = strText.substr(0, 3);
|
|
||||||
myVariations->setText(strText);
|
|
||||||
|
|
||||||
strText = mySpecial->getText();
|
|
||||||
strText = strText.substr(0, HSM::MAX_SPECIAL);
|
|
||||||
mySpecial->setText(strText);
|
|
||||||
|
|
||||||
// enable widgets
|
// enable widgets
|
||||||
myPlayersLabel->setEnabled(enable);
|
myPlayersLabel->setEnabled(enable);
|
||||||
|
@ -1040,8 +1033,8 @@ void GameInfoDialog::updateHighScoresWidgets()
|
||||||
myVarsZeroBased->setEnabled(enableVars);
|
myVarsZeroBased->setEnabled(enableVars);
|
||||||
|
|
||||||
mySpecialLabel->setEnabled(enable);
|
mySpecialLabel->setEnabled(enable);
|
||||||
mySpecial->setEnabled(enable);
|
mySpecialName->setEnabled(enable);
|
||||||
mySpecial->setEditable(enable);
|
mySpecialName->setEditable(enable);
|
||||||
mySpecialAddressLabel->setEnabled(enableSpecial);
|
mySpecialAddressLabel->setEnabled(enableSpecial);
|
||||||
mySpecialAddress->setEnabled(enableSpecial);
|
mySpecialAddress->setEnabled(enableSpecial);
|
||||||
mySpecialAddress->setEditable(enableSpecial);
|
mySpecialAddress->setEditable(enableSpecial);
|
||||||
|
@ -1049,7 +1042,6 @@ void GameInfoDialog::updateHighScoresWidgets()
|
||||||
mySpecialBCD->setEnabled(enableSpecial);
|
mySpecialBCD->setEnabled(enableSpecial);
|
||||||
mySpecialZeroBased->setEnabled(enableSpecial);
|
mySpecialZeroBased->setEnabled(enableSpecial);
|
||||||
|
|
||||||
mySpecialLabel->setEnabled(enable);
|
|
||||||
myScoreDigitsLabel->setEnabled(enable);
|
myScoreDigitsLabel->setEnabled(enable);
|
||||||
myScoreDigits->setEnabled(enable);
|
myScoreDigits->setEnabled(enable);
|
||||||
myScoreBCD->setEnabled(enable);
|
myScoreBCD->setEnabled(enable);
|
||||||
|
@ -1123,8 +1115,7 @@ void GameInfoDialog::setAddressVal(EditTextWidget* addressWidget, EditTextWidget
|
||||||
|
|
||||||
// limit address size
|
// limit address size
|
||||||
strAddr = addressWidget->getText();
|
strAddr = addressWidget->getText();
|
||||||
strAddr = strAddr.substr(0, 4);
|
strAddr = strAddr.substr(0, HSM::MAX_ADDR_CHARS);
|
||||||
addressWidget->setText(strAddr);
|
|
||||||
|
|
||||||
if (instance().hasConsole() && valWidget->isEnabled())
|
if (instance().hasConsole() && valWidget->isEnabled())
|
||||||
{
|
{
|
||||||
|
@ -1139,7 +1130,7 @@ void GameInfoDialog::setAddressVal(EditTextWidget* addressWidget, EditTextWidget
|
||||||
// format output and display in value widget
|
// format output and display in value widget
|
||||||
if (isBCD)
|
if (isBCD)
|
||||||
ss << hex;
|
ss << hex;
|
||||||
ss << right << setw(2) << setfill(' ')
|
ss << right //<< setw(2) << setfill(' ')
|
||||||
<< uppercase << uInt16(val);
|
<< uppercase << uInt16(val);
|
||||||
valWidget->setText(ss.str());
|
valWidget->setText(ss.str());
|
||||||
}
|
}
|
||||||
|
|
|
@ -131,7 +131,7 @@ class GameInfoDialog : public Dialog, public CommandSender
|
||||||
CheckboxWidget* myVarsZeroBased{nullptr};
|
CheckboxWidget* myVarsZeroBased{nullptr};
|
||||||
|
|
||||||
StaticTextWidget* mySpecialLabel{nullptr};
|
StaticTextWidget* mySpecialLabel{nullptr};
|
||||||
EditTextWidget* mySpecial{nullptr};
|
EditTextWidget* mySpecialName{nullptr};
|
||||||
StaticTextWidget* mySpecialAddressLabel{nullptr};
|
StaticTextWidget* mySpecialAddressLabel{nullptr};
|
||||||
EditTextWidget* mySpecialAddress{nullptr};
|
EditTextWidget* mySpecialAddress{nullptr};
|
||||||
EditTextWidget* mySpecialAddressVal{nullptr};
|
EditTextWidget* mySpecialAddressVal{nullptr};
|
||||||
|
@ -147,8 +147,8 @@ class GameInfoDialog : public Dialog, public CommandSender
|
||||||
StaticTextWidget* myScoreAddressesLabel[HSM::MAX_PLAYERS]{nullptr};
|
StaticTextWidget* myScoreAddressesLabel[HSM::MAX_PLAYERS]{nullptr};
|
||||||
EditTextWidget* myScoreAddress[HSM::MAX_PLAYERS][HSM::MAX_SCORE_ADDR]{nullptr};
|
EditTextWidget* myScoreAddress[HSM::MAX_PLAYERS][HSM::MAX_SCORE_ADDR]{nullptr};
|
||||||
EditTextWidget* myScoreAddressVal[HSM::MAX_PLAYERS][HSM::MAX_SCORE_ADDR]{nullptr};
|
EditTextWidget* myScoreAddressVal[HSM::MAX_PLAYERS][HSM::MAX_SCORE_ADDR]{nullptr};
|
||||||
StaticTextWidget* myCurrentScoreLabel;
|
StaticTextWidget* myCurrentScoreLabel{nullptr};
|
||||||
StaticTextWidget* myCurrentScore[HSM::MAX_PLAYERS];
|
StaticTextWidget* myCurrentScore[HSM::MAX_PLAYERS]{nullptr};
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
kVCenterChanged = 'Vcch',
|
kVCenterChanged = 'Vcch',
|
||||||
|
|
|
@ -55,7 +55,7 @@ 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 ");
|
||||||
myVariation = new PopUpWidget(this, font, s->getRight(), ypos,
|
myVariationWidget = new PopUpWidget(this, font, s->getRight(), ypos,
|
||||||
font.getStringWidth("256") - 4, lineHeight, items, "", 0, 0);
|
font.getStringWidth("256") - 4, lineHeight, items, "", 0, 0);
|
||||||
|
|
||||||
ypos += lineHeight + VGAP * 4;
|
ypos += lineHeight + VGAP * 4;
|
||||||
|
@ -69,7 +69,7 @@ HighScoresDialog::HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
|
|
||||||
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");
|
||||||
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");
|
||||||
|
|
||||||
|
@ -77,25 +77,24 @@ HighScoresDialog::HighScoresDialog(OSystem& osystem, DialogContainer& parent,
|
||||||
|
|
||||||
for (uInt32 p = 0; p < NUM_POSITIONS; ++p)
|
for (uInt32 p = 0; p < NUM_POSITIONS; ++p)
|
||||||
{
|
{
|
||||||
myPositions[p] = new StaticTextWidget(this, font, xposRank, 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));
|
||||||
myScores[p] = new StaticTextWidget(this, font, xposScore, ypos + 1, "123456");
|
myScoresWidget[p] = new StaticTextWidget(this, font, xposScore, ypos + 1, "123456");
|
||||||
mySpecials[p] = new StaticTextWidget(this, font, xposSpecial + 8, ypos + 1, "123");
|
mySpecialsWidget[p] = new StaticTextWidget(this, font, xposSpecial + 8, ypos + 1, "123");
|
||||||
myEditNames[p] = new EditTextWidget(this, font, xposName, ypos - 1, nWidth, lineHeight, "JTZ");
|
myEditNamesWidget[p] = new EditTextWidget(this, font, xposName, ypos - 1, nWidth, lineHeight, "JTZ");
|
||||||
//myEditNames[p]->setEditable(false);
|
myEditNamesWidget[p]->setFlags(EditTextWidget::FLAG_INVISIBLE);
|
||||||
myEditNames[p]->setFlags(EditTextWidget::FLAG_INVISIBLE);
|
wid.push_back(myEditNamesWidget[p]);
|
||||||
wid.push_back(myEditNames[p]);
|
myNamesWidget[p] = new StaticTextWidget(this, font, xposName + 2, ypos + 1, "JTZ");
|
||||||
myNames[p] = new StaticTextWidget(this, font, xposName + 2, ypos + 1, "JTZ");
|
|
||||||
|
|
||||||
//new StaticTextWidget(this, font, xposDate, ypos + 1, "12.02.20 17:15");
|
//new StaticTextWidget(this, font, xposDate, ypos + 1, "12.02.20 17:15");
|
||||||
//new StaticTextWidget(this, font, xposDate, ypos + 1, "02/12/20 12:30am");
|
//new StaticTextWidget(this, font, xposDate, ypos + 1, "02/12/20 12:30am");
|
||||||
myDates[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");
|
||||||
|
|
||||||
ypos += lineHeight + VGAP;
|
ypos += lineHeight + VGAP;
|
||||||
}
|
}
|
||||||
ypos += VGAP * 2;
|
ypos += VGAP * 2;
|
||||||
|
|
||||||
myMD5 = new StaticTextWidget(this, ifont, xpos, ypos + 1, "MD5: 9ad36e699ef6f45d9eb6c4cf90475c9f");
|
myMD5Widget = new StaticTextWidget(this, ifont, xpos, ypos + 1, "MD5: 12345678901234567890123456789012");
|
||||||
|
|
||||||
wid.clear();
|
wid.clear();
|
||||||
addOKCancelBGroup(wid, font);
|
addOKCancelBGroup(wid, font);
|
||||||
|
@ -122,20 +121,27 @@ void HighScoresDialog::loadConfig()
|
||||||
|
|
||||||
items.clear();
|
items.clear();
|
||||||
|
|
||||||
|
myVariation = instance().highScores().variation();
|
||||||
|
|
||||||
for (Int32 i = 1; i <= instance().highScores().numVariations(); ++i)
|
for (Int32 i = 1; i <= instance().highScores().numVariations(); ++i)
|
||||||
{
|
{
|
||||||
ostringstream buf;
|
ostringstream buf;
|
||||||
buf << std::setw(3) << std::setfill(' ') << i;
|
buf << std::setw(3) << std::setfill(' ') << i;
|
||||||
VarList::push_back(items, buf.str(), i);
|
VarList::push_back(items, buf.str(), i);
|
||||||
}
|
}
|
||||||
myVariation->addItems(items);
|
myVariationWidget->addItems(items);
|
||||||
myVariation->setSelected(instance().highScores().variation());
|
|
||||||
|
|
||||||
|
myScore = instance().highScores().score();
|
||||||
|
mySpecial = instance().highScores().special();
|
||||||
|
myVariationWidget->setSelected(myVariation);
|
||||||
|
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
// mock data
|
// mock data
|
||||||
const string SCORES[NUM_POSITIONS] = {"999999", "250000", "100000", " 50000", " 20000",
|
const Int32 SCORES[NUM_POSITIONS] = {999999, 250000, 100000, 50000, 20000,
|
||||||
" 5000", " 2000", " 700", " 200", " -"};
|
5000, 2000, 200, 20, 0};
|
||||||
const string SPECIALS[NUM_POSITIONS] = {"200", "150", " 90", " 70", " 45",
|
const Int32 SPECIALS[NUM_POSITIONS] = {200, 150, 90, 70, 45,
|
||||||
" 30", " 25", " 10", " 7", " -"};
|
30, 25, 10, 7, 0};
|
||||||
const string NAMES[NUM_POSITIONS] = {"RAM", "CDW", "AD ", "JTZ", "DOA",
|
const string NAMES[NUM_POSITIONS] = {"RAM", "CDW", "AD ", "JTZ", "DOA",
|
||||||
"ROM", "VCS", "N.S", "JWC", " -"};
|
"ROM", "VCS", "N.S", "JWC", " -"};
|
||||||
const string DATES[NUM_POSITIONS] = {"19-12-24 21:00", "19-07-18 00:00", "20-01-01 12:00",
|
const string DATES[NUM_POSITIONS] = {"19-12-24 21:00", "19-07-18 00:00", "20-01-01 12:00",
|
||||||
|
@ -145,18 +151,66 @@ void HighScoresDialog::loadConfig()
|
||||||
|
|
||||||
for (Int32 p = 0; p < NUM_POSITIONS; ++p)
|
for (Int32 p = 0; p < NUM_POSITIONS; ++p)
|
||||||
{
|
{
|
||||||
myScores[p]->setLabel(SCORES[p]);
|
myScores[p] = SCORES[p];
|
||||||
mySpecials[p]->setLabel(SPECIALS[p]);
|
mySpecials[p] = SPECIALS[p];
|
||||||
myNames[p]->setLabel(NAMES[p]);
|
myNames[p] = NAMES[p];
|
||||||
myEditNames[p]->setText(NAMES[p]);
|
myDates[p] = DATES[p];
|
||||||
myDates[p]->setLabel(DATES[p]);
|
}
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
Int32 pos;
|
||||||
|
|
||||||
|
mySpecialLabelWidget->setLabel(instance().highScores().specialLabel());
|
||||||
|
|
||||||
|
for (Int32 p = 0; p < NUM_POSITIONS; ++p)
|
||||||
|
myEditNamesWidget[p]->setFlags(EditTextWidget::FLAG_INVISIBLE);
|
||||||
|
|
||||||
|
if (myScore > 0)
|
||||||
|
{
|
||||||
|
for (pos = 0; pos < NUM_POSITIONS; ++pos)
|
||||||
|
{
|
||||||
|
if (myScore > myScores[pos] ||
|
||||||
|
(myScore == myScores[pos] && mySpecial > mySpecials[pos]))
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pos < NUM_POSITIONS)
|
||||||
|
{
|
||||||
|
for (Int32 p = NUM_POSITIONS - 1; p > pos; --p)
|
||||||
|
{
|
||||||
|
myScores[p] = myScores[p - 1];
|
||||||
|
mySpecials[p] = mySpecials[p - 1];
|
||||||
|
myNames[p] = myNames[p - 1];
|
||||||
|
myDates[p] = myDates[p - 1];
|
||||||
|
}
|
||||||
|
myScores[pos] = myScore;
|
||||||
|
myNames[pos] = "";
|
||||||
|
mySpecials[pos] = mySpecial;
|
||||||
|
myDates[pos] = now();
|
||||||
|
|
||||||
|
myEditNamesWidget[pos]->clearFlags(EditTextWidget::FLAG_INVISIBLE);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//myEditNames[4]->setEditable(true);
|
for (Int32 p = 0; p < NUM_POSITIONS; ++p)
|
||||||
|
{
|
||||||
|
ostringstream buf;
|
||||||
|
|
||||||
|
buf << std::setw(HSM::MAX_SCORE_DIGITS) << std::setfill(' ') << myScores[p];
|
||||||
|
myScoresWidget[p]->setLabel(buf.str());
|
||||||
|
buf.str("");
|
||||||
|
buf << std::setw(HSM::MAX_SPECIAL_DIGITS) << std::setfill(' ') << mySpecials[p];
|
||||||
|
mySpecialsWidget[p]->setLabel(buf.str());
|
||||||
|
myNamesWidget[p]->setLabel(myNames[p]);
|
||||||
|
myEditNamesWidget[p]->setText(myNames[p]);
|
||||||
|
myDatesWidget[p]->setLabel(myDates[p]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void HighScoresDialog::saveConfig()
|
||||||
|
{
|
||||||
|
|
||||||
//myNames[3]->setHeight(1);
|
|
||||||
//myNames[3]->setWidth(0);
|
|
||||||
myEditNames[4]->clearFlags(EditTextWidget::FLAG_INVISIBLE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -165,12 +219,32 @@ void HighScoresDialog::handleCommand(CommandSender* sender, int cmd, int data, i
|
||||||
switch (cmd)
|
switch (cmd)
|
||||||
{
|
{
|
||||||
case kOKCmd:
|
case kOKCmd:
|
||||||
|
saveConfig();
|
||||||
case kCloseCmd:
|
case kCloseCmd:
|
||||||
instance().eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
instance().eventHandler().handleEvent(Event::ExitMode);
|
// instance().eventHandler().handleEvent(Event::ExitMode);
|
||||||
|
|
||||||
|
// case GuiObject::kOKCmd:
|
||||||
|
// close();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
Dialog::handleCommand(sender, cmd, data, 0);
|
Dialog::handleCommand(sender, cmd, data, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
string HighScoresDialog::now() const
|
||||||
|
{
|
||||||
|
std::tm now = BSPF::localTime();
|
||||||
|
ostringstream ss;
|
||||||
|
|
||||||
|
ss << std::setfill('0') << std::right
|
||||||
|
<< std::setw(2) << (now.tm_year - 100) << '-'
|
||||||
|
<< std::setw(2) << (now.tm_mon + 1) << '-'
|
||||||
|
<< std::setw(2) << now.tm_mday << " "
|
||||||
|
<< std::setw(2) << now.tm_hour << ":"
|
||||||
|
<< std::setw(2) << now.tm_min;
|
||||||
|
|
||||||
|
return ss.str();
|
||||||
|
}
|
||||||
|
|
|
@ -44,17 +44,31 @@ class HighScoresDialog : public Dialog
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void loadConfig() override;
|
void loadConfig() override;
|
||||||
|
void saveConfig() override;
|
||||||
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
void handleCommand(CommandSender* sender, int cmd, int data, int id) override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
PopUpWidget* myVariation;
|
Int32 myVariation;
|
||||||
StaticTextWidget* myPositions[NUM_POSITIONS];
|
Int32 myScore;
|
||||||
StaticTextWidget* myScores[NUM_POSITIONS];
|
Int32 mySpecial;
|
||||||
StaticTextWidget* mySpecials[NUM_POSITIONS];
|
|
||||||
StaticTextWidget* myNames[NUM_POSITIONS];
|
Int32 myScores[NUM_POSITIONS];
|
||||||
EditTextWidget* myEditNames[NUM_POSITIONS];
|
Int32 mySpecials[NUM_POSITIONS];
|
||||||
StaticTextWidget* myDates[NUM_POSITIONS];
|
string myNames[NUM_POSITIONS];
|
||||||
StaticTextWidget* myMD5;
|
string myDates[NUM_POSITIONS];
|
||||||
|
string myMD5;
|
||||||
|
|
||||||
|
PopUpWidget* myVariationWidget{nullptr};
|
||||||
|
StaticTextWidget* mySpecialLabelWidget{nullptr};
|
||||||
|
StaticTextWidget* myPositionsWidget[NUM_POSITIONS]{nullptr};
|
||||||
|
StaticTextWidget* myScoresWidget[NUM_POSITIONS]{nullptr};
|
||||||
|
StaticTextWidget* mySpecialsWidget[NUM_POSITIONS]{nullptr};
|
||||||
|
StaticTextWidget* myNamesWidget[NUM_POSITIONS]{nullptr};
|
||||||
|
EditTextWidget* myEditNamesWidget[NUM_POSITIONS]{nullptr};
|
||||||
|
StaticTextWidget* myDatesWidget[NUM_POSITIONS]{nullptr};
|
||||||
|
StaticTextWidget* myMD5Widget{nullptr};
|
||||||
|
|
||||||
|
string now() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
// Following constructors and assignment operators not supported
|
// Following constructors and assignment operators not supported
|
||||||
|
|
Loading…
Reference in New Issue