Added all editable game properties to GameInfoDialog. At this point,

only the 'Cartridge' properties can be saved to user.pro, and only
if you manually hit the merge keys (Alt-s).  Once this is complete,
the properties will be saved automatically when 'OK' is pressed, and
a ROM reload will make those new properties take effect.


git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@801 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
stephena 2005-09-30 00:40:34 +00:00
parent 9ba65abb12
commit c6ac381c01
15 changed files with 357 additions and 107 deletions

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: SoundSDL.cxx,v 1.25 2005-09-10 16:19:20 bwmott Exp $
// $Id: SoundSDL.cxx,v 1.26 2005-09-30 00:40:33 stephena Exp $
//============================================================================
#ifdef SOUND_SUPPORT

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: DebuggerDialog.cxx,v 1.6 2005-09-20 19:09:10 stephena Exp $
// $Id: DebuggerDialog.cxx,v 1.7 2005-09-30 00:40:33 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -192,6 +192,7 @@ void DebuggerDialog::addStatusArea()
font.getLineHeight(), "");
myMessageBox->setFont(font);
myMessageBox->setEditable(false);
myMessageBox->setColor(kTextColorEm);
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: Console.cxx,v 1.72 2005-09-23 23:35:02 stephena Exp $
// $Id: Console.cxx,v 1.73 2005-09-30 00:40:33 stephena Exp $
//============================================================================
#include <assert.h>
@ -190,9 +190,7 @@ Console::Console(const uInt8* image, uInt32 size, OSystem* osystem)
// Initialize the sound interface.
// The # of channels can be overridden in the AudioDialog box or on
// the commandline, but it can't be saved.
uInt32 channels = myOSystem->settings().getInt("channels");
if(channels == 0)
{
uInt32 channels;
string s = myProperties.get("Cartridge.Sound", true);
if(s == "STEREO")
channels = 2;
@ -200,7 +198,8 @@ Console::Console(const uInt8* image, uInt32 size, OSystem* osystem)
channels = 1;
else
channels = 1;
}
myOSystem->sound().close();
myOSystem->sound().setChannels(channels);
myOSystem->sound().setFrameRate(framerate);
myOSystem->sound().initialize();

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: CheatCodeDialog.cxx,v 1.6 2005-09-26 19:10:37 stephena Exp $
// $Id: CheatCodeDialog.cxx,v 1.7 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -38,7 +38,8 @@ enum {
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
CheatCodeDialog::CheatCodeDialog(OSystem* osystem, DialogContainer* parent,
int x, int y, int w, int h)
: Dialog(osystem, parent, x, y, w, h)
: Dialog(osystem, parent, x, y, w, h),
myErrorFlag(false)
{
const GUI::Font& font = instance()->font();
const int fontHeight = font.getFontHeight(),
@ -85,6 +86,7 @@ void CheatCodeDialog::handleCommand(CommandSender* sender, int cmd,
{
// make sure "invalid code" isn't showing any more:
myError->setLabel("");
myErrorFlag = false;
// set up the cheat
myCheat->enable();
@ -96,11 +98,11 @@ void CheatCodeDialog::handleCommand(CommandSender* sender, int cmd,
}
else // parse() returned 0 (null)
{
// cerr << "bad cheat code" << endl;
myInput->setEditString("");
// show error message "invalid code":
myInput->setEditString("");
myError->setLabel("Invalid Code");
myErrorFlag = true;
// not sure this does anything useful:
Dialog::handleCommand(sender, cmd, data, 0);
@ -112,6 +114,15 @@ void CheatCodeDialog::handleCommand(CommandSender* sender, int cmd,
instance()->eventHandler().leaveMenuMode();
break;
case kEditChangedCmd:
// Erase the invalid message once editing is restarted
if(myErrorFlag)
{
myError->setLabel("");
myErrorFlag = false;
}
break;
default:
Dialog::handleCommand(sender, cmd, data, 0);
break;

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: CheatCodeDialog.hxx,v 1.3 2005-09-26 19:10:37 stephena Exp $
// $Id: CheatCodeDialog.hxx,v 1.4 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -54,6 +54,8 @@ class CheatCodeDialog : public Dialog
StaticTextWidget* myError;
EditTextWidget* myInput;
// CheckboxWidget* myEnableCheat;
bool myErrorFlag;
};
#endif

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: Dialog.cxx,v 1.30 2005-09-29 18:50:51 stephena Exp $
// $Id: Dialog.cxx,v 1.31 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -122,7 +122,7 @@ void Dialog::addToFocusList(WidgetArray& list, int id)
_ourFocusList[id].focusList.push_back(list);
if(list.size() > 0)
if(list.size() > 0 && !(list[0]->getFlags() & WIDGET_NODRAW_FOCUS))
_ourFocusList[id].focusedWidget = list[0];
}

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: EditTextWidget.cxx,v 1.9 2005-08-11 19:12:39 stephena Exp $
// $Id: EditTextWidget.cxx,v 1.10 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -33,6 +33,9 @@ EditTextWidget::EditTextWidget(GuiObject* boss, int x, int y, int w, int h,
_flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS;
_type = kEditTextWidget;
if(text == "name")
cerr << "EditTextWidget(): _x = " << _x << ", _y = " << _y << endl << endl;
setEditString(text);
}
@ -68,6 +71,9 @@ void EditTextWidget::handleMouseDown(int x, int y, int button, int clickCount)
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void EditTextWidget::drawWidget(bool hilite)
{
//cerr << "EditTextWidget::drawWidget(): (" << _editString << ") " << this << endl
// << "_x = " << _x << ", _y = " << _y << endl << endl;
FrameBuffer& fb = _boss->instance()->frameBuffer();
// Draw a thin frame around us.
@ -79,7 +85,7 @@ void EditTextWidget::drawWidget(bool hilite)
// Draw the text
adjustOffset();
fb.drawString(_font, _editString, _x + 2, _y + 2, getEditRect().width(),
kTextColor, kTextAlignLeft, -_editScrollOffset, false);
_color, kTextAlignLeft, -_editScrollOffset, false);
// Draw the caret
drawCaret();

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: EditableWidget.cxx,v 1.12 2005-09-29 18:50:51 stephena Exp $
// $Id: EditableWidget.cxx,v 1.13 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -135,6 +135,7 @@ bool EditableWidget::handleKeyDown(int ascii, int keycode, int modifiers)
if (tryInsertChar((char)ascii, _caretPos))
{
_caretPos++;
sendCommand(kEditChangedCmd, ascii, _id);
dirty = true;
}
else

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: EditableWidget.hxx,v 1.6 2005-08-11 19:12:39 stephena Exp $
// $Id: EditableWidget.hxx,v 1.7 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -27,7 +27,8 @@
enum {
kEditAcceptCmd = 'EDac',
kEditCancelCmd = 'EDcl'
kEditCancelCmd = 'EDcl',
kEditChangedCmd = 'EDch'
};
/**

View File

@ -13,12 +13,15 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: GameInfoDialog.cxx,v 1.13 2005-09-29 18:50:51 stephena Exp $
// $Id: GameInfoDialog.cxx,v 1.14 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
//============================================================================
#include <cctype>
#include <algorithm>
#include "GuiUtils.hxx"
#include "OSystem.hxx"
#include "Props.hxx"
@ -42,6 +45,7 @@ GameInfoDialog::GameInfoDialog(
const int vBorder = 4;
int xpos, ypos, lwidth, fwidth, tabID;
unsigned int i;
WidgetArray wid;
// The tab widget
@ -55,69 +59,107 @@ GameInfoDialog::GameInfoDialog(
xpos = 10;
lwidth = font.getStringWidth("Manufacturer: ");
fwidth = _w - xpos - lwidth - 10;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Name:", kTextAlignLeft);
myName = new EditTextWidget(myTab, xpos+lwidth, ypos, fwidth, fontHeight, "");
wid.push_back(myName);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"MD5:", kTextAlignLeft);
myMD5 = new StaticTextWidget(myTab, xpos+lwidth, ypos,
fwidth, fontHeight,
"", kTextAlignLeft);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Manufacturer:", kTextAlignLeft);
myManufacturer = new EditTextWidget(myTab, xpos+lwidth, ypos,
100, fontHeight, "");
wid.push_back(myManufacturer);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Model:", kTextAlignLeft);
myModelNo = new EditTextWidget(myTab, xpos+lwidth, ypos,
100, fontHeight, "");
wid.push_back(myModelNo);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Rarity:", kTextAlignLeft);
myRarity = new EditTextWidget(myTab, xpos+lwidth, ypos,
100, fontHeight, "");
wid.push_back(myRarity);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Note:", kTextAlignLeft);
myNote = new EditTextWidget(myTab, xpos+lwidth, ypos,
fwidth, fontHeight, "");
wid.push_back(myNote);
/*
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Sound:", kTextAlignLeft);
mySound = new EditTextWidget(myTab, xpos+lwidth, ypos,
100, fontHeight, "");
mySound = new PopUpWidget(myTab, xpos+lwidth, ypos,
font.getStringWidth("Stereo") + 15, lineHeight,
"", 0, 0);
mySound->appendEntry("Mono", 1);
mySound->appendEntry("Stereo", 2);
wid.push_back(mySound);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos, lwidth, fontHeight,
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Type:", kTextAlignLeft);
myType = new EditTextWidget(myTab, xpos+lwidth, ypos,
100, fontHeight, "");
wid.push_back(myType);
*/
myType = new PopUpWidget(myTab, xpos+lwidth, ypos,
font.getStringWidth("Auto-detect") + 15, lineHeight,
"", 0, 0);
myType->appendEntry("Auto-detect", 1);
myType->appendEntry("2K", 2);
myType->appendEntry("3E", 3);
wid.push_back(myType); // FIXME - add rest of types
// Add items for tab 0
addToFocusList(wid, tabID);
// 2) Console/Controller properties
wid.clear();
tabID = myTab->addTab("Console");
xpos = 10; ypos = vBorder;
lwidth = font.getStringWidth("Right Difficulty: ");
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Left Difficulty:", kTextAlignLeft);
myLeftDiff = new PopUpWidget(myTab, xpos+lwidth, ypos,
font.getStringWidth(" ") + 15, lineHeight,
"", 0, 0);
myLeftDiff->appendEntry("B", 1);
myLeftDiff->appendEntry("A", 2);
wid.push_back(myLeftDiff);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Right Difficulty:", kTextAlignLeft);
myRightDiff = new PopUpWidget(myTab, xpos+lwidth, ypos,
font.getStringWidth(" ") + 15, lineHeight,
"", 0, 0);
myRightDiff->appendEntry("B", 1);
myRightDiff->appendEntry("A", 2);
wid.push_back(myRightDiff);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"TV Type:", kTextAlignLeft);
myTVType = new PopUpWidget(myTab, xpos+lwidth, ypos,
font.getStringWidth("B & W") + 15, lineHeight,
"", 0, 0);
myTVType->appendEntry("Color", 1);
myTVType->appendEntry("B & W", 2);
wid.push_back(myTVType);
// Add items for tab 1
addToFocusList(wid, tabID);
@ -125,6 +167,29 @@ GameInfoDialog::GameInfoDialog(
wid.clear();
tabID = myTab->addTab("Controller");
xpos = 10; ypos = vBorder;
lwidth = font.getStringWidth("Right Controller: ");
fwidth = font.getStringWidth("Booster-Grip");
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Left Controller:", kTextAlignLeft);
myLeftController = new PopUpWidget(myTab, xpos+lwidth, ypos,
fwidth + 15, lineHeight,
"", 0, 0);
for(i = 0; i < 5; ++i)
myLeftController->appendEntry(ourControllerList[i].name, i+1);
wid.push_back(myLeftController);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Right Controller:", kTextAlignLeft);
myRightController = new PopUpWidget(myTab, xpos+lwidth, ypos,
fwidth + 15, lineHeight,
"", 0, 0);
for(i = 0; i < 5; ++i)
myRightController->appendEntry(ourControllerList[i].name, i+1);
wid.push_back(myRightController);
// Add items for tab 2
addToFocusList(wid, tabID);
@ -132,30 +197,58 @@ GameInfoDialog::GameInfoDialog(
wid.clear();
tabID = myTab->addTab("Display");
xpos = 10; ypos = vBorder;
lwidth = font.getStringWidth("Use HMBlanks: ");
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Format:", kTextAlignLeft);
myFormat = new PopUpWidget(myTab, xpos+lwidth, ypos,
font.getStringWidth("NTSC") + 15, lineHeight,
"", 0, 0);
myFormat->appendEntry("NTSC", 1);
myFormat->appendEntry("PAL", 2);
wid.push_back(myFormat);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"XStart:", kTextAlignLeft);
myXStart = new EditTextWidget(myTab, xpos+lwidth, ypos,
25, fontHeight, "");
wid.push_back(myXStart);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Width:", kTextAlignLeft);
myWidth = new EditTextWidget(myTab, xpos+lwidth, ypos,
25, fontHeight, "");
wid.push_back(myWidth);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"YStart:", kTextAlignLeft);
myYStart = new EditTextWidget(myTab, xpos+lwidth, ypos,
25, fontHeight, "");
wid.push_back(myYStart);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Height:", kTextAlignLeft);
myHeight = new EditTextWidget(myTab, xpos+lwidth, ypos,
25, fontHeight, "");
wid.push_back(myHeight);
ypos += lineHeight + 3;
new StaticTextWidget(myTab, xpos, ypos+1, lwidth, fontHeight,
"Use HMBlanks:", kTextAlignLeft);
myHmoveBlanks = new PopUpWidget(myTab, xpos+lwidth, ypos,
font.getStringWidth("Yes") + 15, lineHeight,
"", 0, 0);
myHmoveBlanks->appendEntry("Yes", 1);
myHmoveBlanks->appendEntry("No", 2);
wid.push_back(myHmoveBlanks);
// Add items for tab 3
addToFocusList(wid, tabID);
/*
// Snapshot path
xpos = 15;
new ButtonWidget(myTab, xpos, ypos, kButtonWidth + 14, 16, "Path",
kChooseSnapDirCmd, 0);
xpos += kButtonWidth + 30;
mySnapPath = new StaticTextWidget(myTab, xpos, ypos + 3,
_w - xpos - 10, kLineHeight,
"", kTextAlignLeft);
// Snapshot save name
xpos = 10; ypos += 22;
mySnapTypePopup = new PopUpWidget(myTab, xpos, ypos, 140, kLineHeight,
"Save snapshot as: ", 87, 0);
mySnapTypePopup->appendEntry("romname", 1);
mySnapTypePopup->appendEntry("md5sum", 2);
// Snapshot single or multiple saves
xpos = 30; ypos += 18;
mySnapSingleCheckbox = new CheckboxWidget(myTab, font, xpos, ypos,
"Multiple snapshots");
*/
// Activate the first tab
myTab->setActiveTab(0);
@ -183,7 +276,9 @@ GameInfoDialog::~GameInfoDialog()
void GameInfoDialog::loadConfig()
{
string s;
int i;
// Cartridge properties
s = myGameProperties->get("Cartridge.Name");
myName->setEditString(s);
@ -202,15 +297,96 @@ void GameInfoDialog::loadConfig()
s = myGameProperties->get("Cartridge.Note");
myNote->setEditString(s);
/*
s = instance()->settings().getString("ssname");
if(s == "romname")
mySnapTypePopup->setSelectedTag(1);
else if(s == "md5sum")
mySnapTypePopup->setSelectedTag(2);
s = myGameProperties->get("Cartridge.Sound", true);
if(s == "MONO")
mySound->setSelectedTag(1);
else if(s == "STEREO")
mySound->setSelectedTag(2);
else
mySnapTypePopup->setSelectedTag(0);
*/
mySound->setSelectedTag(0);
// FIXME - add type properties
// Console properties
s = myGameProperties->get("Console.LeftDifficulty", true);
if(s == "B")
myLeftDiff->setSelectedTag(1);
else if(s == "A")
myLeftDiff->setSelectedTag(2);
else
myLeftDiff->setSelectedTag(0);
s = myGameProperties->get("Console.RightDifficulty", true);
if(s == "B")
myRightDiff->setSelectedTag(1);
else if(s == "A")
myRightDiff->setSelectedTag(2);
else
myRightDiff->setSelectedTag(0);
s = myGameProperties->get("Console.RightDifficulty", true);
if(s == "B")
myRightDiff->setSelectedTag(1);
else if(s == "A")
myRightDiff->setSelectedTag(2);
else
myRightDiff->setSelectedTag(0);
s = myGameProperties->get("Console.TelevisionType", true);
if(s == "COLOR")
myTVType->setSelectedTag(1);
else if(s == "BLACKANDWHITE")
myTVType->setSelectedTag(2);
else
myTVType->setSelectedTag(0);
// Controller properties
s = myGameProperties->get("Controller.Left", true);
for(i = 0; i < 5; ++i)
{
if(s == ourControllerList[i].comparitor)
break;
}
i = (i == 5) ? 0: i + 1;
myLeftController->setSelectedTag(i);
s = myGameProperties->get("Controller.Right", true);
for(i = 0; i < 5; ++i)
{
if(s == ourControllerList[i].comparitor)
break;
}
i = (i == 5) ? 0: i + 1;
myRightController->setSelectedTag(i);
// Display properties
s = myGameProperties->get("Display.Format", true);
if(s == "NTSC")
myFormat->setSelectedTag(1);
else if(s == "PAL")
myFormat->setSelectedTag(2);
else
myFormat->setSelectedTag(0);
s = myGameProperties->get("Display.XStart");
myXStart->setEditString(s);
s = myGameProperties->get("Display.Width");
myWidth->setEditString(s);
s = myGameProperties->get("Display.YStart");
myYStart->setEditString(s);
s = myGameProperties->get("Display.Height");
myHeight->setEditString(s);
s = myGameProperties->get("Emulation.HmoveBlanks", true);
if(s == "YES")
myHmoveBlanks->setSelectedTag(1);
else if(s == "NO")
myHmoveBlanks->setSelectedTag(2);
else
myHmoveBlanks->setSelectedTag(0);
myTab->loadConfig();
}
@ -218,26 +394,33 @@ void GameInfoDialog::loadConfig()
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
void GameInfoDialog::saveConfig()
{
cerr << "saveConfig()\n";
/*
string s;
bool b;
int i;
s = myRomPath->getLabel();
instance()->settings().setString("romdir", s);
// Cartridge properties
s = myName->getEditString();
myGameProperties->set("Cartridge.Name", s);
s = mySnapPath->getLabel();
instance()->settings().setString("ssdir", s);
s = myManufacturer->getEditString();
myGameProperties->set("Cartridge.Manufacturer", s);
s = myModelNo->getEditString();
myGameProperties->set("Cartridge.ModelNo", s);
s = myRarity->getEditString();
myGameProperties->set("Cartridge.Rarity", s);
s = myNote->getEditString();
myGameProperties->set("Cartridge.Note", s);
i = mySound->getSelectedTag();
s = (i == 1) ? "Mono" : "Stereo";
myGameProperties->set("Cartridge.Sound", s);
// FIXME - type
s = mySnapTypePopup->getSelectedString();
instance()->settings().setString("ssname", s);
b = mySnapSingleCheckbox->getState();
instance()->settings().setBool("sssingle", !b);
// Flush changes to disk
instance()->settings().saveConfig();
*/
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
@ -256,3 +439,12 @@ void GameInfoDialog::handleCommand(CommandSender* sender, int cmd,
break;
}
}
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
const PropType GameInfoDialog::ourControllerList[5] = {
{ "Booster-Grip", "BOOSTER-GRIP" },
{ "Driving", "DRIVING" },
{ "Keyboard", "KEYBOARD" },
{ "Paddles", "PADDLES" },
{ "Joystick", "JOYSTICK" }
};

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: GameInfoDialog.hxx,v 1.10 2005-09-29 18:50:51 stephena Exp $
// $Id: GameInfoDialog.hxx,v 1.11 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -30,9 +30,16 @@ class StaticTextWidget;
class TabWidget;
class Properties;
#include "Array.hxx"
#include "Dialog.hxx"
#include "Command.hxx"
// Structure used for cartridge and controller types
struct PropType {
string name;
string comparitor;
};
class GameInfoDialog : public Dialog, public CommandSender
{
public:
@ -59,10 +66,12 @@ class GameInfoDialog : public Dialog, public CommandSender
PopUpWidget* mySound;
PopUpWidget* myType;
// Console/controller properties
// Console properties
PopUpWidget* myLeftDiff;
PopUpWidget* myRightDiff;
PopUpWidget* myTVType;
// Controller properties
PopUpWidget* myLeftController;
PopUpWidget* myRightController;
@ -74,10 +83,14 @@ class GameInfoDialog : public Dialog, public CommandSender
EditTextWidget* myHeight;
PopUpWidget* myHmoveBlanks;
/** Game properties for currently loaded ROM */
Properties* myGameProperties;
ButtonWidget* myNextButton;
ButtonWidget* myPrevButton;
/** Holds static strings for Cartridge type */
static const PropType ourCartridgeList[20];
/** Holds static strings for Controller type */
static const PropType ourControllerList[5];
};
#endif

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: OptionsDialog.cxx,v 1.30 2005-09-28 22:49:06 stephena Exp $
// $Id: OptionsDialog.cxx,v 1.31 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -80,7 +80,7 @@ OptionsDialog::OptionsDialog(OSystem* osystem, DialogContainer* parent)
b->clearFlags(WIDGET_ENABLED);
#endif
addBigButton("Event Mapping", kEMapCmd, 0);
addBigButton("Game Information", kInfoCmd, 0);
addBigButton("Game Properties", kInfoCmd, 0);
addBigButton("Cheat Code", kCheatCmd, 0);
addBigButton("Help", kHelpCmd, 0);
addBigButton("About", kAboutCmd, 0);
@ -104,7 +104,7 @@ OptionsDialog::OptionsDialog(OSystem* osystem, DialogContainer* parent)
checkBounds(fbWidth, fbHeight, &x, &y, &w, &h);
myEventMappingDialog = new EventMappingDialog(myOSystem, parent, x, y, w, h);
w = 255; h = 150;
w = 255; h = 175;
checkBounds(fbWidth, fbHeight, &x, &y, &w, &h);
myGameInfoDialog = new GameInfoDialog(myOSystem, parent, this, x, y, w, h);

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: PopUpWidget.cxx,v 1.19 2005-09-23 23:35:02 stephena Exp $
// $Id: PopUpWidget.cxx,v 1.20 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -272,7 +272,8 @@ PopUpWidget::PopUpWidget(GuiObject* boss, int x, int y, int w, int h,
_labelWidth(labelWidth),
_cmd(cmd)
{
_flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS;
_flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS |
WIDGET_NODRAW_FOCUS;
_type = kPopUpWidget;
_selectedItem = -1;

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: Widget.cxx,v 1.36 2005-09-23 23:35:02 stephena Exp $
// $Id: Widget.cxx,v 1.37 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -28,6 +28,7 @@
#include "bspf.hxx"
#include "GuiUtils.hxx"
#include "Widget.hxx"
#include "EditableWidget.hxx"
//static int COUNT = 0;
@ -39,6 +40,7 @@ Widget::Widget(GuiObject* boss, int x, int y, int w, int h)
_id(-1),
_flags(0),
_hasFocus(false),
_drawFocusBorder(false),
_color(kTextColor)
{
// Insert into the widget list of the boss
@ -74,6 +76,16 @@ void Widget::draw()
_x = getAbsX();
_y = getAbsY();
if(_type == kEditTextWidget)
{
EditableWidget* t = (EditableWidget*) this;
if(t->getEditString() == "name")
{
cerr << "oldX = " << oldX << ", oldY = " << oldY << endl
<< "_x = " << _x << ", _y = " << _y << endl << endl;
}
}
// Clear background (unless alpha blending is enabled)
if(_flags & WIDGET_CLEARBG)
fb.fillRect(_x, _y, _w, _h, kBGColor);
@ -94,6 +106,13 @@ void Widget::draw()
// Now perform the actual widget draw
drawWidget((_flags & WIDGET_HILITED) ? true : false);
// Draw focus border
if(_drawFocusBorder)
{
_drawFocusBorder = false;
}
// Restore x/y
if (_flags & WIDGET_BORDER) {
_x -= 4;
@ -235,7 +254,9 @@ Widget* Widget::setFocusForChain(GuiObject* boss, WidgetArray& arr,
{
tmp->lostFocus();
if(!(tmp->_flags & WIDGET_NODRAW_FOCUS))
// tmp->_drawFocusBorder = true;
fb.frameRect(x, y, w, h, kBGColor);
tmp->setDirty(); tmp->draw();
fb.addDirtyRect(x, y, w, h);
}
@ -274,6 +295,7 @@ Widget* Widget::setFocusForChain(GuiObject* boss, WidgetArray& arr,
tmp->receivedFocus();
if(!(tmp->_flags & WIDGET_NODRAW_FOCUS))
// tmp->_drawFocusBorder = true;
fb.frameRect(x, y, w, h, kTextColorEm, kDashLine);
tmp->setDirty(); tmp->draw();

View File

@ -13,7 +13,7 @@
// See the file "license" for information on usage and redistribution of
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
//
// $Id: Widget.hxx,v 1.37 2005-09-16 18:15:44 stephena Exp $
// $Id: Widget.hxx,v 1.38 2005-09-30 00:40:34 stephena Exp $
//
// Based on code from ScummVM - Scumm Interpreter
// Copyright (C) 2002-2004 The ScummVM project
@ -72,7 +72,7 @@ enum {
This is the base class for all widgets.
@author Stephen Anthony
@version $Id: Widget.hxx,v 1.37 2005-09-16 18:15:44 stephena Exp $
@version $Id: Widget.hxx,v 1.38 2005-09-30 00:40:34 stephena Exp $
*/
class Widget : public GuiObject
{
@ -142,6 +142,7 @@ class Widget : public GuiObject
int _id;
int _flags;
bool _hasFocus;
bool _drawFocusBorder;
OverlayColor _color;
public: