mirror of https://github.com/stella-emu/stella.git
Started huge rework of the FrameBuffer UI. The basic idea is that
in-game dialogs are now rendered into separate surfaces, and then layered onto the SDL screen when necessary. The biggest advantage of this is now each 'window' is separate, and won't be affected by the scaling or filtering of other windows. For example, zooming the TIA image no longer changes the size of UI text overlaid on the TIA. Similarly, eventually graphical filters will be added, and filters applied to the TIA won't affect the UI. There's too many changes to list, so for now I'll list what doesn't work: * OpenGL mode (don't even try it) * Several popup dialogs in the debugger * RomInfo stuff is completely broken * Scanline count and FrameBuffer 'messages' aren't shown * Larger fonts - fonts are no longer scaled; we have to use larger ones, and update the UI accordingly * Probably a lot of other stuff I forgot to mention This is a huge undertaking, similar in scale to when the UI was first added in 2.0 release. So it might take some time for this to stabilize ... git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1537 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
340ee7d167
commit
84cd5d1d78
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CheatCodeDialog.cxx,v 1.17 2008-02-06 13:45:19 stephena Exp $
|
// $Id: CheatCodeDialog.cxx,v 1.18 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -105,7 +105,7 @@ void CheatCodeDialog::loadConfig()
|
||||||
StringList l;
|
StringList l;
|
||||||
BoolArray b;
|
BoolArray b;
|
||||||
|
|
||||||
const CheatList& list = instance()->cheat().list();
|
const CheatList& list = instance().cheat().list();
|
||||||
for(unsigned int i = 0; i < list.size(); ++i)
|
for(unsigned int i = 0; i < list.size(); ++i)
|
||||||
{
|
{
|
||||||
l.push_back(list[i]->name());
|
l.push_back(list[i]->name());
|
||||||
|
@ -125,7 +125,7 @@ void CheatCodeDialog::loadConfig()
|
||||||
void CheatCodeDialog::saveConfig()
|
void CheatCodeDialog::saveConfig()
|
||||||
{
|
{
|
||||||
// Inspect checkboxes for enable/disable codes
|
// Inspect checkboxes for enable/disable codes
|
||||||
const CheatList& list = instance()->cheat().list();
|
const CheatList& list = instance().cheat().list();
|
||||||
for(unsigned int i = 0; i < myCheatList->getList().size(); ++i)
|
for(unsigned int i = 0; i < myCheatList->getList().size(); ++i)
|
||||||
{
|
{
|
||||||
if(myCheatList->getState(i))
|
if(myCheatList->getState(i))
|
||||||
|
@ -140,7 +140,7 @@ void CheatCodeDialog::addCheat()
|
||||||
{
|
{
|
||||||
// We have to add the dialog first, so it can be centered
|
// We have to add the dialog first, so it can be centered
|
||||||
// The methods after this depend on the dialog having the correct dimensions
|
// The methods after this depend on the dialog having the correct dimensions
|
||||||
parent()->addDialog(myCheatInput);
|
parent().addDialog(myCheatInput);
|
||||||
myCheatInput->setEditString("", 0);
|
myCheatInput->setEditString("", 0);
|
||||||
myCheatInput->setEditString("", 1);
|
myCheatInput->setEditString("", 1);
|
||||||
myCheatInput->setTitle("");
|
myCheatInput->setTitle("");
|
||||||
|
@ -155,13 +155,13 @@ void CheatCodeDialog::editCheat()
|
||||||
if(idx < 0)
|
if(idx < 0)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const CheatList& list = instance()->cheat().list();
|
const CheatList& list = instance().cheat().list();
|
||||||
const string& name = list[idx]->name();
|
const string& name = list[idx]->name();
|
||||||
const string& code = list[idx]->code();
|
const string& code = list[idx]->code();
|
||||||
|
|
||||||
// We have to add the dialog first, so it can be centered
|
// We have to add the dialog first, so it can be centered
|
||||||
// The methods after this depend on the dialog having the correct dimensions
|
// The methods after this depend on the dialog having the correct dimensions
|
||||||
parent()->addDialog(myCheatInput);
|
parent().addDialog(myCheatInput);
|
||||||
myCheatInput->setEditString(name, 0);
|
myCheatInput->setEditString(name, 0);
|
||||||
myCheatInput->setEditString(code, 1);
|
myCheatInput->setEditString(code, 1);
|
||||||
myCheatInput->setTitle("");
|
myCheatInput->setTitle("");
|
||||||
|
@ -172,7 +172,7 @@ void CheatCodeDialog::editCheat()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void CheatCodeDialog::removeCheat()
|
void CheatCodeDialog::removeCheat()
|
||||||
{
|
{
|
||||||
instance()->cheat().remove(myCheatList->getSelected());
|
instance().cheat().remove(myCheatList->getSelected());
|
||||||
loadConfig(); // reload the cheat list
|
loadConfig(); // reload the cheat list
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -181,7 +181,7 @@ void CheatCodeDialog::addOneShotCheat()
|
||||||
{
|
{
|
||||||
// We have to add the dialog first, so it can be centered
|
// We have to add the dialog first, so it can be centered
|
||||||
// The methods after this depend on the dialog having the correct dimensions
|
// The methods after this depend on the dialog having the correct dimensions
|
||||||
parent()->addDialog(myCheatInput);
|
parent().addDialog(myCheatInput);
|
||||||
myCheatInput->setEditString("One-shot cheat", 0);
|
myCheatInput->setEditString("One-shot cheat", 0);
|
||||||
myCheatInput->setEditString("", 1);
|
myCheatInput->setEditString("", 1);
|
||||||
myCheatInput->setTitle("");
|
myCheatInput->setTitle("");
|
||||||
|
@ -220,10 +220,10 @@ void CheatCodeDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
{
|
{
|
||||||
const string& name = myCheatInput->getResult(0);
|
const string& name = myCheatInput->getResult(0);
|
||||||
const string& code = myCheatInput->getResult(1);
|
const string& code = myCheatInput->getResult(1);
|
||||||
if(instance()->cheat().isValidCode(code))
|
if(instance().cheat().isValidCode(code))
|
||||||
{
|
{
|
||||||
instance()->cheat().add(name, code);
|
instance().cheat().add(name, code);
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
loadConfig(); // show changes onscreen
|
loadConfig(); // show changes onscreen
|
||||||
myCancelButton->setEnabled(false); // cannot cancel when a new cheat added
|
myCancelButton->setEnabled(false); // cannot cancel when a new cheat added
|
||||||
}
|
}
|
||||||
|
@ -238,10 +238,10 @@ void CheatCodeDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
const string& code = myCheatInput->getResult(1);
|
const string& code = myCheatInput->getResult(1);
|
||||||
bool enable = myCheatList->getSelectedState();
|
bool enable = myCheatList->getSelectedState();
|
||||||
int idx = myCheatList->getSelected();
|
int idx = myCheatList->getSelected();
|
||||||
if(instance()->cheat().isValidCode(code))
|
if(instance().cheat().isValidCode(code))
|
||||||
{
|
{
|
||||||
instance()->cheat().add(name, code, enable, idx);
|
instance().cheat().add(name, code, enable, idx);
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
loadConfig(); // show changes onscreen
|
loadConfig(); // show changes onscreen
|
||||||
myCancelButton->setEnabled(false); // cannot cancel when a new cheat added
|
myCancelButton->setEnabled(false); // cannot cancel when a new cheat added
|
||||||
}
|
}
|
||||||
|
@ -262,10 +262,10 @@ void CheatCodeDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
{
|
{
|
||||||
const string& name = myCheatInput->getResult(0);
|
const string& name = myCheatInput->getResult(0);
|
||||||
const string& code = myCheatInput->getResult(1);
|
const string& code = myCheatInput->getResult(1);
|
||||||
if(instance()->cheat().isValidCode(code))
|
if(instance().cheat().isValidCode(code))
|
||||||
{
|
{
|
||||||
instance()->cheat().addOneShot(name, code);
|
instance().cheat().addOneShot(name, code);
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
myCheatInput->setTitle("Invalid code");
|
myCheatInput->setTitle("Invalid code");
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferGL.cxx,v 1.102 2008-04-28 15:53:05 stephena Exp $
|
// $Id: FrameBufferGL.cxx,v 1.103 2008-06-13 13:14:50 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifdef DISPLAY_OPENGL
|
#ifdef DISPLAY_OPENGL
|
||||||
|
@ -423,11 +423,6 @@ void FrameBufferGL::drawMediaSource()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferGL::preFrameUpdate()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::postFrameUpdate()
|
void FrameBufferGL::postFrameUpdate()
|
||||||
{
|
{
|
||||||
|
@ -458,14 +453,12 @@ void FrameBufferGL::postFrameUpdate()
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::scanline(uInt32 row, uInt8* data) const
|
void FrameBufferGL::enablePhosphor(bool enable, int blend)
|
||||||
{
|
{
|
||||||
// Invert the row, since OpenGL rows start at the bottom
|
myUsePhosphor = enable;
|
||||||
// of the framebuffer
|
myPhosphorBlend = blend;
|
||||||
row = myImageDim.h + myImageDim.y - row - 1;
|
|
||||||
|
|
||||||
p_glPixelStorei(GL_PACK_ALIGNMENT, 1);
|
theRedrawTIAIndicator = true;
|
||||||
p_glReadPixels(myImageDim.x, row, myImageDim.w, 1, GL_RGB, GL_UNSIGNED_BYTE, data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -495,27 +488,83 @@ void FrameBufferGL::toggleFilter()
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::hLine(uInt32 x, uInt32 y, uInt32 x2, int color)
|
FBSurface* FrameBufferGL::createSurface(int w, int h, bool isBase) const
|
||||||
{
|
{
|
||||||
uInt16* buffer = (uInt16*) myTexture->pixels + y * myBuffer.pitch + x;
|
return 0;
|
||||||
while(x++ <= x2)
|
#if 0
|
||||||
*buffer++ = (uInt16) myDefPalette[color];
|
SDL_PixelFormat* fmt = myTexture->format;
|
||||||
|
SDL_Surface* data =
|
||||||
|
SDL_CreateRGBSurface(SDL_SWSURFACE, width, height, 16,
|
||||||
|
fmt->Rmask, fmt->Gmask, fmt->Bmask, fmt->Amask);
|
||||||
|
|
||||||
|
return data ? new GUI::Surface(width, height, data) : NULL;
|
||||||
|
|
||||||
|
/*
|
||||||
|
SDL_Surface* surface = isBase ? myScreen :
|
||||||
|
SDL_CreateRGBSurface(SDL_SWSURFACE, w, h, myFormat->BitsPerPixel,
|
||||||
|
myFormat->Rmask, myFormat->Gmask, myFormat->Bmask,
|
||||||
|
myFormat->Amask);
|
||||||
|
|
||||||
|
return new FBSurfaceSoft(*this, surface, w, h, isBase);
|
||||||
|
*/
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::vLine(uInt32 x, uInt32 y, uInt32 y2, int color)
|
void FrameBufferGL::scanline(uInt32 row, uInt8* data) const
|
||||||
{
|
{
|
||||||
|
// Invert the row, since OpenGL rows start at the bottom
|
||||||
|
// of the framebuffer
|
||||||
|
row = myImageDim.h + myImageDim.y - row - 1;
|
||||||
|
|
||||||
|
p_glPixelStorei(GL_PACK_ALIGNMENT, 1);
|
||||||
|
p_glReadPixels(myImageDim.x, row, myImageDim.w, 1, GL_RGB, GL_UNSIGNED_BYTE, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
// FBSurfaceGL implementation follows ...
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
FBSurfaceGL::FBSurfaceGL(const FrameBufferGL& buffer, SDL_Surface* surface,
|
||||||
|
uInt32 w, uInt32 h, bool isBase)
|
||||||
|
: myFB(buffer)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
FBSurfaceGL::~FBSurfaceGL()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceGL::hLine(uInt32 x, uInt32 y, uInt32 x2, int color)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
uInt16* buffer = (uInt16*) myTexture->pixels + y * myBuffer.pitch + x;
|
||||||
|
while(x++ <= x2)
|
||||||
|
*buffer++ = (uInt16) myDefPalette[color];
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceGL::vLine(uInt32 x, uInt32 y, uInt32 y2, int color)
|
||||||
|
{
|
||||||
|
/*
|
||||||
uInt16* buffer = (uInt16*) myTexture->pixels + y * myBuffer.pitch + x;
|
uInt16* buffer = (uInt16*) myTexture->pixels + y * myBuffer.pitch + x;
|
||||||
while(y++ <= y2)
|
while(y++ <= y2)
|
||||||
{
|
{
|
||||||
*buffer = (uInt16) myDefPalette[color];
|
*buffer = (uInt16) myDefPalette[color];
|
||||||
buffer += myBuffer.pitch;
|
buffer += myBuffer.pitch;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color)
|
void FBSurfaceGL::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color)
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
// Fill the rectangle
|
// Fill the rectangle
|
||||||
SDL_Rect tmp;
|
SDL_Rect tmp;
|
||||||
tmp.x = x;
|
tmp.x = x;
|
||||||
|
@ -523,12 +572,14 @@ void FrameBufferGL::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color)
|
||||||
tmp.w = w;
|
tmp.w = w;
|
||||||
tmp.h = h;
|
tmp.h = h;
|
||||||
SDL_FillRect(myTexture, &tmp, myDefPalette[color]);
|
SDL_FillRect(myTexture, &tmp, myDefPalette[color]);
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::drawChar(const GUI::Font* font, uInt8 chr,
|
void FBSurfaceGL::drawChar(const GUI::Font* font, uInt8 chr,
|
||||||
uInt32 tx, uInt32 ty, int color)
|
uInt32 tx, uInt32 ty, int color)
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
const FontDesc& desc = font->desc();
|
const FontDesc& desc = font->desc();
|
||||||
|
|
||||||
// If this character is not included in the font, use the default char.
|
// If this character is not included in the font, use the default char.
|
||||||
|
@ -556,12 +607,14 @@ void FrameBufferGL::drawChar(const GUI::Font* font, uInt8 chr,
|
||||||
}
|
}
|
||||||
buffer += myBuffer.pitch;
|
buffer += myBuffer.pitch;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::drawBitmap(uInt32* bitmap, Int32 tx, Int32 ty,
|
void FBSurfaceGL::drawBitmap(uInt32* bitmap, Int32 tx, Int32 ty,
|
||||||
int color, Int32 h)
|
int color, Int32 h)
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
uInt16* buffer = (uInt16*) myTexture->pixels + ty * myBuffer.pitch + tx;
|
uInt16* buffer = (uInt16*) myTexture->pixels + ty * myBuffer.pitch + tx;
|
||||||
|
|
||||||
for(int y = 0; y < h; ++y)
|
for(int y = 0; y < h; ++y)
|
||||||
|
@ -573,56 +626,88 @@ void FrameBufferGL::drawBitmap(uInt32* bitmap, Int32 tx, Int32 ty,
|
||||||
|
|
||||||
buffer += myBuffer.pitch;
|
buffer += myBuffer.pitch;
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::drawSurface(const GUI::Surface* surface, Int32 x, Int32 y)
|
void FBSurfaceGL::addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h)
|
||||||
{
|
{
|
||||||
SDL_Rect dstrect;
|
// myDirtyFlag = true;
|
||||||
dstrect.x = x;
|
|
||||||
dstrect.y = y;
|
|
||||||
SDL_Rect srcrect;
|
|
||||||
srcrect.x = 0;
|
|
||||||
srcrect.y = 0;
|
|
||||||
srcrect.w = surface->myClipWidth;
|
|
||||||
srcrect.h = surface->myClipHeight;
|
|
||||||
|
|
||||||
SDL_BlitSurface(surface->myData, &srcrect, myTexture, &dstrect);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::bytesToSurface(GUI::Surface* surface, int row,
|
void FBSurfaceGL::centerPos()
|
||||||
uInt8* data, int rowbytes) const
|
|
||||||
{
|
{
|
||||||
SDL_Surface* s = surface->myData;
|
#if 0
|
||||||
uInt16* pixels = (uInt16*) s->pixels;
|
// Make sure pitch is valid
|
||||||
pixels += (row * s->pitch/2);
|
recalc();
|
||||||
|
|
||||||
for(int c = 0; c < rowbytes; c += 3)
|
// X/Y Orig are the coordinates to use when blitting an entire (non-base)
|
||||||
*pixels++ = SDL_MapRGB(s->format, data[c], data[c+1], data[c+2]);
|
// surface to the screen. As such, they're concerned with the 'usable'
|
||||||
|
// area of a surface, not its entire size (ie, we use the originally
|
||||||
|
// requested width & height, which are not necessarily the same as
|
||||||
|
// the surface width & height).
|
||||||
|
// These coordinates are not used at all for drawing base surfaces
|
||||||
|
myXOrig = (myFB.myScreenDim.w - myWidth) >> 1;
|
||||||
|
myYOrig = (myFB.myScreenDim.h - myHeight) >> 1;
|
||||||
|
|
||||||
|
// X/Y/Base Offset determine 'how far' to go into a surface, since base
|
||||||
|
// surfaces are defined larger than necessary in some cases, and have a
|
||||||
|
// 'non-usable' area.
|
||||||
|
if(myIsBaseSurface)
|
||||||
|
{
|
||||||
|
myXOffset = myFB.myImageDim.x;
|
||||||
|
myYOffset = myFB.myImageDim.y;
|
||||||
|
myBaseOffset = myYOffset * myPitch + myXOffset;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
myXOffset = myYOffset = myBaseOffset = 0;
|
||||||
|
}
|
||||||
|
//cerr << "center: xorig = " << myXOrig << ", yorig = " << myYOrig << endl
|
||||||
|
// << " xoffset = " << myXOffset << ", yoffset = " << myYOffset << endl;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::translateCoords(Int32& x, Int32& y) const
|
void FBSurfaceGL::setPos(uInt32 x, uInt32 y)
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
|
// Only non-base surfaces can be arbitrarily 'moved'
|
||||||
|
if(!myIsBaseSurface)
|
||||||
|
{
|
||||||
|
// Make sure pitch is valid
|
||||||
|
recalc();
|
||||||
|
|
||||||
|
myXOrig = x;
|
||||||
|
myYOrig = y;
|
||||||
|
myXOffset = myYOffset = myBaseOffset = 0;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceGL::getPos(uInt32& x, uInt32& y) const
|
||||||
|
{
|
||||||
|
#if 0
|
||||||
|
x = myXOrig;
|
||||||
|
y = myYOrig;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceGL::translateCoords(Int32& x, Int32& y) const
|
||||||
|
{
|
||||||
|
/*
|
||||||
// Wow, what a mess :)
|
// Wow, what a mess :)
|
||||||
x = (Int32) ((x - myImageDim.x) / myWidthScaleFactor);
|
x = (Int32) ((x - myImageDim.x) / myWidthScaleFactor);
|
||||||
y = (Int32) ((y - myImageDim.y) / myHeightScaleFactor);
|
y = (Int32) ((y - myImageDim.y) / myHeightScaleFactor);
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h)
|
void FBSurfaceGL::update()
|
||||||
{
|
{
|
||||||
myDirtyFlag = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferGL::enablePhosphor(bool enable, int blend)
|
|
||||||
{
|
|
||||||
myUsePhosphor = enable;
|
|
||||||
myPhosphorBlend = blend;
|
|
||||||
|
|
||||||
theRedrawTIAIndicator = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -731,6 +816,7 @@ bool FrameBufferGL::createTextures()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if 0
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
GUI::Surface* FrameBufferGL::createSurface(int width, int height) const
|
GUI::Surface* FrameBufferGL::createSurface(int width, int height) const
|
||||||
{
|
{
|
||||||
|
@ -742,6 +828,35 @@ GUI::Surface* FrameBufferGL::createSurface(int width, int height) const
|
||||||
return data ? new GUI::Surface(width, height, data) : NULL;
|
return data ? new GUI::Surface(width, height, data) : NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FrameBufferGL::drawSurface(const GUI::Surface* surface, Int32 x, Int32 y)
|
||||||
|
{
|
||||||
|
SDL_Rect dstrect;
|
||||||
|
dstrect.x = x;
|
||||||
|
dstrect.y = y;
|
||||||
|
SDL_Rect srcrect;
|
||||||
|
srcrect.x = 0;
|
||||||
|
srcrect.y = 0;
|
||||||
|
srcrect.w = surface->myClipWidth;
|
||||||
|
srcrect.h = surface->myClipHeight;
|
||||||
|
|
||||||
|
SDL_BlitSurface(surface->myData, &srcrect, myTexture, &dstrect);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FrameBufferGL::bytesToSurface(GUI::Surface* surface, int row,
|
||||||
|
uInt8* data, int rowbytes) const
|
||||||
|
{
|
||||||
|
SDL_Surface* s = surface->myData;
|
||||||
|
uInt16* pixels = (uInt16*) s->pixels;
|
||||||
|
pixels += (row * s->pitch/2);
|
||||||
|
|
||||||
|
for(int c = 0; c < rowbytes; c += 3)
|
||||||
|
*pixels++ = SDL_MapRGB(s->format, data[c], data[c+1], data[c+2]);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
bool FrameBufferGL::myLibraryLoaded = false;
|
bool FrameBufferGL::myLibraryLoaded = false;
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferGL.hxx,v 1.52 2008-03-13 22:58:06 stephena Exp $
|
// $Id: FrameBufferGL.hxx,v 1.53 2008-06-13 13:14:50 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_GL_HXX
|
#ifndef FRAMEBUFFER_GL_HXX
|
||||||
|
@ -35,10 +35,12 @@ class GUI::Font;
|
||||||
This class implements an SDL OpenGL framebuffer.
|
This class implements an SDL OpenGL framebuffer.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBufferGL.hxx,v 1.52 2008-03-13 22:58:06 stephena Exp $
|
@version $Id: FrameBufferGL.hxx,v 1.53 2008-06-13 13:14:50 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBufferGL : public FrameBuffer
|
class FrameBufferGL : public FrameBuffer
|
||||||
{
|
{
|
||||||
|
friend class FBSurfaceGL;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
Creates a new OpenGL framebuffer
|
Creates a new OpenGL framebuffer
|
||||||
|
@ -60,13 +62,22 @@ class FrameBufferGL : public FrameBuffer
|
||||||
static bool loadLibrary(const string& library);
|
static bool loadLibrary(const string& library);
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// The following methods are derived from FrameBuffer.hxx
|
// The following are derived from public methods in FrameBuffer.hxx
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
/**
|
/**
|
||||||
This method is called to initialize OpenGL video mode.
|
Enable/disable phosphor effect.
|
||||||
Return false if any operation fails, otherwise return true.
|
|
||||||
*/
|
*/
|
||||||
bool initSubsystem(VideoMode mode);
|
void enablePhosphor(bool enable, int blend);
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method is called to map a given r,g,b triple to the screen palette.
|
||||||
|
|
||||||
|
@param r The red component of the color.
|
||||||
|
@param g The green component of the color.
|
||||||
|
@param b The blue component of the color.
|
||||||
|
*/
|
||||||
|
Uint32 mapRGB(Uint8 r, Uint8 g, Uint8 b) const
|
||||||
|
{ return SDL_MapRGB(myTexture->format, r, g, b); }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to query the type of the FrameBuffer.
|
This method is called to query the type of the FrameBuffer.
|
||||||
|
@ -74,9 +85,32 @@ class FrameBufferGL : public FrameBuffer
|
||||||
BufferType type() const { return kGLBuffer; }
|
BufferType type() const { return kGLBuffer; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to provide information about the FrameBuffer.
|
This method is called to create a surface compatible with the one
|
||||||
|
currently in use, but having the given dimensions.
|
||||||
|
|
||||||
|
@param w The requested width of the new surface.
|
||||||
|
@param h The requested height of the new surface.
|
||||||
|
@param useBase Use the base surface instead of creating a new one
|
||||||
*/
|
*/
|
||||||
string about() const;
|
FBSurface* createSurface(int w, int h, bool useBase = false) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method is called to get the specified scanline data.
|
||||||
|
|
||||||
|
@param row The row we are looking for
|
||||||
|
@param data The actual pixel data (in bytes)
|
||||||
|
*/
|
||||||
|
void scanline(uInt32 row, uInt8* data) const;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
// The following are derived from protected methods in FrameBuffer.hxx
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
/**
|
||||||
|
This method is called to initialize OpenGL video mode.
|
||||||
|
Return false if any operation fails, otherwise return true.
|
||||||
|
*/
|
||||||
|
bool initSubsystem(VideoMode mode);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to change to the given video mode.
|
This method is called to change to the given video mode.
|
||||||
|
@ -98,147 +132,21 @@ class FrameBufferGL : public FrameBuffer
|
||||||
void drawMediaSource();
|
void drawMediaSource();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called before any drawing is done (per-frame).
|
This method is called to provide information about the FrameBuffer.
|
||||||
*/
|
*/
|
||||||
void preFrameUpdate();
|
string about() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called after any drawing is done (per-frame).
|
This method is called after any drawing is done (per-frame).
|
||||||
*/
|
*/
|
||||||
void postFrameUpdate();
|
void postFrameUpdate();
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to get the specified scanline data.
|
|
||||||
|
|
||||||
@param row The row we are looking for
|
|
||||||
@param data The actual pixel data (in bytes)
|
|
||||||
*/
|
|
||||||
void scanline(uInt32 row, uInt8* data) const;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to map a given r,g,b triple to the screen palette.
|
|
||||||
|
|
||||||
@param r The red component of the color.
|
|
||||||
@param g The green component of the color.
|
|
||||||
@param b The blue component of the color.
|
|
||||||
*/
|
|
||||||
Uint32 mapRGB(Uint8 r, Uint8 g, Uint8 b) const
|
|
||||||
{ return SDL_MapRGB(myTexture->format, r, g, b); }
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to create a surface compatible with the one
|
|
||||||
currently in use, but having the given dimensions.
|
|
||||||
|
|
||||||
@param width The requested width of the new surface.
|
|
||||||
@param height The requested height of the new surface.
|
|
||||||
*/
|
|
||||||
GUI::Surface* createSurface(int width, int height) const;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to draw a horizontal line.
|
|
||||||
|
|
||||||
@param x The first x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param x2 The second x coordinate
|
|
||||||
@param color The color of the line
|
|
||||||
*/
|
|
||||||
void hLine(uInt32 x, uInt32 y, uInt32 x2, int color);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to draw a vertical line.
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The first y coordinate
|
|
||||||
@param y2 The second y coordinate
|
|
||||||
@param color The color of the line
|
|
||||||
*/
|
|
||||||
void vLine(uInt32 x, uInt32 y, uInt32 y2, int color);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to draw a filled rectangle.
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the area
|
|
||||||
@param h The height of the area
|
|
||||||
@param color The color of the area
|
|
||||||
*/
|
|
||||||
void fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to draw the specified character.
|
|
||||||
|
|
||||||
@param font The font to use to draw the character
|
|
||||||
@param c The character to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param color The color of the character
|
|
||||||
*/
|
|
||||||
void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y, int color);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to draw the bitmap image.
|
|
||||||
|
|
||||||
@param bitmap The data to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param color The color of the character
|
|
||||||
@param h The height of the data image
|
|
||||||
*/
|
|
||||||
void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, int color, Int32 h = 8);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw an SDL surface.
|
|
||||||
|
|
||||||
@param surface The data to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
*/
|
|
||||||
void drawSurface(const GUI::Surface* surface, Int32 x, Int32 y);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to convert and copy a given row of RGB
|
|
||||||
data into an SDL surface.
|
|
||||||
|
|
||||||
@param surface The data to draw
|
|
||||||
@param row The row of the surface the data should be placed in
|
|
||||||
@param data The data in uInt8 R/G/B format
|
|
||||||
@param rowbytes The number of bytes in row of 'data'
|
|
||||||
*/
|
|
||||||
void bytesToSurface(GUI::Surface* surface, int row,
|
|
||||||
uInt8* data, int rowbytes) const;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method translates the given coordinates to their
|
|
||||||
unzoomed/unscaled equivalents.
|
|
||||||
|
|
||||||
@param x X coordinate to translate
|
|
||||||
@param y Y coordinate to translate
|
|
||||||
*/
|
|
||||||
void translateCoords(Int32& x, Int32& y) const;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method adds a dirty rectangle
|
|
||||||
(ie, an area of the screen that has changed)
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the area
|
|
||||||
@param h The height of the area
|
|
||||||
*/
|
|
||||||
void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h);
|
|
||||||
|
|
||||||
/**
|
|
||||||
Enable/disable phosphor effect.
|
|
||||||
*/
|
|
||||||
void enablePhosphor(bool enable, int blend);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
bool loadFuncs();
|
bool loadFuncs();
|
||||||
|
|
||||||
bool createTextures();
|
bool createTextures();
|
||||||
|
|
||||||
inline uInt32 power_of_two(uInt32 input)
|
static uInt32 power_of_two(uInt32 input)
|
||||||
{
|
{
|
||||||
uInt32 value = 1;
|
uInt32 value = 1;
|
||||||
while( value < input )
|
while( value < input )
|
||||||
|
@ -291,6 +199,47 @@ class FrameBufferGL : public FrameBuffer
|
||||||
static bool myLibraryLoaded;
|
static bool myLibraryLoaded;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
A surface suitable for software rendering mode.
|
||||||
|
|
||||||
|
@author Stephen Anthony
|
||||||
|
@version $Id: FrameBufferGL.hxx,v 1.53 2008-06-13 13:14:50 stephena Exp $
|
||||||
|
*/
|
||||||
|
class FBSurfaceGL : public FBSurface
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
FBSurfaceGL(const FrameBufferGL& buffer, SDL_Surface* surface,
|
||||||
|
uInt32 w, uInt32 h, bool isBase);
|
||||||
|
virtual ~FBSurfaceGL();
|
||||||
|
|
||||||
|
void hLine(uInt32 x, uInt32 y, uInt32 x2, int color);
|
||||||
|
void vLine(uInt32 x, uInt32 y, uInt32 y2, int color);
|
||||||
|
void fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color);
|
||||||
|
void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y, int color);
|
||||||
|
void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, int color, Int32 h = 8);
|
||||||
|
void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h);
|
||||||
|
void centerPos();
|
||||||
|
void setPos(uInt32 x, uInt32 y);
|
||||||
|
void getPos(uInt32& x, uInt32& y) const;
|
||||||
|
void translateCoords(Int32& x, Int32& y) const;
|
||||||
|
void update();
|
||||||
|
|
||||||
|
private:
|
||||||
|
void recalc();
|
||||||
|
|
||||||
|
private:
|
||||||
|
const FrameBufferGL& myFB;
|
||||||
|
SDL_Surface* myTexture;
|
||||||
|
uInt32 myWidth, myHeight;
|
||||||
|
bool myIsBaseSurface;
|
||||||
|
bool mySurfaceIsDirty;
|
||||||
|
int myBaseOffset;
|
||||||
|
int myPitch;
|
||||||
|
|
||||||
|
uInt32 myXOrig, myYOrig;
|
||||||
|
uInt32 myXOffset, myYOffset;
|
||||||
|
};
|
||||||
|
|
||||||
#endif // DISPLAY_OPENGL
|
#endif // DISPLAY_OPENGL
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferSoft.cxx,v 1.78 2008-03-24 00:02:16 stephena Exp $
|
// $Id: FrameBufferSoft.cxx,v 1.79 2008-06-13 13:14:50 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
@ -34,10 +34,7 @@
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
FrameBufferSoft::FrameBufferSoft(OSystem* osystem)
|
FrameBufferSoft::FrameBufferSoft(OSystem* osystem)
|
||||||
: FrameBuffer(osystem),
|
: FrameBuffer(osystem),
|
||||||
myZoomLevel(1),
|
|
||||||
myRenderType(kSoftZoom_16),
|
myRenderType(kSoftZoom_16),
|
||||||
myDirtyFlag(false),
|
|
||||||
myInUIMode(false),
|
|
||||||
myRectList(NULL)
|
myRectList(NULL)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -136,6 +133,8 @@ void FrameBufferSoft::drawMediaSource()
|
||||||
uInt32 width = mediasrc.width();
|
uInt32 width = mediasrc.width();
|
||||||
uInt32 height = mediasrc.height();
|
uInt32 height = mediasrc.height();
|
||||||
|
|
||||||
|
bool tiaChanged = false;
|
||||||
|
|
||||||
switch(myRenderType)
|
switch(myRenderType)
|
||||||
{
|
{
|
||||||
case kSoftZoom_16:
|
case kSoftZoom_16:
|
||||||
|
@ -165,7 +164,7 @@ void FrameBufferSoft::drawMediaSource()
|
||||||
buffer[pos++] = (uInt16) myDefPalette[v];
|
buffer[pos++] = (uInt16) myDefPalette[v];
|
||||||
buffer[pos++] = (uInt16) myDefPalette[v];
|
buffer[pos++] = (uInt16) myDefPalette[v];
|
||||||
}
|
}
|
||||||
myDirtyFlag = true;
|
tiaChanged = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
pos += xstride + xstride;
|
pos += xstride + xstride;
|
||||||
|
@ -210,7 +209,7 @@ void FrameBufferSoft::drawMediaSource()
|
||||||
buffer[pos++] = r; buffer[pos++] = g; buffer[pos++] = b;
|
buffer[pos++] = r; buffer[pos++] = g; buffer[pos++] = b;
|
||||||
buffer[pos++] = r; buffer[pos++] = g; buffer[pos++] = b;
|
buffer[pos++] = r; buffer[pos++] = g; buffer[pos++] = b;
|
||||||
}
|
}
|
||||||
myDirtyFlag = true;
|
tiaChanged = true;
|
||||||
}
|
}
|
||||||
else // try to eliminate multply whereever possible
|
else // try to eliminate multply whereever possible
|
||||||
pos += xstride + xstride + xstride + xstride + xstride + xstride;
|
pos += xstride + xstride + xstride + xstride + xstride + xstride;
|
||||||
|
@ -250,7 +249,7 @@ void FrameBufferSoft::drawMediaSource()
|
||||||
buffer[pos++] = (uInt32) myDefPalette[v];
|
buffer[pos++] = (uInt32) myDefPalette[v];
|
||||||
buffer[pos++] = (uInt32) myDefPalette[v];
|
buffer[pos++] = (uInt32) myDefPalette[v];
|
||||||
}
|
}
|
||||||
myDirtyFlag = true;
|
tiaChanged = true;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
pos += xstride + xstride;
|
pos += xstride + xstride;
|
||||||
|
@ -294,7 +293,7 @@ void FrameBufferSoft::drawMediaSource()
|
||||||
bufofsY += width;
|
bufofsY += width;
|
||||||
}
|
}
|
||||||
SDL_UnlockSurface(myScreen);
|
SDL_UnlockSurface(myScreen);
|
||||||
myDirtyFlag = true;
|
tiaChanged = true;
|
||||||
break; // kPhosphor_16
|
break; // kPhosphor_16
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -333,7 +332,7 @@ void FrameBufferSoft::drawMediaSource()
|
||||||
bufofsY += width;
|
bufofsY += width;
|
||||||
}
|
}
|
||||||
SDL_UnlockSurface(myScreen);
|
SDL_UnlockSurface(myScreen);
|
||||||
myDirtyFlag = true;
|
tiaChanged = true;
|
||||||
break; // kPhosphor_24
|
break; // kPhosphor_24
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -368,37 +367,63 @@ void FrameBufferSoft::drawMediaSource()
|
||||||
bufofsY += width;
|
bufofsY += width;
|
||||||
}
|
}
|
||||||
SDL_UnlockSurface(myScreen);
|
SDL_UnlockSurface(myScreen);
|
||||||
myDirtyFlag = true;
|
tiaChanged = true;
|
||||||
break; // kPhosphor_32
|
break; // kPhosphor_32
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
if(tiaChanged)
|
||||||
void FrameBufferSoft::preFrameUpdate()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferSoft::postFrameUpdate()
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
cerr << "FrameBufferSoft::postFrameUpdate()" << endl
|
|
||||||
<< " myInUIMode: " << myInUIMode << endl
|
|
||||||
<< " myRectList->numRects(): " << myRectList->numRects() << endl
|
|
||||||
<< " myDirtyFlag: " << myDirtyFlag << endl
|
|
||||||
<< endl;
|
|
||||||
*/
|
|
||||||
if(myInUIMode && myRectList->numRects() > 0)
|
|
||||||
{
|
|
||||||
SDL_UpdateRects(myScreen, myRectList->numRects(), myRectList->rects());
|
|
||||||
}
|
|
||||||
else if(myDirtyFlag || myRectList->numRects() > 0)
|
|
||||||
{
|
{
|
||||||
SDL_Flip(myScreen);
|
SDL_Flip(myScreen);
|
||||||
myDirtyFlag = false;
|
tiaChanged = false;
|
||||||
}
|
}
|
||||||
myRectList->start();
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FrameBufferSoft::enablePhosphor(bool enable, int blend)
|
||||||
|
{
|
||||||
|
myUsePhosphor = enable;
|
||||||
|
myPhosphorBlend = blend;
|
||||||
|
|
||||||
|
stateChanged(myOSystem->eventHandler().state());
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FrameBufferSoft::stateChanged(EventHandler::State state)
|
||||||
|
{
|
||||||
|
if(!myScreen)
|
||||||
|
return;
|
||||||
|
|
||||||
|
// Make sure drawMediaSource() knows which renderer to use
|
||||||
|
switch(myBytesPerPixel)
|
||||||
|
{
|
||||||
|
case 2: // 16-bit
|
||||||
|
myPitch = myScreen->pitch >> 1;
|
||||||
|
myRenderType = myUsePhosphor ? kPhosphor_16 : kSoftZoom_16;
|
||||||
|
break;
|
||||||
|
case 3: // 24-bit
|
||||||
|
myPitch = myScreen->pitch;
|
||||||
|
myRenderType = myUsePhosphor ? kPhosphor_24 : kSoftZoom_24;
|
||||||
|
break;
|
||||||
|
case 4: // 32-bit
|
||||||
|
myPitch = myScreen->pitch >> 2;
|
||||||
|
myRenderType = myUsePhosphor ? kPhosphor_32 : kSoftZoom_32;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Have the changes take effect
|
||||||
|
myOSystem->eventHandler().refreshDisplay();
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
FBSurface* FrameBufferSoft::createSurface(int w, int h, bool isBase) const
|
||||||
|
{
|
||||||
|
SDL_Surface* surface = isBase ? myScreen :
|
||||||
|
SDL_CreateRGBSurface(SDL_SWSURFACE, w, h, myFormat->BitsPerPixel,
|
||||||
|
myFormat->Rmask, myFormat->Gmask, myFormat->Bmask,
|
||||||
|
myFormat->Amask);
|
||||||
|
|
||||||
|
return new FBSurfaceSoft(*this, surface, w, h, isBase);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -450,54 +475,76 @@ void FrameBufferSoft::scanline(uInt32 row, uInt8* data) const
|
||||||
SDL_UnlockSurface(myScreen);
|
SDL_UnlockSurface(myScreen);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSoft::toggleFilter()
|
// FBSurfaceSoft implementation follows ...
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
FBSurfaceSoft::FBSurfaceSoft(const FrameBufferSoft& buffer, SDL_Surface* surface,
|
||||||
|
uInt32 w, uInt32 h, bool isBase)
|
||||||
|
: myFB(buffer),
|
||||||
|
mySurface(surface),
|
||||||
|
myWidth(w),
|
||||||
|
myHeight(h),
|
||||||
|
myIsBaseSurface(isBase),
|
||||||
|
mySurfaceIsDirty(false),
|
||||||
|
myBaseOffset(0),
|
||||||
|
myPitch(0),
|
||||||
|
myXOrig(0),
|
||||||
|
myYOrig(0),
|
||||||
|
myXOffset(0),
|
||||||
|
myYOffset(0)
|
||||||
{
|
{
|
||||||
// No filter added yet ...
|
recalc();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSoft::hLine(uInt32 x, uInt32 y, uInt32 x2, int color)
|
FBSurfaceSoft::~FBSurfaceSoft()
|
||||||
{
|
{
|
||||||
SDL_Rect tmp;
|
if(!myIsBaseSurface)
|
||||||
|
SDL_FreeSurface(mySurface);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::hLine(uInt32 x, uInt32 y, uInt32 x2, int color)
|
||||||
|
{
|
||||||
// Horizontal line
|
// Horizontal line
|
||||||
tmp.x = myImageDim.x + x * myZoomLevel;
|
SDL_Rect tmp;
|
||||||
tmp.y = myImageDim.y + y * myZoomLevel;
|
tmp.x = x + myXOffset;
|
||||||
tmp.w = (x2 - x + 1) * myZoomLevel;
|
tmp.y = y + myYOffset;
|
||||||
tmp.h = myZoomLevel;
|
tmp.w = x2 - x + 1;
|
||||||
SDL_FillRect(myScreen, &tmp, myDefPalette[color]);
|
tmp.h = 1;
|
||||||
|
SDL_FillRect(mySurface, &tmp, myFB.myDefPalette[color]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSoft::vLine(uInt32 x, uInt32 y, uInt32 y2, int color)
|
void FBSurfaceSoft::vLine(uInt32 x, uInt32 y, uInt32 y2, int color)
|
||||||
{
|
{
|
||||||
SDL_Rect tmp;
|
|
||||||
|
|
||||||
// Vertical line
|
// Vertical line
|
||||||
tmp.x = myImageDim.x + x * myZoomLevel;
|
|
||||||
tmp.y = myImageDim.y + y * myZoomLevel;
|
|
||||||
tmp.w = myZoomLevel;
|
|
||||||
tmp.h = (y2 - y + 1) * myZoomLevel;
|
|
||||||
SDL_FillRect(myScreen, &tmp, myDefPalette[color]);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferSoft::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color)
|
|
||||||
{
|
|
||||||
SDL_Rect tmp;
|
SDL_Rect tmp;
|
||||||
|
tmp.x = x + myXOffset;
|
||||||
// Fill the rectangle
|
tmp.y = y + myYOffset;
|
||||||
tmp.x = myImageDim.x + x * myZoomLevel;
|
tmp.w = 1;
|
||||||
tmp.y = myImageDim.y + y * myZoomLevel;
|
tmp.h = y2 - y + 1;
|
||||||
tmp.w = w * myZoomLevel;
|
SDL_FillRect(mySurface, &tmp, myFB.myDefPalette[color]);
|
||||||
tmp.h = h * myZoomLevel;
|
|
||||||
SDL_FillRect(myScreen, &tmp, myDefPalette[color]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSoft::drawChar(const GUI::Font* font, uInt8 chr,
|
void FBSurfaceSoft::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color)
|
||||||
uInt32 xorig, uInt32 yorig, int color)
|
{
|
||||||
|
// Fill the rectangle
|
||||||
|
SDL_Rect tmp;
|
||||||
|
tmp.x = x + myXOffset;
|
||||||
|
tmp.y = y + myYOffset;
|
||||||
|
tmp.w = w;
|
||||||
|
tmp.h = h;
|
||||||
|
SDL_FillRect(mySurface, &tmp, myFB.myDefPalette[color]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::drawChar(const GUI::Font* font, uInt8 chr,
|
||||||
|
uInt32 tx, uInt32 ty, int color)
|
||||||
{
|
{
|
||||||
const FontDesc& desc = font->desc();
|
const FontDesc& desc = font->desc();
|
||||||
|
|
||||||
|
@ -513,48 +560,33 @@ void FrameBufferSoft::drawChar(const GUI::Font* font, uInt8 chr,
|
||||||
chr -= desc.firstchar;
|
chr -= desc.firstchar;
|
||||||
const uInt32* tmp = desc.bits + (desc.offset ? desc.offset[chr] : (chr * h));
|
const uInt32* tmp = desc.bits + (desc.offset ? desc.offset[chr] : (chr * h));
|
||||||
|
|
||||||
// Scale the origins to the current zoom
|
SDL_LockSurface(mySurface);
|
||||||
xorig *= myZoomLevel;
|
|
||||||
yorig *= myZoomLevel;
|
|
||||||
|
|
||||||
SDL_LockSurface(myScreen);
|
switch(myFB.myBytesPerPixel)
|
||||||
|
|
||||||
int screenofsY = 0;
|
|
||||||
switch(myBytesPerPixel)
|
|
||||||
{
|
{
|
||||||
case 2:
|
case 2:
|
||||||
{
|
{
|
||||||
// Get buffer position where upper-left pixel of the character will be drawn
|
// Get buffer position where upper-left pixel of the character will be drawn
|
||||||
uInt16* buffer = (uInt16*) myScreen->pixels + myBaseOffset + yorig * myPitch + xorig;
|
uInt16* buffer = (uInt16*) mySurface->pixels + myBaseOffset + ty * myPitch + tx;
|
||||||
for(int y = h; y; --y)
|
for(int y = 0; y < h; ++y)
|
||||||
{
|
{
|
||||||
const uInt32 fontbuf = *tmp++;
|
const uInt32 ptr = *tmp++;
|
||||||
int ystride = myZoomLevel;
|
if(ptr)
|
||||||
while(ystride--)
|
|
||||||
{
|
|
||||||
if(fontbuf)
|
|
||||||
{
|
{
|
||||||
uInt32 mask = 0x80000000;
|
uInt32 mask = 0x80000000;
|
||||||
int pos = screenofsY;
|
for(int x = 0; x < w; ++x, mask >>= 1)
|
||||||
for(int x = 0; x < w; x++, mask >>= 1)
|
if(ptr & mask)
|
||||||
{
|
buffer[x] = (uInt16) myFB.myDefPalette[color];
|
||||||
int xstride = myZoomLevel;
|
|
||||||
if((fontbuf & mask) != 0)
|
|
||||||
while(xstride--)
|
|
||||||
buffer[pos++] = myDefPalette[color];
|
|
||||||
else
|
|
||||||
pos += xstride;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
screenofsY += myPitch;
|
|
||||||
}
|
}
|
||||||
|
buffer += myFB.myPitch;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 3:
|
case 3:
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
// Get buffer position where upper-left pixel of the character will be drawn
|
// Get buffer position where upper-left pixel of the character will be drawn
|
||||||
uInt8* buffer = (uInt8*) myScreen->pixels + myBaseOffset + yorig * myPitch + xorig;
|
uInt8* buffer = (uInt8*) surface->pixels + myBaseOffset + yorig * myPitch + xorig;
|
||||||
uInt32 pixel = myDefPalette[color];
|
uInt32 pixel = myDefPalette[color];
|
||||||
uInt8 r = (pixel & myFormat->Rmask) >> myFormat->Rshift;
|
uInt8 r = (pixel & myFormat->Rmask) >> myFormat->Rshift;
|
||||||
uInt8 g = (pixel & myFormat->Gmask) >> myFormat->Gshift;
|
uInt8 g = (pixel & myFormat->Gmask) >> myFormat->Gshift;
|
||||||
|
@ -587,45 +619,35 @@ void FrameBufferSoft::drawChar(const GUI::Font* font, uInt8 chr,
|
||||||
screenofsY += myPitch;
|
screenofsY += myPitch;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 4:
|
case 4:
|
||||||
{
|
{
|
||||||
// Get buffer position where upper-left pixel of the character will be drawn
|
// Get buffer position where upper-left pixel of the character will be drawn
|
||||||
uInt32* buffer = (uInt32*) myScreen->pixels + myBaseOffset + yorig * myPitch + xorig;
|
uInt32* buffer = (uInt32*) mySurface->pixels + myBaseOffset + ty * myPitch + tx;
|
||||||
for(int y = h; y; --y)
|
for(int y = 0; y < h; ++y)
|
||||||
{
|
{
|
||||||
const uInt32 fontbuf = *tmp++;
|
const uInt32 ptr = *tmp++;
|
||||||
int ystride = myZoomLevel;
|
if(ptr)
|
||||||
while(ystride--)
|
|
||||||
{
|
|
||||||
if(fontbuf)
|
|
||||||
{
|
{
|
||||||
uInt32 mask = 0x80000000;
|
uInt32 mask = 0x80000000;
|
||||||
int pos = screenofsY;
|
for(int x = 0; x < w; ++x, mask >>= 1)
|
||||||
for(int x = 0; x < w; x++, mask >>= 1)
|
if(ptr & mask)
|
||||||
{
|
buffer[x] = (uInt32) myFB.myDefPalette[color];
|
||||||
int xstride = myZoomLevel;
|
|
||||||
if((fontbuf & mask) != 0)
|
|
||||||
while(xstride--)
|
|
||||||
buffer[pos++] = myDefPalette[color];
|
|
||||||
else
|
|
||||||
pos += xstride;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
screenofsY += myPitch;
|
|
||||||
}
|
}
|
||||||
|
buffer += myPitch;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
SDL_UnlockSurface(myScreen);
|
SDL_UnlockSurface(mySurface);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSoft::drawBitmap(uInt32* bitmap, Int32 xorig, Int32 yorig,
|
void FBSurfaceSoft::drawBitmap(uInt32* bitmap, Int32 tx, Int32 ty,
|
||||||
int color, Int32 h)
|
int color, Int32 h)
|
||||||
{
|
{
|
||||||
SDL_Rect rect;
|
SDL_Rect rect;
|
||||||
|
@ -637,15 +659,152 @@ void FrameBufferSoft::drawBitmap(uInt32* bitmap, Int32 xorig, Int32 yorig,
|
||||||
{
|
{
|
||||||
if(bitmap[y] & mask)
|
if(bitmap[y] & mask)
|
||||||
{
|
{
|
||||||
rect.x = myImageDim.x + (x + xorig) * myZoomLevel;
|
rect.x = x + tx + myXOffset;
|
||||||
rect.y = myImageDim.y + (y + yorig) * myZoomLevel;
|
rect.y = y + ty + myYOffset;
|
||||||
rect.w = rect.h = myZoomLevel;
|
rect.w = rect.h = 1;
|
||||||
SDL_FillRect(myScreen, &rect, myDefPalette[color]);
|
SDL_FillRect(mySurface, &rect, myFB.myDefPalette[color]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h)
|
||||||
|
{
|
||||||
|
// Base surfaces use dirty-rectangle updates, since they can be quite
|
||||||
|
// large, and updating the entire surface each frame would be too slow
|
||||||
|
// Non-base surfaces are usually smaller, and can be updated entirely
|
||||||
|
if(myIsBaseSurface)
|
||||||
|
{
|
||||||
|
// Add a dirty rect to the UI rectangle list
|
||||||
|
// TODO - intelligent merging of rectangles, to avoid overlap
|
||||||
|
SDL_Rect temp;
|
||||||
|
temp.x = x + myXOrig; temp.y = y + myYOrig; temp.w = w; temp.h = h;
|
||||||
|
myFB.myRectList->add(&temp);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Indicate that at least one dirty rect has been added
|
||||||
|
// This is an optimization for the update() method
|
||||||
|
mySurfaceIsDirty = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::centerPos()
|
||||||
|
{
|
||||||
|
// Make sure pitch is valid
|
||||||
|
recalc();
|
||||||
|
|
||||||
|
// X/Y Orig are the coordinates to use when blitting an entire (non-base)
|
||||||
|
// surface to the screen. As such, they're concerned with the 'usable'
|
||||||
|
// area of a surface, not its entire size (ie, we use the originally
|
||||||
|
// requested width & height, which are not necessarily the same as
|
||||||
|
// the surface width & height).
|
||||||
|
// These coordinates are not used at all for drawing base surfaces
|
||||||
|
myXOrig = (myFB.myScreenDim.w - myWidth) >> 1;
|
||||||
|
myYOrig = (myFB.myScreenDim.h - myHeight) >> 1;
|
||||||
|
|
||||||
|
// X/Y/Base Offset determine 'how far' to go into a surface, since base
|
||||||
|
// surfaces are defined larger than necessary in some cases, and have a
|
||||||
|
// 'non-usable' area.
|
||||||
|
if(myIsBaseSurface)
|
||||||
|
{
|
||||||
|
myXOffset = myFB.myImageDim.x;
|
||||||
|
myYOffset = myFB.myImageDim.y;
|
||||||
|
myBaseOffset = myYOffset * myPitch + myXOffset;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
myXOffset = myYOffset = myBaseOffset = 0;
|
||||||
|
}
|
||||||
|
//cerr << "center: xorig = " << myXOrig << ", yorig = " << myYOrig << endl
|
||||||
|
// << " xoffset = " << myXOffset << ", yoffset = " << myYOffset << endl;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::setPos(uInt32 x, uInt32 y)
|
||||||
|
{
|
||||||
|
// Only non-base surfaces can be arbitrarily 'moved'
|
||||||
|
if(!myIsBaseSurface)
|
||||||
|
{
|
||||||
|
// Make sure pitch is valid
|
||||||
|
recalc();
|
||||||
|
|
||||||
|
myXOrig = x;
|
||||||
|
myYOrig = y;
|
||||||
|
myXOffset = myYOffset = myBaseOffset = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::getPos(uInt32& x, uInt32& y) const
|
||||||
|
{
|
||||||
|
x = myXOrig;
|
||||||
|
y = myYOrig;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::translateCoords(Int32& x, Int32& y) const
|
||||||
|
{
|
||||||
|
x -= myXOrig;
|
||||||
|
y -= myYOrig;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::update()
|
||||||
|
{
|
||||||
|
// Since this method is called each frame, we only blit the surfaces when
|
||||||
|
// absolutely necessary
|
||||||
|
if(myIsBaseSurface)
|
||||||
|
{
|
||||||
|
if(myFB.myRectList->numRects() > 0)
|
||||||
|
{
|
||||||
|
SDL_UpdateRects(mySurface, myFB.myRectList->numRects(), myFB.myRectList->rects());
|
||||||
|
myFB.myRectList->start();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if(mySurfaceIsDirty /* && !myIsBaseSurface */)
|
||||||
|
{
|
||||||
|
SDL_Rect dstrect;
|
||||||
|
dstrect.x = myXOrig;
|
||||||
|
dstrect.y = myYOrig;
|
||||||
|
dstrect.w = myWidth;
|
||||||
|
dstrect.h = myHeight;
|
||||||
|
/*
|
||||||
|
cerr << "blit sub-surface:" << endl
|
||||||
|
<< " src x = " << dstrect.x << endl
|
||||||
|
<< " src y = " << dstrect.y << endl
|
||||||
|
<< " dst w = " << dstrect.w << endl
|
||||||
|
<< " dst h = " << dstrect.h << endl
|
||||||
|
<< endl;
|
||||||
|
*/
|
||||||
|
SDL_BlitSurface(mySurface, NULL, myFB.myScreen, &dstrect);
|
||||||
|
SDL_UpdateRect(myFB.myScreen, myXOrig, myYOrig, myWidth, myHeight);
|
||||||
|
|
||||||
|
mySurfaceIsDirty = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurfaceSoft::recalc()
|
||||||
|
{
|
||||||
|
switch(mySurface->format->BytesPerPixel)
|
||||||
|
{
|
||||||
|
case 2: // 16-bit
|
||||||
|
myPitch = mySurface->pitch/2;
|
||||||
|
break;
|
||||||
|
case 3: // 24-bit
|
||||||
|
myPitch = mySurface->pitch;
|
||||||
|
break;
|
||||||
|
case 4: // 32-bit
|
||||||
|
myPitch = mySurface->pitch/4;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSoft::drawSurface(const GUI::Surface* surface, Int32 x, Int32 y)
|
void FrameBufferSoft::drawSurface(const GUI::Surface* surface, Int32 x, Int32 y)
|
||||||
{
|
{
|
||||||
|
@ -678,95 +837,4 @@ void FrameBufferSoft::bytesToSurface(GUI::Surface* surface, int row,
|
||||||
SDL_FillRect(surface->myData, &rect, pixel);
|
SDL_FillRect(surface->myData, &rect, pixel);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferSoft::translateCoords(Int32& x, Int32& y) const
|
|
||||||
{
|
|
||||||
x = (x - myImageDim.x) / myZoomLevel;
|
|
||||||
y = (y - myImageDim.y) / myZoomLevel;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferSoft::addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h)
|
|
||||||
{
|
|
||||||
// Add a dirty rect to the UI rectangle list
|
|
||||||
// TODO - intelligent merging of rectangles, to avoid overlap
|
|
||||||
SDL_Rect temp;
|
|
||||||
#if 1
|
|
||||||
temp.x = myImageDim.x + x * myZoomLevel;
|
|
||||||
temp.y = myImageDim.y + y * myZoomLevel;
|
|
||||||
temp.w = w * myZoomLevel;
|
|
||||||
temp.h = h * myZoomLevel;
|
|
||||||
#else
|
|
||||||
temp.x = 0;
|
|
||||||
temp.y = 0;
|
|
||||||
temp.w = myScreenDim.w;
|
|
||||||
temp.h = myScreenDim.h;
|
|
||||||
#endif
|
#endif
|
||||||
myRectList->add(&temp);
|
|
||||||
|
|
||||||
// cerr << "addDirtyRect(): "
|
|
||||||
// << "x=" << temp.x << ", y=" << temp.y << ", w=" << temp.w << ", h=" << temp.h << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferSoft::enablePhosphor(bool enable, int blend)
|
|
||||||
{
|
|
||||||
myUsePhosphor = enable;
|
|
||||||
myPhosphorBlend = blend;
|
|
||||||
|
|
||||||
stateChanged(myOSystem->eventHandler().state());
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBufferSoft::stateChanged(EventHandler::State state)
|
|
||||||
{
|
|
||||||
if(!myScreen)
|
|
||||||
return;
|
|
||||||
|
|
||||||
myInUIMode = (state == EventHandler::S_LAUNCHER ||
|
|
||||||
state == EventHandler::S_DEBUGGER);
|
|
||||||
|
|
||||||
// Make sure drawMediaSource() knows which renderer to use
|
|
||||||
switch(myBytesPerPixel)
|
|
||||||
{
|
|
||||||
case 2: // 16-bit
|
|
||||||
myPitch = myScreen->pitch/2;
|
|
||||||
if(myUsePhosphor)
|
|
||||||
myRenderType = kPhosphor_16;
|
|
||||||
else
|
|
||||||
myRenderType = kSoftZoom_16;
|
|
||||||
break;
|
|
||||||
case 3: // 24-bit
|
|
||||||
myPitch = myScreen->pitch;
|
|
||||||
if(myUsePhosphor)
|
|
||||||
myRenderType = kPhosphor_24;
|
|
||||||
else
|
|
||||||
myRenderType = kSoftZoom_24;
|
|
||||||
break;
|
|
||||||
case 4: // 32-bit
|
|
||||||
myPitch = myScreen->pitch/4;
|
|
||||||
if(myUsePhosphor)
|
|
||||||
myRenderType = kPhosphor_32;
|
|
||||||
else
|
|
||||||
myRenderType = kSoftZoom_32;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
myRenderType = kSoftZoom_16; // What else should we do here?
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Have the changes take effect
|
|
||||||
myOSystem->eventHandler().refreshDisplay();
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
GUI::Surface* FrameBufferSoft::createSurface(int width, int height) const
|
|
||||||
{
|
|
||||||
SDL_Surface* data =
|
|
||||||
SDL_CreateRGBSurface(SDL_SWSURFACE, width*myZoomLevel, height*myZoomLevel,
|
|
||||||
myBytesPerPixel << 3, myFormat->Rmask, myFormat->Gmask,
|
|
||||||
myFormat->Bmask, myFormat->Amask);
|
|
||||||
|
|
||||||
return data ? new GUI::Surface(width, height, data) : NULL;
|
|
||||||
}
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferSoft.hxx,v 1.50 2008-03-13 22:58:06 stephena Exp $
|
// $Id: FrameBufferSoft.hxx,v 1.51 2008-06-13 13:14:50 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_SOFT_HXX
|
#ifndef FRAMEBUFFER_SOFT_HXX
|
||||||
|
@ -33,10 +33,12 @@ class RectList;
|
||||||
This class implements an SDL software framebuffer.
|
This class implements an SDL software framebuffer.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBufferSoft.hxx,v 1.50 2008-03-13 22:58:06 stephena Exp $
|
@version $Id: FrameBufferSoft.hxx,v 1.51 2008-06-13 13:14:50 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBufferSoft : public FrameBuffer
|
class FrameBufferSoft : public FrameBuffer
|
||||||
{
|
{
|
||||||
|
friend class FBSurfaceSoft;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
Creates a new software framebuffer
|
Creates a new software framebuffer
|
||||||
|
@ -49,60 +51,12 @@ class FrameBufferSoft : public FrameBuffer
|
||||||
virtual ~FrameBufferSoft();
|
virtual ~FrameBufferSoft();
|
||||||
|
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
// The following methods are derived from FrameBuffer.hxx
|
// The following are derived from public methods in FrameBuffer.hxx
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
/**
|
/**
|
||||||
This method is called to initialize software video mode.
|
Enable/disable phosphor effect.
|
||||||
Return false if any operation fails, otherwise return true.
|
|
||||||
*/
|
*/
|
||||||
bool initSubsystem(VideoMode mode);
|
void enablePhosphor(bool enable, int blend);
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to query the type of the FrameBuffer.
|
|
||||||
*/
|
|
||||||
BufferType type() const { return kSoftBuffer; }
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to provide information about the FrameBuffer.
|
|
||||||
*/
|
|
||||||
string about() const;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to change to the given videomode type.
|
|
||||||
|
|
||||||
@param mode The video mode to use for rendering the mediasource
|
|
||||||
*/
|
|
||||||
bool setVidMode(VideoMode mode);
|
|
||||||
|
|
||||||
/**
|
|
||||||
Switches between the filtering options in software mode.
|
|
||||||
Currently, none exist.
|
|
||||||
*/
|
|
||||||
void toggleFilter();
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called anytime the MediaSource needs to be redrawn
|
|
||||||
to the screen.
|
|
||||||
*/
|
|
||||||
void drawMediaSource();
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called before any drawing is done (per-frame).
|
|
||||||
*/
|
|
||||||
void preFrameUpdate();
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called after any drawing is done (per-frame).
|
|
||||||
*/
|
|
||||||
void postFrameUpdate();
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to get the specified scanline data.
|
|
||||||
|
|
||||||
@param row The row we are looking for
|
|
||||||
@param data The actual pixel data (in bytes)
|
|
||||||
*/
|
|
||||||
void scanline(uInt32 row, uInt8* data) const;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to map a given r,g,b triple to the screen palette.
|
This method is called to map a given r,g,b triple to the screen palette.
|
||||||
|
@ -114,113 +68,62 @@ class FrameBufferSoft : public FrameBuffer
|
||||||
Uint32 mapRGB(Uint8 r, Uint8 g, Uint8 b) const
|
Uint32 mapRGB(Uint8 r, Uint8 g, Uint8 b) const
|
||||||
{ return SDL_MapRGB(myScreen->format, r, g, b); }
|
{ return SDL_MapRGB(myScreen->format, r, g, b); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method is called to query the type of the FrameBuffer.
|
||||||
|
*/
|
||||||
|
BufferType type() const { return kSoftBuffer; }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to create a surface compatible with the one
|
This method is called to create a surface compatible with the one
|
||||||
currently in use, but having the given dimensions.
|
currently in use, but having the given dimensions.
|
||||||
|
|
||||||
@param width The requested width of the new surface.
|
@param w The requested width of the new surface.
|
||||||
@param height The requested height of the new surface.
|
@param h The requested height of the new surface.
|
||||||
|
@param useBase Use the base surface instead of creating a new one
|
||||||
*/
|
*/
|
||||||
GUI::Surface* createSurface(int width, int height) const;
|
FBSurface* createSurface(int w, int h, bool useBase = false) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to draw a horizontal line.
|
This method is called to get the specified scanline data.
|
||||||
|
|
||||||
@param x The first x coordinate
|
@param row The row we are looking for
|
||||||
@param y The y coordinate
|
@param data The actual pixel data (in bytes)
|
||||||
@param x2 The second x coordinate
|
|
||||||
@param color The color of the line
|
|
||||||
*/
|
*/
|
||||||
void hLine(uInt32 x, uInt32 y, uInt32 x2, int color);
|
void scanline(uInt32 row, uInt8* data) const;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
// The following are derived from protected methods in FrameBuffer.hxx
|
||||||
|
//////////////////////////////////////////////////////////////////////
|
||||||
|
/**
|
||||||
|
This method is called to initialize software video mode.
|
||||||
|
Return false if any operation fails, otherwise return true.
|
||||||
|
*/
|
||||||
|
bool initSubsystem(VideoMode mode);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to draw a vertical line.
|
This method is called to change to the given videomode type.
|
||||||
|
|
||||||
@param x The x coordinate
|
@param mode The video mode to use for rendering the mediasource
|
||||||
@param y The first y coordinate
|
|
||||||
@param y2 The second y coordinate
|
|
||||||
@param color The color of the line
|
|
||||||
*/
|
*/
|
||||||
void vLine(uInt32 x, uInt32 y, uInt32 y2, int color);
|
bool setVidMode(VideoMode mode);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to draw a filled rectangle.
|
Switches between the filtering options in software mode.
|
||||||
|
Currently, none exist.
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the area
|
|
||||||
@param h The height of the area
|
|
||||||
@param color The color of the area
|
|
||||||
*/
|
*/
|
||||||
void fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color);
|
void toggleFilter() { /* No filter added yet */ }
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to draw the specified character.
|
This method should be called anytime the MediaSource needs to be redrawn
|
||||||
|
to the screen.
|
||||||
@param font The font to use to draw the character
|
|
||||||
@param c The character to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param color The color of the character
|
|
||||||
*/
|
*/
|
||||||
void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y, int color);
|
void drawMediaSource();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to draw the bitmap image.
|
This method is called to provide information about the FrameBuffer.
|
||||||
|
|
||||||
@param bitmap The data to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param color The color of the character
|
|
||||||
@param h The height of the data image
|
|
||||||
*/
|
*/
|
||||||
void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, int color, Int32 h = 8);
|
string about() const;
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw an SDL surface.
|
|
||||||
|
|
||||||
@param surface The data to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
*/
|
|
||||||
void drawSurface(const GUI::Surface* surface, Int32 x, Int32 y);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to convert and copy a given row of RGB
|
|
||||||
data into an SDL surface.
|
|
||||||
|
|
||||||
@param surface The data to draw
|
|
||||||
@param row The row of the surface the data should be placed in
|
|
||||||
@param data The data in uInt8 R/G/B format
|
|
||||||
@param rowbytes The number of bytes in row of 'data'
|
|
||||||
*/
|
|
||||||
void bytesToSurface(GUI::Surface* surface, int row,
|
|
||||||
uInt8* data, int rowbytes) const;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method translates the given coordinates to their
|
|
||||||
unzoomed/unscaled equivalents.
|
|
||||||
|
|
||||||
@param x X coordinate to translate
|
|
||||||
@param y Y coordinate to translate
|
|
||||||
*/
|
|
||||||
void translateCoords(Int32& x, Int32& y) const;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method adds a dirty rectangle
|
|
||||||
(ie, an area of the screen that has changed)
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the area
|
|
||||||
@param h The height of the area
|
|
||||||
*/
|
|
||||||
void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h);
|
|
||||||
|
|
||||||
/**
|
|
||||||
Enable/disable phosphor effect.
|
|
||||||
*/
|
|
||||||
void enablePhosphor(bool enable, int blend);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Informs the Framebuffer of a change in EventHandler state.
|
Informs the Framebuffer of a change in EventHandler state.
|
||||||
|
@ -230,8 +133,8 @@ class FrameBufferSoft : public FrameBuffer
|
||||||
private:
|
private:
|
||||||
int myZoomLevel;
|
int myZoomLevel;
|
||||||
int myBytesPerPixel;
|
int myBytesPerPixel;
|
||||||
int myPitch;
|
|
||||||
int myBaseOffset;
|
int myBaseOffset;
|
||||||
|
int myPitch;
|
||||||
SDL_PixelFormat* myFormat;
|
SDL_PixelFormat* myFormat;
|
||||||
|
|
||||||
enum RenderType {
|
enum RenderType {
|
||||||
|
@ -244,14 +147,49 @@ class FrameBufferSoft : public FrameBuffer
|
||||||
};
|
};
|
||||||
RenderType myRenderType;
|
RenderType myRenderType;
|
||||||
|
|
||||||
// Indicates if the TIA image has been modified
|
|
||||||
bool myDirtyFlag;
|
|
||||||
|
|
||||||
// Indicates if we're in a purely UI mode
|
|
||||||
bool myInUIMode;
|
|
||||||
|
|
||||||
// Used in the dirty update of rectangles in non-TIA modes
|
// Used in the dirty update of rectangles in non-TIA modes
|
||||||
RectList* myRectList;
|
RectList* myRectList;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
A surface suitable for software rendering mode.
|
||||||
|
|
||||||
|
@author Stephen Anthony
|
||||||
|
@version $Id: FrameBufferSoft.hxx,v 1.51 2008-06-13 13:14:50 stephena Exp $
|
||||||
|
*/
|
||||||
|
class FBSurfaceSoft : public FBSurface
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
FBSurfaceSoft(const FrameBufferSoft& buffer, SDL_Surface* surface,
|
||||||
|
uInt32 w, uInt32 h, bool isBase);
|
||||||
|
virtual ~FBSurfaceSoft();
|
||||||
|
|
||||||
|
void hLine(uInt32 x, uInt32 y, uInt32 x2, int color);
|
||||||
|
void vLine(uInt32 x, uInt32 y, uInt32 y2, int color);
|
||||||
|
void fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h, int color);
|
||||||
|
void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y, int color);
|
||||||
|
void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, int color, Int32 h = 8);
|
||||||
|
void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h);
|
||||||
|
void centerPos();
|
||||||
|
void setPos(uInt32 x, uInt32 y);
|
||||||
|
void getPos(uInt32& x, uInt32& y) const;
|
||||||
|
void translateCoords(Int32& x, Int32& y) const;
|
||||||
|
void update();
|
||||||
|
|
||||||
|
private:
|
||||||
|
void recalc();
|
||||||
|
|
||||||
|
private:
|
||||||
|
const FrameBufferSoft& myFB;
|
||||||
|
SDL_Surface* mySurface;
|
||||||
|
uInt32 myWidth, myHeight;
|
||||||
|
bool myIsBaseSurface;
|
||||||
|
bool mySurfaceIsDirty;
|
||||||
|
int myBaseOffset;
|
||||||
|
int myPitch;
|
||||||
|
|
||||||
|
uInt32 myXOrig, myYOrig;
|
||||||
|
uInt32 myXOffset, myYOffset;
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: AudioWidget.cxx,v 1.7 2008-02-06 13:45:20 stephena Exp $
|
// $Id: AudioWidget.cxx,v 1.8 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -108,7 +108,7 @@ void AudioWidget::handleCommand(CommandSender* sender, int cmd, int data, int id
|
||||||
int addr, value;
|
int addr, value;
|
||||||
string buf;
|
string buf;
|
||||||
|
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
TIADebug& tia = dbg.tiaDebug();
|
TIADebug& tia = dbg.tiaDebug();
|
||||||
|
|
||||||
switch(cmd)
|
switch(cmd)
|
||||||
|
@ -140,7 +140,7 @@ void AudioWidget::fillGrid()
|
||||||
IntArray vlist;
|
IntArray vlist;
|
||||||
BoolArray blist, changed, grNew, grOld;
|
BoolArray blist, changed, grNew, grOld;
|
||||||
|
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
TIADebug& tia = dbg.tiaDebug();
|
TIADebug& tia = dbg.tiaDebug();
|
||||||
TiaState state = (TiaState&) tia.getState();
|
TiaState state = (TiaState&) tia.getState();
|
||||||
TiaState oldstate = (TiaState&) tia.getOldState();
|
TiaState oldstate = (TiaState&) tia.getOldState();
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ColorWidget.cxx,v 1.8 2008-02-06 13:45:20 stephena Exp $
|
// $Id: ColorWidget.cxx,v 1.9 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -64,14 +64,14 @@ void ColorWidget::handleMouseDown(int x, int y, int button, int clickCount)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ColorWidget::drawWidget(bool hilite)
|
void ColorWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
FBSurface& s = dialog().surface();
|
||||||
|
|
||||||
// Draw a thin frame around us.
|
// Draw a thin frame around us.
|
||||||
fb.hLine(_x, _y, _x + _w - 1, kColor);
|
s.hLine(_x, _y, _x + _w - 1, kColor);
|
||||||
fb.hLine(_x, _y +_h, _x + _w - 1, kShadowColor);
|
s.hLine(_x, _y +_h, _x + _w - 1, kShadowColor);
|
||||||
fb.vLine(_x, _y, _y+_h, kColor);
|
s.vLine(_x, _y, _y+_h, kColor);
|
||||||
fb.vLine(_x + _w - 1, _y, _y +_h - 1, kShadowColor);
|
s.vLine(_x + _w - 1, _y, _y +_h - 1, kShadowColor);
|
||||||
|
|
||||||
// Show the currently selected color
|
// Show the currently selected color
|
||||||
fb.fillRect(_x+1, _y+1, _w-2, _h-1, _color);
|
s.fillRect(_x+1, _y+1, _w-2, _h-1, _color);
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CpuWidget.cxx,v 1.13 2008-05-15 18:59:56 stephena Exp $
|
// $Id: CpuWidget.cxx,v 1.14 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -133,7 +133,7 @@ CpuWidget::~CpuWidget()
|
||||||
void CpuWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
void CpuWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
{
|
{
|
||||||
int addr = -1, value = -1;
|
int addr = -1, value = -1;
|
||||||
CpuDebug& dbg = instance()->debugger().cpuDebug();
|
CpuDebug& dbg = instance().debugger().cpuDebug();
|
||||||
|
|
||||||
switch(cmd)
|
switch(cmd)
|
||||||
{
|
{
|
||||||
|
@ -159,7 +159,7 @@ void CpuWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
// event the rest of the debugger widgets
|
// event the rest of the debugger widgets
|
||||||
ostringstream command;
|
ostringstream command;
|
||||||
command << "pc #" << value;
|
command << "pc #" << value;
|
||||||
instance()->debugger().run(command.str());
|
instance().debugger().run(command.str());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -241,7 +241,7 @@ void CpuWidget::fillGrid()
|
||||||
|
|
||||||
// We push the enumerated items as addresses, and deal with the real
|
// We push the enumerated items as addresses, and deal with the real
|
||||||
// address in the callback (handleCommand)
|
// address in the callback (handleCommand)
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
CpuDebug& cpu = dbg.cpuDebug();
|
CpuDebug& cpu = dbg.cpuDebug();
|
||||||
const CpuState& state = (CpuState&) cpu.getState();
|
const CpuState& state = (CpuState&) cpu.getState();
|
||||||
const CpuState& oldstate = (CpuState&) cpu.getOldState();
|
const CpuState& oldstate = (CpuState&) cpu.getOldState();
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: DataGridWidget.cxx,v 1.13 2008-02-06 13:45:20 stephena Exp $
|
// $Id: DataGridWidget.cxx,v 1.14 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -98,7 +98,7 @@ cerr << "alist.size() = " << alist.size()
|
||||||
string temp;
|
string temp;
|
||||||
for(int i = 0; i < size; ++i)
|
for(int i = 0; i < size; ++i)
|
||||||
{
|
{
|
||||||
temp = instance()->debugger().valueToString(_valueList[i], _base);
|
temp = instance().debugger().valueToString(_valueList[i], _base);
|
||||||
_valueStringList.push_back(temp);
|
_valueStringList.push_back(temp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -156,7 +156,7 @@ void DataGridWidget::setHiliteList(const IntArray& hilitelist)
|
||||||
void DataGridWidget::setSelectedValue(int value)
|
void DataGridWidget::setSelectedValue(int value)
|
||||||
{
|
{
|
||||||
// Correctly format the data for viewing
|
// Correctly format the data for viewing
|
||||||
_editString = instance()->debugger().valueToString(value, _base);
|
_editString = instance().debugger().valueToString(value, _base);
|
||||||
|
|
||||||
_valueStringList[_selectedItem] = _editString;
|
_valueStringList[_selectedItem] = _editString;
|
||||||
_changedList[_selectedItem] = (_valueList[_selectedItem] != value);
|
_changedList[_selectedItem] = (_valueList[_selectedItem] != value);
|
||||||
|
@ -231,8 +231,8 @@ int DataGridWidget::findItem(int x, int y)
|
||||||
bool DataGridWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
bool DataGridWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
{
|
{
|
||||||
// Ignore all mod keys
|
// Ignore all mod keys
|
||||||
if(instance()->eventHandler().kbdControl(modifiers) ||
|
if(instance().eventHandler().kbdControl(modifiers) ||
|
||||||
instance()->eventHandler().kbdAlt(modifiers))
|
instance().eventHandler().kbdAlt(modifiers))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
bool handled = true;
|
bool handled = true;
|
||||||
|
@ -481,17 +481,17 @@ void DataGridWidget::handleCommand(CommandSender* sender, int cmd,
|
||||||
void DataGridWidget::drawWidget(bool hilite)
|
void DataGridWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "DataGridWidget::drawWidget\n";
|
//cerr << "DataGridWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
int row, col, deltax;
|
int row, col, deltax;
|
||||||
string buffer;
|
string buffer;
|
||||||
|
|
||||||
// Draw the internal grid and labels
|
// Draw the internal grid and labels
|
||||||
int linewidth = _cols * _colWidth;
|
int linewidth = _cols * _colWidth;
|
||||||
for (row = 0; row <= _rows; row++)
|
for (row = 0; row <= _rows; row++)
|
||||||
fb.hLine(_x, _y + (row * _rowHeight), _x + linewidth, kColor);
|
s.hLine(_x, _y + (row * _rowHeight), _x + linewidth, kColor);
|
||||||
int lineheight = _rows * _rowHeight;
|
int lineheight = _rows * _rowHeight;
|
||||||
for (col = 0; col <= _cols; col++)
|
for (col = 0; col <= _cols; col++)
|
||||||
fb.vLine(_x + (col * _colWidth), _y, _y + lineheight, kColor);
|
s.vLine(_x + (col * _colWidth), _y, _y + lineheight, kColor);
|
||||||
|
|
||||||
// Draw the list items
|
// Draw the list items
|
||||||
for (row = 0; row < _rows; row++)
|
for (row = 0; row < _rows; row++)
|
||||||
|
@ -505,7 +505,7 @@ void DataGridWidget::drawWidget(bool hilite)
|
||||||
// Draw the selected item inverted, on a highlighted background.
|
// Draw the selected item inverted, on a highlighted background.
|
||||||
if (_currentRow == row && _currentCol == col &&
|
if (_currentRow == row && _currentCol == col &&
|
||||||
_hasFocus && !_editMode)
|
_hasFocus && !_editMode)
|
||||||
fb.fillRect(x - 4, y - 2, _colWidth+1, _rowHeight+1, kTextColorHi);
|
s.fillRect(x - 4, y - 2, _colWidth+1, _rowHeight+1, kTextColorHi);
|
||||||
|
|
||||||
if (_selectedItem == pos && _editMode)
|
if (_selectedItem == pos && _editMode)
|
||||||
{
|
{
|
||||||
|
@ -513,7 +513,7 @@ void DataGridWidget::drawWidget(bool hilite)
|
||||||
adjustOffset();
|
adjustOffset();
|
||||||
deltax = -_editScrollOffset;
|
deltax = -_editScrollOffset;
|
||||||
|
|
||||||
fb.drawString(_font, buffer, x, y, _colWidth, kTextColor,
|
s.drawString(_font, buffer, x, y, _colWidth, kTextColor,
|
||||||
kTextAlignLeft, deltax, false);
|
kTextAlignLeft, deltax, false);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -524,7 +524,7 @@ void DataGridWidget::drawWidget(bool hilite)
|
||||||
int color = kTextColor;
|
int color = kTextColor;
|
||||||
if(_changedList[pos])
|
if(_changedList[pos])
|
||||||
{
|
{
|
||||||
fb.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kDbgChangedColor);
|
s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kDbgChangedColor);
|
||||||
|
|
||||||
if(_hiliteList[pos])
|
if(_hiliteList[pos])
|
||||||
color = kDbgColorHi;
|
color = kDbgColorHi;
|
||||||
|
@ -534,7 +534,7 @@ void DataGridWidget::drawWidget(bool hilite)
|
||||||
else if(_hiliteList[pos])
|
else if(_hiliteList[pos])
|
||||||
color = kDbgColorHi;
|
color = kDbgColorHi;
|
||||||
|
|
||||||
fb.drawString(_font, buffer, x, y, _colWidth, color);
|
s.drawString(_font, buffer, x, y, _colWidth, color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -578,7 +578,7 @@ void DataGridWidget::endEditMode()
|
||||||
_editMode = false;
|
_editMode = false;
|
||||||
|
|
||||||
// Update the both the string representation and the real data
|
// Update the both the string representation and the real data
|
||||||
int value = instance()->debugger().stringToValue(_editString);
|
int value = instance().debugger().stringToValue(_editString);
|
||||||
if(value < _lowerBound || value >= _upperBound)
|
if(value < _lowerBound || value >= _upperBound)
|
||||||
{
|
{
|
||||||
abortEditMode();
|
abortEditMode();
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: DebuggerDialog.cxx,v 1.24 2008-04-29 15:13:15 stephena Exp $
|
// $Id: DebuggerDialog.cxx,v 1.25 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -51,7 +51,7 @@ enum {
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
DebuggerDialog::DebuggerDialog(OSystem* osystem, DialogContainer* parent,
|
DebuggerDialog::DebuggerDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
int x, int y, int w, int h)
|
int x, int y, int w, int h)
|
||||||
: Dialog(osystem, parent, x, y, w, h),
|
: Dialog(osystem, parent, x, y, w, h, true), // use base surface
|
||||||
myTab(NULL)
|
myTab(NULL)
|
||||||
{
|
{
|
||||||
addTiaArea();
|
addTiaArea();
|
||||||
|
@ -85,7 +85,7 @@ void DebuggerDialog::loadConfig()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::handleKeyDown(int ascii, int keycode, int modifiers)
|
void DebuggerDialog::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
{
|
{
|
||||||
bool handled = instance()->eventHandler().kbdAlt(modifiers);
|
bool handled = instance().eventHandler().kbdAlt(modifiers);
|
||||||
if(handled)
|
if(handled)
|
||||||
{
|
{
|
||||||
switch(ascii)
|
switch(ascii)
|
||||||
|
@ -147,21 +147,21 @@ void DebuggerDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::addTiaArea()
|
void DebuggerDialog::addTiaArea()
|
||||||
{
|
{
|
||||||
GUI::Rect r = instance()->debugger().getTiaBounds();
|
GUI::Rect r = instance().debugger().getTiaBounds();
|
||||||
|
|
||||||
myTiaOutput = new TiaOutputWidget(this, instance()->consoleFont(),
|
myTiaOutput = new TiaOutputWidget(this, instance().consoleFont(),
|
||||||
r.left, r.top, r.width(), r.height());
|
r.left, r.top, r.width(), r.height());
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::addTabArea()
|
void DebuggerDialog::addTabArea()
|
||||||
{
|
{
|
||||||
GUI::Rect r = instance()->debugger().getTabBounds();
|
GUI::Rect r = instance().debugger().getTabBounds();
|
||||||
|
|
||||||
const int vBorder = 4;
|
const int vBorder = 4;
|
||||||
|
|
||||||
// The tab widget
|
// The tab widget
|
||||||
myTab = new TabWidget(this, instance()->consoleFont(), r.left, r.top + vBorder,
|
myTab = new TabWidget(this, instance().consoleFont(), r.left, r.top + vBorder,
|
||||||
r.width(), r.height() - vBorder);
|
r.width(), r.height() - vBorder);
|
||||||
addTabWidget(myTab);
|
addTabWidget(myTab);
|
||||||
|
|
||||||
|
@ -171,28 +171,28 @@ void DebuggerDialog::addTabArea()
|
||||||
|
|
||||||
// The Prompt/console tab
|
// The Prompt/console tab
|
||||||
tabID = myTab->addTab("Prompt");
|
tabID = myTab->addTab("Prompt");
|
||||||
myPrompt = new PromptWidget(myTab, instance()->consoleFont(),
|
myPrompt = new PromptWidget(myTab, instance().consoleFont(),
|
||||||
2, 2, widWidth, widHeight);
|
2, 2, widWidth, widHeight);
|
||||||
myTab->setParentWidget(tabID, myPrompt);
|
myTab->setParentWidget(tabID, myPrompt);
|
||||||
addToFocusList(myPrompt->getFocusList(), tabID);
|
addToFocusList(myPrompt->getFocusList(), tabID);
|
||||||
|
|
||||||
// The TIA tab
|
// The TIA tab
|
||||||
tabID = myTab->addTab("TIA");
|
tabID = myTab->addTab("TIA");
|
||||||
TiaWidget* tia = new TiaWidget(myTab, instance()->consoleFont(),
|
TiaWidget* tia = new TiaWidget(myTab, instance().consoleFont(),
|
||||||
2, 2, widWidth, widHeight);
|
2, 2, widWidth, widHeight);
|
||||||
myTab->setParentWidget(tabID, tia);
|
myTab->setParentWidget(tabID, tia);
|
||||||
addToFocusList(tia->getFocusList(), tabID);
|
addToFocusList(tia->getFocusList(), tabID);
|
||||||
|
|
||||||
// The input/output tab (includes RIOT and INPTx from TIA)
|
// The input/output tab (includes RIOT and INPTx from TIA)
|
||||||
tabID = myTab->addTab("I/O");
|
tabID = myTab->addTab("I/O");
|
||||||
RiotWidget* riot = new RiotWidget(myTab, instance()->consoleFont(),
|
RiotWidget* riot = new RiotWidget(myTab, instance().consoleFont(),
|
||||||
2, 2, widWidth, widHeight);
|
2, 2, widWidth, widHeight);
|
||||||
myTab->setParentWidget(tabID, riot);
|
myTab->setParentWidget(tabID, riot);
|
||||||
addToFocusList(riot->getFocusList(), tabID);
|
addToFocusList(riot->getFocusList(), tabID);
|
||||||
|
|
||||||
// The Audio tab
|
// The Audio tab
|
||||||
tabID = myTab->addTab("Audio");
|
tabID = myTab->addTab("Audio");
|
||||||
AudioWidget* aud = new AudioWidget(myTab, instance()->consoleFont(),
|
AudioWidget* aud = new AudioWidget(myTab, instance().consoleFont(),
|
||||||
2, 2, widWidth, widHeight);
|
2, 2, widWidth, widHeight);
|
||||||
myTab->setParentWidget(tabID, aud);
|
myTab->setParentWidget(tabID, aud);
|
||||||
addToFocusList(aud->getFocusList(), tabID);
|
addToFocusList(aud->getFocusList(), tabID);
|
||||||
|
@ -203,21 +203,21 @@ void DebuggerDialog::addTabArea()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::addStatusArea()
|
void DebuggerDialog::addStatusArea()
|
||||||
{
|
{
|
||||||
const GUI::Font& font = instance()->consoleFont();
|
const GUI::Font& font = instance().consoleFont();
|
||||||
const int lineHeight = font.getLineHeight();
|
const int lineHeight = font.getLineHeight();
|
||||||
GUI::Rect r = instance()->debugger().getStatusBounds();
|
GUI::Rect r = instance().debugger().getStatusBounds();
|
||||||
int xpos, ypos;
|
int xpos, ypos;
|
||||||
|
|
||||||
xpos = r.left; ypos = r.top;
|
xpos = r.left; ypos = r.top;
|
||||||
myTiaInfo = new TiaInfoWidget(this, instance()->consoleFont(), xpos, ypos);
|
myTiaInfo = new TiaInfoWidget(this, instance().consoleFont(), xpos, ypos);
|
||||||
|
|
||||||
ypos += myTiaInfo->getHeight() + 10;
|
ypos += myTiaInfo->getHeight() + 10;
|
||||||
myTiaZoom = new TiaZoomWidget(this, instance()->consoleFont(), xpos+10, ypos,
|
myTiaZoom = new TiaZoomWidget(this, instance().consoleFont(), xpos+10, ypos,
|
||||||
r.width()-10, r.height()-lineHeight-ypos-10);
|
r.width()-10, r.height()-lineHeight-ypos-10);
|
||||||
addToFocusList(myTiaZoom->getFocusList());
|
addToFocusList(myTiaZoom->getFocusList());
|
||||||
|
|
||||||
xpos += 10; ypos += myTiaZoom->getHeight() + 10;
|
xpos += 10; ypos += myTiaZoom->getHeight() + 10;
|
||||||
myMessageBox = new EditTextWidget(this, instance()->consoleFont(),
|
myMessageBox = new EditTextWidget(this, instance().consoleFont(),
|
||||||
xpos, ypos, myTiaZoom->getWidth(),
|
xpos, ypos, myTiaZoom->getWidth(),
|
||||||
font.getLineHeight(), "");
|
font.getLineHeight(), "");
|
||||||
myMessageBox->setEditable(false);
|
myMessageBox->setEditable(false);
|
||||||
|
@ -228,43 +228,43 @@ void DebuggerDialog::addStatusArea()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::addRomArea()
|
void DebuggerDialog::addRomArea()
|
||||||
{
|
{
|
||||||
GUI::Rect r = instance()->debugger().getRomBounds();
|
GUI::Rect r = instance().debugger().getRomBounds();
|
||||||
int xpos, ypos;
|
int xpos, ypos;
|
||||||
|
|
||||||
xpos = r.left + 10; ypos = 10;
|
xpos = r.left + 10; ypos = 10;
|
||||||
myCpu = new CpuWidget(this, instance()->consoleFont(), xpos, ypos);
|
myCpu = new CpuWidget(this, instance().consoleFont(), xpos, ypos);
|
||||||
addToFocusList(myCpu->getFocusList());
|
addToFocusList(myCpu->getFocusList());
|
||||||
|
|
||||||
xpos = r.left + 10; ypos += myCpu->getHeight() + 10;
|
xpos = r.left + 10; ypos += myCpu->getHeight() + 10;
|
||||||
myRam = new RamWidget(this, instance()->consoleFont(), xpos, ypos);
|
myRam = new RamWidget(this, instance().consoleFont(), xpos, ypos);
|
||||||
addToFocusList(myRam->getFocusList());
|
addToFocusList(myRam->getFocusList());
|
||||||
|
|
||||||
xpos = r.left + 10 + myCpu->getWidth() + 5;
|
xpos = r.left + 10 + myCpu->getWidth() + 5;
|
||||||
DataGridOpsWidget* ops = new DataGridOpsWidget(this, instance()->consoleFont(),
|
DataGridOpsWidget* ops = new DataGridOpsWidget(this, instance().consoleFont(),
|
||||||
xpos, 20);
|
xpos, 20);
|
||||||
|
|
||||||
const int bwidth = instance()->consoleFont().getStringWidth("Frame +1 "),
|
const int bwidth = instance().consoleFont().getStringWidth("Frame +1 "),
|
||||||
bheight = instance()->consoleFont().getLineHeight() + 2;
|
bheight = instance().consoleFont().getLineHeight() + 2;
|
||||||
int buttonX = r.right - bwidth - 5, buttonY = r.top + 5;
|
int buttonX = r.right - bwidth - 5, buttonY = r.top + 5;
|
||||||
|
|
||||||
new ButtonWidget(this, instance()->consoleFont(), buttonX, buttonY,
|
new ButtonWidget(this, instance().consoleFont(), buttonX, buttonY,
|
||||||
bwidth, bheight, "Step", kDDStepCmd);
|
bwidth, bheight, "Step", kDDStepCmd);
|
||||||
buttonY += bheight + 4;
|
buttonY += bheight + 4;
|
||||||
new ButtonWidget(this, instance()->consoleFont(), buttonX, buttonY,
|
new ButtonWidget(this, instance().consoleFont(), buttonX, buttonY,
|
||||||
bwidth, bheight, "Trace", kDDTraceCmd);
|
bwidth, bheight, "Trace", kDDTraceCmd);
|
||||||
buttonY += bheight + 4;
|
buttonY += bheight + 4;
|
||||||
new ButtonWidget(this, instance()->consoleFont(), buttonX, buttonY,
|
new ButtonWidget(this, instance().consoleFont(), buttonX, buttonY,
|
||||||
bwidth, bheight, "Scan +1", kDDSAdvCmd);
|
bwidth, bheight, "Scan +1", kDDSAdvCmd);
|
||||||
buttonY += bheight + 4;
|
buttonY += bheight + 4;
|
||||||
new ButtonWidget(this, instance()->consoleFont(), buttonX, buttonY,
|
new ButtonWidget(this, instance().consoleFont(), buttonX, buttonY,
|
||||||
bwidth, bheight, "Frame +1", kDDAdvCmd);
|
bwidth, bheight, "Frame +1", kDDAdvCmd);
|
||||||
buttonY += bheight + 4;
|
buttonY += bheight + 4;
|
||||||
new ButtonWidget(this, instance()->consoleFont(), buttonX, buttonY,
|
new ButtonWidget(this, instance().consoleFont(), buttonX, buttonY,
|
||||||
bwidth, bheight, "Exit", kDDExitCmd);
|
bwidth, bheight, "Exit", kDDExitCmd);
|
||||||
buttonY += bheight + 4;
|
buttonY += bheight + 4;
|
||||||
|
|
||||||
xpos = r.left + 10; ypos += myRam->getHeight() + 5;
|
xpos = r.left + 10; ypos += myRam->getHeight() + 5;
|
||||||
myRom = new RomWidget(this, instance()->consoleFont(), xpos, ypos);
|
myRom = new RomWidget(this, instance().consoleFont(), xpos, ypos);
|
||||||
addToFocusList(myRom->getFocusList());
|
addToFocusList(myRom->getFocusList());
|
||||||
|
|
||||||
// Add the DataGridOpsWidget to any widgets which contain a
|
// Add the DataGridOpsWidget to any widgets which contain a
|
||||||
|
@ -276,29 +276,29 @@ void DebuggerDialog::addRomArea()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::doStep()
|
void DebuggerDialog::doStep()
|
||||||
{
|
{
|
||||||
instance()->debugger().parser().run("step");
|
instance().debugger().parser().run("step");
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::doTrace()
|
void DebuggerDialog::doTrace()
|
||||||
{
|
{
|
||||||
instance()->debugger().parser().run("trace");
|
instance().debugger().parser().run("trace");
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::doAdvance()
|
void DebuggerDialog::doAdvance()
|
||||||
{
|
{
|
||||||
instance()->debugger().parser().run("frame #1");
|
instance().debugger().parser().run("frame #1");
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::doScanlineAdvance()
|
void DebuggerDialog::doScanlineAdvance()
|
||||||
{
|
{
|
||||||
instance()->debugger().parser().run("scanline #1");
|
instance().debugger().parser().run("scanline #1");
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void DebuggerDialog::doExit()
|
void DebuggerDialog::doExit()
|
||||||
{
|
{
|
||||||
instance()->debugger().parser().run("run");
|
instance().debugger().parser().run("run");
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: PromptWidget.cxx,v 1.24 2008-05-01 23:08:24 stephena Exp $
|
// $Id: PromptWidget.cxx,v 1.25 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -103,7 +103,7 @@ void PromptWidget::drawWidget(bool hilite)
|
||||||
//cerr << "PromptWidget::drawWidget\n";
|
//cerr << "PromptWidget::drawWidget\n";
|
||||||
int fgcolor, bgcolor;
|
int fgcolor, bgcolor;
|
||||||
|
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
|
|
||||||
// Draw text
|
// Draw text
|
||||||
int start = _scrollLine - _linesPerPage + 1;
|
int start = _scrollLine - _linesPerPage + 1;
|
||||||
|
@ -118,11 +118,11 @@ void PromptWidget::drawWidget(bool hilite)
|
||||||
if(c & (1 << 17)) { // inverse video flag
|
if(c & (1 << 17)) { // inverse video flag
|
||||||
fgcolor = _bgcolor;
|
fgcolor = _bgcolor;
|
||||||
bgcolor = (c & 0x1ffff) >> 8;
|
bgcolor = (c & 0x1ffff) >> 8;
|
||||||
fb.fillRect(x, y, _kConsoleCharWidth, _kConsoleCharHeight, bgcolor);
|
s.fillRect(x, y, _kConsoleCharWidth, _kConsoleCharHeight, bgcolor);
|
||||||
} else {
|
} else {
|
||||||
fgcolor = c >> 8;
|
fgcolor = c >> 8;
|
||||||
}
|
}
|
||||||
fb.drawChar(&instance()->consoleFont(), c & 0x7f, x, y, fgcolor);
|
s.drawChar(&instance().consoleFont(), c & 0x7f, x, y, fgcolor);
|
||||||
x += _kConsoleCharWidth;
|
x += _kConsoleCharWidth;
|
||||||
}
|
}
|
||||||
y += _kConsoleLineHeight;
|
y += _kConsoleLineHeight;
|
||||||
|
@ -150,7 +150,7 @@ void PromptWidget::handleMouseWheel(int x, int y, int direction)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void PromptWidget::printPrompt()
|
void PromptWidget::printPrompt()
|
||||||
{
|
{
|
||||||
string watches = instance()->debugger().showWatches();
|
string watches = instance().debugger().showWatches();
|
||||||
if(watches.length() > 0)
|
if(watches.length() > 0)
|
||||||
print(watches);
|
print(watches);
|
||||||
|
|
||||||
|
@ -186,7 +186,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
addToHistory(command.c_str());
|
addToHistory(command.c_str());
|
||||||
|
|
||||||
// Pass the command to the debugger, and print the result
|
// Pass the command to the debugger, and print the result
|
||||||
string result = instance()->debugger().run(command);
|
string result = instance().debugger().run(command);
|
||||||
|
|
||||||
// This is a bit of a hack
|
// This is a bit of a hack
|
||||||
// Certain commands remove the debugger dialog from underneath us,
|
// Certain commands remove the debugger dialog from underneath us,
|
||||||
|
@ -239,7 +239,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
if(lastDelimPos < 0)
|
if(lastDelimPos < 0)
|
||||||
{
|
{
|
||||||
// no delimiters, do command completion:
|
// no delimiters, do command completion:
|
||||||
DebuggerParser& parser = instance()->debugger().parser();
|
DebuggerParser& parser = instance().debugger().parser();
|
||||||
possibilities = parser.countCompletions(str);
|
possibilities = parser.countCompletions(str);
|
||||||
|
|
||||||
if(possibilities < 1) {
|
if(possibilities < 1) {
|
||||||
|
@ -253,7 +253,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// we got a delimiter, so this must be a label:
|
// we got a delimiter, so this must be a label:
|
||||||
EquateList& equates = instance()->debugger().equates();
|
EquateList& equates = instance().debugger().equates();
|
||||||
possibilities = equates.countCompletions(str + lastDelimPos + 1);
|
possibilities = equates.countCompletions(str + lastDelimPos + 1);
|
||||||
|
|
||||||
if(possibilities < 1) {
|
if(possibilities < 1) {
|
||||||
|
@ -317,7 +317,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 256 + 24: // pageup
|
case 256 + 24: // pageup
|
||||||
if (instance()->eventHandler().kbdShift(modifiers))
|
if (instance().eventHandler().kbdShift(modifiers))
|
||||||
{
|
{
|
||||||
// Don't scroll up when at top of buffer
|
// Don't scroll up when at top of buffer
|
||||||
if(_scrollLine < _linesPerPage)
|
if(_scrollLine < _linesPerPage)
|
||||||
|
@ -333,7 +333,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 256 + 25: // pagedown
|
case 256 + 25: // pagedown
|
||||||
if (instance()->eventHandler().kbdShift(modifiers))
|
if (instance().eventHandler().kbdShift(modifiers))
|
||||||
{
|
{
|
||||||
// Don't scroll down when at bottom of buffer
|
// Don't scroll down when at bottom of buffer
|
||||||
if(_scrollLine >= _promptEndPos / _lineWidth)
|
if(_scrollLine >= _promptEndPos / _lineWidth)
|
||||||
|
@ -349,7 +349,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 256 + 22: // home
|
case 256 + 22: // home
|
||||||
if (instance()->eventHandler().kbdShift(modifiers))
|
if (instance().eventHandler().kbdShift(modifiers))
|
||||||
{
|
{
|
||||||
_scrollLine = _firstLineInBuffer + _linesPerPage - 1;
|
_scrollLine = _firstLineInBuffer + _linesPerPage - 1;
|
||||||
updateScrollBuffer();
|
updateScrollBuffer();
|
||||||
|
@ -361,7 +361,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 256 + 23: // end
|
case 256 + 23: // end
|
||||||
if (instance()->eventHandler().kbdShift(modifiers))
|
if (instance().eventHandler().kbdShift(modifiers))
|
||||||
{
|
{
|
||||||
_scrollLine = _promptEndPos / _lineWidth;
|
_scrollLine = _promptEndPos / _lineWidth;
|
||||||
if (_scrollLine < _linesPerPage - 1)
|
if (_scrollLine < _linesPerPage - 1)
|
||||||
|
@ -375,7 +375,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 273: // cursor up
|
case 273: // cursor up
|
||||||
if (instance()->eventHandler().kbdShift(modifiers))
|
if (instance().eventHandler().kbdShift(modifiers))
|
||||||
{
|
{
|
||||||
if(_scrollLine <= _firstLineInBuffer + _linesPerPage - 1)
|
if(_scrollLine <= _firstLineInBuffer + _linesPerPage - 1)
|
||||||
break;
|
break;
|
||||||
|
@ -390,7 +390,7 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 274: // cursor down
|
case 274: // cursor down
|
||||||
if (instance()->eventHandler().kbdShift(modifiers))
|
if (instance().eventHandler().kbdShift(modifiers))
|
||||||
{
|
{
|
||||||
// Don't scroll down when at bottom of buffer
|
// Don't scroll down when at bottom of buffer
|
||||||
if(_scrollLine >= _promptEndPos / _lineWidth)
|
if(_scrollLine >= _promptEndPos / _lineWidth)
|
||||||
|
@ -420,11 +420,11 @@ bool PromptWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (instance()->eventHandler().kbdControl(modifiers))
|
if (instance().eventHandler().kbdControl(modifiers))
|
||||||
{
|
{
|
||||||
specialKeys(keycode);
|
specialKeys(keycode);
|
||||||
}
|
}
|
||||||
else if (instance()->eventHandler().kbdAlt(modifiers))
|
else if (instance().eventHandler().kbdAlt(modifiers))
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
else if (isprint(ascii))
|
else if (isprint(ascii))
|
||||||
|
@ -526,7 +526,7 @@ void PromptWidget::loadConfig()
|
||||||
_exitedEarly = false;
|
_exitedEarly = false;
|
||||||
|
|
||||||
// Take care of one-time debugger stuff
|
// Take care of one-time debugger stuff
|
||||||
instance()->debugger().autoExec();
|
instance().debugger().autoExec();
|
||||||
}
|
}
|
||||||
else if(_exitedEarly)
|
else if(_exitedEarly)
|
||||||
{
|
{
|
||||||
|
@ -836,7 +836,7 @@ void PromptWidget::print(const string& str)
|
||||||
void PromptWidget::drawCaret()
|
void PromptWidget::drawCaret()
|
||||||
{
|
{
|
||||||
//cerr << "PromptWidget::drawCaret()\n";
|
//cerr << "PromptWidget::drawCaret()\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
|
|
||||||
int line = _currentPos / _lineWidth;
|
int line = _currentPos / _lineWidth;
|
||||||
|
|
||||||
|
@ -849,8 +849,8 @@ void PromptWidget::drawCaret()
|
||||||
int y = _y + displayLine * _kConsoleLineHeight;
|
int y = _y + displayLine * _kConsoleLineHeight;
|
||||||
|
|
||||||
char c = buffer(_currentPos);
|
char c = buffer(_currentPos);
|
||||||
fb.fillRect(x, y, _kConsoleCharWidth, _kConsoleLineHeight, kTextColor);
|
s.fillRect(x, y, _kConsoleCharWidth, _kConsoleLineHeight, kTextColor);
|
||||||
fb.drawChar(&_boss->instance()->consoleFont(), c, x, y + 2, kBGColor);
|
s.drawChar(&_boss->instance().consoleFont(), c, x, y + 2, kBGColor);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: RamWidget.cxx,v 1.17 2008-05-04 17:16:39 stephena Exp $
|
// $Id: RamWidget.cxx,v 1.18 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -154,7 +154,7 @@ void RamWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
// memory location
|
// memory location
|
||||||
int addr, value;
|
int addr, value;
|
||||||
|
|
||||||
RamDebug& dbg = instance()->debugger().ramDebug();
|
RamDebug& dbg = instance().debugger().ramDebug();
|
||||||
switch(cmd)
|
switch(cmd)
|
||||||
{
|
{
|
||||||
case kDGItemDataChangedCmd:
|
case kDGItemDataChangedCmd:
|
||||||
|
@ -165,8 +165,8 @@ void RamWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
myUndoValue = dbg.read(addr);
|
myUndoValue = dbg.read(addr);
|
||||||
|
|
||||||
dbg.write(addr, value);
|
dbg.write(addr, value);
|
||||||
myDecValue->setEditString(instance()->debugger().valueToString(value, kBASE_10));
|
myDecValue->setEditString(instance().debugger().valueToString(value, kBASE_10));
|
||||||
myBinValue->setEditString(instance()->debugger().valueToString(value, kBASE_2));
|
myBinValue->setEditString(instance().debugger().valueToString(value, kBASE_2));
|
||||||
myRevertButton->setEnabled(true);
|
myRevertButton->setEnabled(true);
|
||||||
myUndoButton->setEnabled(true);
|
myUndoButton->setEnabled(true);
|
||||||
break;
|
break;
|
||||||
|
@ -177,9 +177,9 @@ void RamWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
value = myRamGrid->getSelectedValue();
|
value = myRamGrid->getSelectedValue();
|
||||||
|
|
||||||
myLabel->setEditString(
|
myLabel->setEditString(
|
||||||
instance()->debugger().equates().getLabel(addr+kRamStart, true));
|
instance().debugger().equates().getLabel(addr+kRamStart, true));
|
||||||
myDecValue->setEditString(instance()->debugger().valueToString(value, kBASE_10));
|
myDecValue->setEditString(instance().debugger().valueToString(value, kBASE_10));
|
||||||
myBinValue->setEditString(instance()->debugger().valueToString(value, kBASE_2));
|
myBinValue->setEditString(instance().debugger().valueToString(value, kBASE_2));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -196,14 +196,14 @@ void RamWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kSearchCmd:
|
case kSearchCmd:
|
||||||
parent()->addDialog(myInputBox);
|
parent().addDialog(myInputBox);
|
||||||
myInputBox->setEditString("");
|
myInputBox->setEditString("");
|
||||||
myInputBox->setTitle("");
|
myInputBox->setTitle("");
|
||||||
myInputBox->setEmitSignal(kSValEntered);
|
myInputBox->setEmitSignal(kSValEntered);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kCmpCmd:
|
case kCmpCmd:
|
||||||
parent()->addDialog(myInputBox);
|
parent().addDialog(myInputBox);
|
||||||
myInputBox->setEditString("");
|
myInputBox->setEditString("");
|
||||||
myInputBox->setTitle("");
|
myInputBox->setTitle("");
|
||||||
myInputBox->setEmitSignal(kCValEntered);
|
myInputBox->setEmitSignal(kCValEntered);
|
||||||
|
@ -219,7 +219,7 @@ void RamWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
if(result != "")
|
if(result != "")
|
||||||
myInputBox->setTitle(result);
|
myInputBox->setTitle(result);
|
||||||
else
|
else
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -229,7 +229,7 @@ void RamWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
if(result != "")
|
if(result != "")
|
||||||
myInputBox->setTitle(result);
|
myInputBox->setTitle(result);
|
||||||
else
|
else
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -251,7 +251,7 @@ void RamWidget::fillGrid(bool updateOld)
|
||||||
|
|
||||||
if(updateOld) myOldValueList.clear();
|
if(updateOld) myOldValueList.clear();
|
||||||
|
|
||||||
RamDebug& dbg = instance()->debugger().ramDebug();
|
RamDebug& dbg = instance().debugger().ramDebug();
|
||||||
|
|
||||||
RamState state = (RamState&) dbg.getState();
|
RamState state = (RamState&) dbg.getState();
|
||||||
RamState oldstate = (RamState&) dbg.getOldState();
|
RamState oldstate = (RamState&) dbg.getOldState();
|
||||||
|
@ -289,7 +289,7 @@ const string RamWidget::doSearch(const string& str)
|
||||||
return "Invalid input +|-";
|
return "Invalid input +|-";
|
||||||
}
|
}
|
||||||
|
|
||||||
int searchVal = instance()->debugger().stringToValue(str);
|
int searchVal = instance().debugger().stringToValue(str);
|
||||||
|
|
||||||
// Clear the search array of previous items
|
// Clear the search array of previous items
|
||||||
mySearchAddr.clear();
|
mySearchAddr.clear();
|
||||||
|
@ -297,7 +297,7 @@ const string RamWidget::doSearch(const string& str)
|
||||||
|
|
||||||
// Now, search all memory locations for this value, and add it to the
|
// Now, search all memory locations for this value, and add it to the
|
||||||
// search array
|
// search array
|
||||||
RamDebug& dbg = instance()->debugger().ramDebug();
|
RamDebug& dbg = instance().debugger().ramDebug();
|
||||||
for(int addr = 0; addr < kRamSize; ++addr)
|
for(int addr = 0; addr < kRamSize; ++addr)
|
||||||
{
|
{
|
||||||
int value = dbg.read(addr);
|
int value = dbg.read(addr);
|
||||||
|
@ -351,15 +351,15 @@ const string RamWidget::doCompare(const string& str)
|
||||||
|
|
||||||
string tmp = str;
|
string tmp = str;
|
||||||
tmp.erase(0, 1); // remove the operator
|
tmp.erase(0, 1); // remove the operator
|
||||||
offset = instance()->debugger().stringToValue(tmp);
|
offset = instance().debugger().stringToValue(tmp);
|
||||||
if(negative)
|
if(negative)
|
||||||
offset = -offset;
|
offset = -offset;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
searchVal = instance()->debugger().stringToValue(str);
|
searchVal = instance().debugger().stringToValue(str);
|
||||||
|
|
||||||
// Now, search all memory locations specified in mySearchArray for this value
|
// Now, search all memory locations specified in mySearchArray for this value
|
||||||
RamDebug& dbg = instance()->debugger().ramDebug();
|
RamDebug& dbg = instance().debugger().ramDebug();
|
||||||
IntArray tempAddrList, tempValueList;
|
IntArray tempAddrList, tempValueList;
|
||||||
for(unsigned int i = 0; i < mySearchAddr.size(); ++i)
|
for(unsigned int i = 0; i < mySearchAddr.size(); ++i)
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: RiotWidget.cxx,v 1.5 2008-05-15 18:59:56 stephena Exp $
|
// $Id: RiotWidget.cxx,v 1.6 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -91,6 +91,7 @@ RiotWidget::RiotWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
lineHeight = font.getLineHeight();
|
lineHeight = font.getLineHeight();
|
||||||
int xpos = 10, ypos = 25, lwidth = 9 * fontWidth, col = 0;
|
int xpos = 10, ypos = 25, lwidth = 9 * fontWidth, col = 0;
|
||||||
StaticTextWidget* t;
|
StaticTextWidget* t;
|
||||||
|
StringList items;
|
||||||
|
|
||||||
// Set the strings to be used in the various bit registers
|
// Set the strings to be used in the various bit registers
|
||||||
// We only do this once because it's the state that changes, not the strings
|
// We only do this once because it's the state that changes, not the strings
|
||||||
|
@ -157,26 +158,26 @@ RiotWidget::RiotWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
int pwidth = font.getStringWidth("B/easy");
|
int pwidth = font.getStringWidth("B/easy");
|
||||||
lwidth = font.getStringWidth("P0 Diff: ");
|
lwidth = font.getStringWidth("P0 Diff: ");
|
||||||
xpos = col; ypos += 3 * lineHeight;
|
xpos = col; ypos += 3 * lineHeight;
|
||||||
myP0Diff = new PopUpWidget(boss, font, xpos, ypos, pwidth, lineHeight,
|
items.clear();
|
||||||
|
items.push_back("B/easy");
|
||||||
|
items.push_back("A/hard");
|
||||||
|
myP0Diff = new PopUpWidget(boss, font, xpos, ypos, pwidth, lineHeight, items,
|
||||||
"P0 Diff: ", lwidth, kP0DiffChanged);
|
"P0 Diff: ", lwidth, kP0DiffChanged);
|
||||||
myP0Diff->appendEntry("B/easy", 0);
|
|
||||||
myP0Diff->appendEntry("A/hard", 1);
|
|
||||||
myP0Diff->setTarget(this);
|
myP0Diff->setTarget(this);
|
||||||
addFocusWidget(myP0Diff);
|
addFocusWidget(myP0Diff);
|
||||||
ypos += myP0Diff->getHeight() + 5;
|
ypos += myP0Diff->getHeight() + 5;
|
||||||
myP1Diff = new PopUpWidget(boss, font, xpos, ypos, pwidth, lineHeight,
|
myP1Diff = new PopUpWidget(boss, font, xpos, ypos, pwidth, lineHeight, items,
|
||||||
"P1 Diff: ", lwidth, kP1DiffChanged);
|
"P1 Diff: ", lwidth, kP1DiffChanged);
|
||||||
myP1Diff->appendEntry("B/easy", 0);
|
|
||||||
myP1Diff->appendEntry("A/hard", 1);
|
|
||||||
myP1Diff->setTarget(this);
|
myP1Diff->setTarget(this);
|
||||||
addFocusWidget(myP1Diff);
|
addFocusWidget(myP1Diff);
|
||||||
|
|
||||||
// TV Type
|
// TV Type
|
||||||
ypos += myP1Diff->getHeight() + 5;
|
ypos += myP1Diff->getHeight() + 5;
|
||||||
myTVType = new PopUpWidget(boss, font, xpos, ypos, pwidth, lineHeight,
|
items.clear();
|
||||||
|
items.push_back("B&W");
|
||||||
|
items.push_back("Color");
|
||||||
|
myTVType = new PopUpWidget(boss, font, xpos, ypos, pwidth, lineHeight, items,
|
||||||
"TV Type: ", lwidth, kTVTypeChanged);
|
"TV Type: ", lwidth, kTVTypeChanged);
|
||||||
myTVType->appendEntry("B&W", 0);
|
|
||||||
myTVType->appendEntry("Color", 1);
|
|
||||||
myTVType->setTarget(this);
|
myTVType->setTarget(this);
|
||||||
addFocusWidget(myTVType);
|
addFocusWidget(myTVType);
|
||||||
|
|
||||||
|
@ -215,7 +216,7 @@ void RiotWidget::loadConfig()
|
||||||
|
|
||||||
// We push the enumerated items as addresses, and deal with the real
|
// We push the enumerated items as addresses, and deal with the real
|
||||||
// address in the callback (handleCommand)
|
// address in the callback (handleCommand)
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
RiotDebug& riot = dbg.riotDebug();
|
RiotDebug& riot = dbg.riotDebug();
|
||||||
const RiotState& state = (RiotState&) riot.getState();
|
const RiotState& state = (RiotState&) riot.getState();
|
||||||
const RiotState& oldstate = (RiotState&) riot.getOldState();
|
const RiotState& oldstate = (RiotState&) riot.getOldState();
|
||||||
|
@ -269,9 +270,9 @@ void RiotWidget::loadConfig()
|
||||||
myP1Pins[4]->setState(!state.P1_PIN6);
|
myP1Pins[4]->setState(!state.P1_PIN6);
|
||||||
|
|
||||||
// Console switches (invert reset/select for same reason as the pins)
|
// Console switches (invert reset/select for same reason as the pins)
|
||||||
myP0Diff->setSelectedTag((int)riot.diffP0());
|
myP0Diff->setSelected((int)riot.diffP0());
|
||||||
myP1Diff->setSelectedTag((int)riot.diffP1());
|
myP1Diff->setSelected((int)riot.diffP1());
|
||||||
myTVType->setSelectedTag((int)riot.tvType());
|
myTVType->setSelected((int)riot.tvType());
|
||||||
mySelect->setState(!riot.select());
|
mySelect->setState(!riot.select());
|
||||||
myReset->setState(!riot.reset());
|
myReset->setState(!riot.reset());
|
||||||
}
|
}
|
||||||
|
@ -280,7 +281,7 @@ void RiotWidget::loadConfig()
|
||||||
void RiotWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
void RiotWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
{
|
{
|
||||||
int value = -1;
|
int value = -1;
|
||||||
RiotDebug& riot = instance()->debugger().riotDebug();
|
RiotDebug& riot = instance().debugger().riotDebug();
|
||||||
|
|
||||||
switch(cmd)
|
switch(cmd)
|
||||||
{
|
{
|
||||||
|
@ -344,15 +345,15 @@ void RiotWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kP0DiffChanged:
|
case kP0DiffChanged:
|
||||||
riot.diffP0((bool)myP0Diff->getSelectedTag());
|
riot.diffP0((bool)myP0Diff->getSelected());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kP1DiffChanged:
|
case kP1DiffChanged:
|
||||||
riot.diffP1((bool)myP1Diff->getSelectedTag());
|
riot.diffP1((bool)myP1Diff->getSelected());
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kTVTypeChanged:
|
case kTVTypeChanged:
|
||||||
riot.tvType((bool)myTVType->getSelectedTag());
|
riot.tvType((bool)myTVType->getSelected());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: RomListWidget.cxx,v 1.12 2008-05-11 21:18:34 stephena Exp $
|
// $Id: RomListWidget.cxx,v 1.13 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -32,14 +32,11 @@ RomListWidget::RomListWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
{
|
{
|
||||||
_type = kRomListWidget;
|
_type = kRomListWidget;
|
||||||
|
|
||||||
myMenu = new ContextMenu(this, font);
|
|
||||||
|
|
||||||
StringList l;
|
StringList l;
|
||||||
// l.push_back("Add bookmark");
|
// l.push_back("Add bookmark");
|
||||||
l.push_back("Save ROM");
|
l.push_back("Save ROM");
|
||||||
l.push_back("Set PC");
|
l.push_back("Set PC");
|
||||||
|
myMenu = new ContextMenu(this, font, l);
|
||||||
myMenu->setList(l);
|
|
||||||
|
|
||||||
// Take advantage of a wide debugger window when possible
|
// Take advantage of a wide debugger window when possible
|
||||||
const int fontWidth = font.getMaxCharWidth(),
|
const int fontWidth = font.getMaxCharWidth(),
|
||||||
|
@ -70,10 +67,7 @@ void RomListWidget::handleMouseDown(int x, int y, int button, 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(button == 2)
|
if(button == 2)
|
||||||
{
|
myMenu->show(x + getAbsX(), y + getAbsY());
|
||||||
myMenu->setPos(x + getAbsX(), y + getAbsY());
|
|
||||||
myMenu->show();
|
|
||||||
}
|
|
||||||
|
|
||||||
ListWidget::handleMouseDown(x, y, button, clickCount);
|
ListWidget::handleMouseDown(x, y, button, clickCount);
|
||||||
}
|
}
|
||||||
|
@ -88,17 +82,17 @@ bool RomListWidget::handleEvent(Event::Type e)
|
||||||
void RomListWidget::drawWidget(bool hilite)
|
void RomListWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "RomListWidget::drawWidget\n";
|
//cerr << "RomListWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
int i, pos, len = _list.size();
|
int i, pos, len = _list.size();
|
||||||
string buffer;
|
string buffer;
|
||||||
int deltax;
|
int deltax;
|
||||||
|
|
||||||
// Draw a thin frame around the list and to separate columns
|
// Draw a thin frame around the list and to separate columns
|
||||||
fb.hLine(_x, _y, _x + _w - 1, kColor);
|
s.hLine(_x, _y, _x + _w - 1, kColor);
|
||||||
fb.hLine(_x, _y + _h - 1, _x + _w - 1, kShadowColor);
|
s.hLine(_x, _y + _h - 1, _x + _w - 1, kShadowColor);
|
||||||
fb.vLine(_x, _y, _y + _h - 1, kColor);
|
s.vLine(_x, _y, _y + _h - 1, kColor);
|
||||||
|
|
||||||
fb.vLine(_x + CheckboxWidget::boxSize() + 5, _y, _y + _h - 1, kColor);
|
s.vLine(_x + CheckboxWidget::boxSize() + 5, _y, _y + _h - 1, kColor);
|
||||||
|
|
||||||
// Draw the list items
|
// Draw the list items
|
||||||
for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++)
|
for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++)
|
||||||
|
@ -116,7 +110,7 @@ void RomListWidget::drawWidget(bool hilite)
|
||||||
// Draw highlighted item in a frame
|
// Draw highlighted item in a frame
|
||||||
if (_highlightedItem == pos)
|
if (_highlightedItem == pos)
|
||||||
{
|
{
|
||||||
fb.frameRect(_x + l.left - 3, _y + 1 + _fontHeight * i,
|
s.frameRect(_x + l.left - 3, _y + 1 + _fontHeight * i,
|
||||||
_w - l.left, _fontHeight, kDbgColorHi);
|
_w - l.left, _fontHeight, kDbgColorHi);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -124,20 +118,18 @@ void RomListWidget::drawWidget(bool hilite)
|
||||||
if (_selectedItem == pos && _hasFocus)
|
if (_selectedItem == pos && _hasFocus)
|
||||||
{
|
{
|
||||||
if (!_editMode)
|
if (!_editMode)
|
||||||
fb.fillRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
s.fillRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
||||||
r.width(), _fontHeight,
|
r.width(), _fontHeight, kTextColorHi);
|
||||||
kTextColorHi);
|
|
||||||
else
|
else
|
||||||
fb.frameRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
s.frameRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
||||||
r.width(), _fontHeight,
|
r.width(), _fontHeight, kTextColorHi);
|
||||||
kTextColorHi);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw labels and actual disassembly
|
// Draw labels and actual disassembly
|
||||||
fb.drawString(_font, myLabel[pos], _x + r.left - myLabelWidth, y,
|
s.drawString(_font, myLabel[pos], _x + r.left - myLabelWidth, y,
|
||||||
myLabelWidth, kTextColor);
|
myLabelWidth, kTextColor);
|
||||||
|
|
||||||
fb.drawString(_font, myDisasm[pos], _x + r.right, y,
|
s.drawString(_font, myDisasm[pos], _x + r.right, y,
|
||||||
_w - r.right, kTextColor);
|
_w - r.right, kTextColor);
|
||||||
|
|
||||||
// Draw editable bytes
|
// Draw editable bytes
|
||||||
|
@ -147,14 +139,14 @@ void RomListWidget::drawWidget(bool hilite)
|
||||||
adjustOffset();
|
adjustOffset();
|
||||||
deltax = -_editScrollOffset;
|
deltax = -_editScrollOffset;
|
||||||
|
|
||||||
fb.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor,
|
s.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor,
|
||||||
kTextAlignLeft, deltax, false);
|
kTextAlignLeft, deltax, false);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
buffer = _list[pos];
|
buffer = _list[pos];
|
||||||
deltax = 0;
|
deltax = 0;
|
||||||
fb.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor);
|
s.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: RomWidget.cxx,v 1.24 2008-03-23 17:43:22 stephena Exp $
|
// $Id: RomWidget.cxx,v 1.25 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -61,8 +61,8 @@ RomWidget::RomWidget(GuiObject* boss, const GUI::Font& font, int x, int y)
|
||||||
myBank = new DataGridWidget(boss, font, xpos, ypos-2,
|
myBank = new DataGridWidget(boss, font, xpos, ypos-2,
|
||||||
1, 1, 3, 8, kBASE_10);
|
1, 1, 3, 8, kBASE_10);
|
||||||
myBank->setTarget(this);
|
myBank->setTarget(this);
|
||||||
myBank->setRange(0, instance()->debugger().bankCount());
|
myBank->setRange(0, instance().debugger().bankCount());
|
||||||
if(instance()->debugger().bankCount() <= 1)
|
if(instance().debugger().bankCount() <= 1)
|
||||||
myBank->setEditable(false);
|
myBank->setEditable(false);
|
||||||
addFocusWidget(myBank);
|
addFocusWidget(myBank);
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@ RomWidget::RomWidget(GuiObject* boss, const GUI::Font& font, int x, int y)
|
||||||
|
|
||||||
// Create rom listing
|
// Create rom listing
|
||||||
xpos = x; ypos += myBank->getHeight() + 4;
|
xpos = x; ypos += myBank->getHeight() + 4;
|
||||||
GUI::Rect dialog = instance()->debugger().getDialogBounds();
|
GUI::Rect dialog = instance().debugger().getDialogBounds();
|
||||||
int w = dialog.width() - x - 5, h = dialog.height() - ypos - 3;
|
int w = dialog.width() - x - 5, h = dialog.height() - ypos - 3;
|
||||||
|
|
||||||
myRomList = new RomListWidget(boss, font, xpos, ypos, w, h);
|
myRomList = new RomListWidget(boss, font, xpos, ypos, w, h);
|
||||||
|
@ -133,7 +133,7 @@ void RomWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
{
|
{
|
||||||
mySaveRom->setTitle("");
|
mySaveRom->setTitle("");
|
||||||
mySaveRom->setEmitSignal(kRomNameEntered);
|
mySaveRom->setEmitSignal(kRomNameEntered);
|
||||||
parent()->addDialog(mySaveRom);
|
parent().addDialog(mySaveRom);
|
||||||
}
|
}
|
||||||
else if(rmb == "Set PC")
|
else if(rmb == "Set PC")
|
||||||
setPC(myRomList->getSelected());
|
setPC(myRomList->getSelected());
|
||||||
|
@ -149,7 +149,7 @@ void RomWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
saveROM(rom);
|
saveROM(rom);
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -157,7 +157,7 @@ void RomWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
case kDGItemDataChangedCmd:
|
case kDGItemDataChangedCmd:
|
||||||
{
|
{
|
||||||
int bank = myBank->getSelectedValue();
|
int bank = myBank->getSelectedValue();
|
||||||
instance()->debugger().setBank(bank);
|
instance().debugger().setBank(bank);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -165,7 +165,7 @@ void RomWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void RomWidget::loadConfig()
|
void RomWidget::loadConfig()
|
||||||
{
|
{
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
bool bankChanged = myCurrentBank != dbg.getBank();
|
bool bankChanged = myCurrentBank != dbg.getBank();
|
||||||
|
|
||||||
// Only reload full bank when necessary
|
// Only reload full bank when necessary
|
||||||
|
@ -216,7 +216,7 @@ void RomWidget::loadConfig()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void RomWidget::initialUpdate()
|
void RomWidget::initialUpdate()
|
||||||
{
|
{
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
PackedBitArray& bp = dbg.breakpoints();
|
PackedBitArray& bp = dbg.breakpoints();
|
||||||
|
|
||||||
// Reading from ROM might trigger a bankswitch, so save the current bank
|
// Reading from ROM might trigger a bankswitch, so save the current bank
|
||||||
|
@ -266,7 +266,7 @@ void RomWidget::incrementalUpdate(int line, int rows)
|
||||||
void RomWidget::setBreak(int data)
|
void RomWidget::setBreak(int data)
|
||||||
{
|
{
|
||||||
bool state = myRomList->getState(data);
|
bool state = myRomList->getState(data);
|
||||||
instance()->debugger().setBreakPoint(myAddrList[data], state);
|
instance().debugger().setBreakPoint(myAddrList[data], state);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -274,7 +274,7 @@ void RomWidget::setPC(int data)
|
||||||
{
|
{
|
||||||
ostringstream command;
|
ostringstream command;
|
||||||
command << "pc #" << myAddrList[data];
|
command << "pc #" << myAddrList[data];
|
||||||
instance()->debugger().run(command.str());
|
instance().debugger().run(command.str());
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -285,14 +285,14 @@ void RomWidget::patchROM(int data, const string& bytes)
|
||||||
// Temporarily set to base 16, since that's the format the disassembled
|
// Temporarily set to base 16, since that's the format the disassembled
|
||||||
// byte string is in. This eliminates the need to prefix each byte with
|
// byte string is in. This eliminates the need to prefix each byte with
|
||||||
// a '$' character
|
// a '$' character
|
||||||
BaseFormat oldbase = instance()->debugger().parser().base();
|
BaseFormat oldbase = instance().debugger().parser().base();
|
||||||
instance()->debugger().parser().setBase(kBASE_16);
|
instance().debugger().parser().setBase(kBASE_16);
|
||||||
|
|
||||||
command << "rom #" << myAddrList[data] << " " << bytes;
|
command << "rom #" << myAddrList[data] << " " << bytes;
|
||||||
instance()->debugger().run(command.str());
|
instance().debugger().run(command.str());
|
||||||
|
|
||||||
// Restore previous base
|
// Restore previous base
|
||||||
instance()->debugger().parser().setBase(oldbase);
|
instance().debugger().parser().setBase(oldbase);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -300,5 +300,5 @@ void RomWidget::saveROM(const string& rom)
|
||||||
{
|
{
|
||||||
ostringstream command;
|
ostringstream command;
|
||||||
command << "saverom " << rom;
|
command << "saverom " << rom;
|
||||||
instance()->debugger().run(command.str());
|
instance().debugger().run(command.str());
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: TiaInfoWidget.cxx,v 1.9 2008-02-06 13:45:20 stephena Exp $
|
// $Id: TiaInfoWidget.cxx,v 1.10 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -121,7 +121,7 @@ void TiaInfoWidget::handleCommand(CommandSender* sender, int cmd, int data, int
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void TiaInfoWidget::loadConfig()
|
void TiaInfoWidget::loadConfig()
|
||||||
{
|
{
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
TIADebug& tia = dbg.tiaDebug();
|
TIADebug& tia = dbg.tiaDebug();
|
||||||
|
|
||||||
myFrameCount->setEditString(dbg.valueToString(tia.frameCount(), kBASE_10));
|
myFrameCount->setEditString(dbg.valueToString(tia.frameCount(), kBASE_10));
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: TiaOutputWidget.cxx,v 1.15 2008-03-23 17:43:22 stephena Exp $
|
// $Id: TiaOutputWidget.cxx,v 1.16 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -44,14 +44,11 @@ TiaOutputWidget::TiaOutputWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
_type = kTiaOutputWidget;
|
_type = kTiaOutputWidget;
|
||||||
|
|
||||||
// Create context menu for commands
|
// Create context menu for commands
|
||||||
myMenu = new ContextMenu(this, font);
|
|
||||||
|
|
||||||
StringList l;
|
StringList l;
|
||||||
l.push_back("Fill to scanline");
|
l.push_back("Fill to scanline");
|
||||||
l.push_back("Set breakpoint");
|
l.push_back("Set breakpoint");
|
||||||
l.push_back("Set zoom position");
|
l.push_back("Set zoom position");
|
||||||
|
myMenu = new ContextMenu(this, font, l);
|
||||||
myMenu->setList(l);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -71,7 +68,7 @@ void TiaOutputWidget::advanceScanline(int lines)
|
||||||
{
|
{
|
||||||
while(lines)
|
while(lines)
|
||||||
{
|
{
|
||||||
instance()->console().mediaSource().updateScanline();
|
instance().console().mediaSource().updateScanline();
|
||||||
--lines;
|
--lines;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -81,7 +78,7 @@ void TiaOutputWidget::advance(int frames)
|
||||||
{
|
{
|
||||||
while(frames)
|
while(frames)
|
||||||
{
|
{
|
||||||
instance()->console().mediaSource().update();
|
instance().console().mediaSource().update();
|
||||||
--frames;
|
--frames;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -95,15 +92,14 @@ void TiaOutputWidget::handleMouseDown(int x, int y, int button, int clickCount)
|
||||||
myClickX = x;
|
myClickX = x;
|
||||||
myClickY = y;
|
myClickY = y;
|
||||||
|
|
||||||
myMenu->setPos(x + getAbsX(), y + getAbsY());
|
myMenu->show(x + getAbsX(), y + getAbsY());
|
||||||
myMenu->show();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void TiaOutputWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
void TiaOutputWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
{
|
{
|
||||||
int ystart = atoi(instance()->console().properties().get(Display_YStart).c_str());
|
int ystart = atoi(instance().console().properties().get(Display_YStart).c_str());
|
||||||
|
|
||||||
switch(cmd)
|
switch(cmd)
|
||||||
{
|
{
|
||||||
|
@ -114,11 +110,11 @@ void TiaOutputWidget::handleCommand(CommandSender* sender, int cmd, int data, in
|
||||||
{
|
{
|
||||||
ostringstream command;
|
ostringstream command;
|
||||||
int lines = myClickY + ystart -
|
int lines = myClickY + ystart -
|
||||||
instance()->debugger().tiaDebug().scanlines();
|
instance().debugger().tiaDebug().scanlines();
|
||||||
if(lines > 0)
|
if(lines > 0)
|
||||||
{
|
{
|
||||||
command << "scanline #" << lines;
|
command << "scanline #" << lines;
|
||||||
instance()->debugger().parser().run(command.str());
|
instance().debugger().parser().run(command.str());
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -128,7 +124,7 @@ void TiaOutputWidget::handleCommand(CommandSender* sender, int cmd, int data, in
|
||||||
ostringstream command;
|
ostringstream command;
|
||||||
int scanline = myClickY + ystart;
|
int scanline = myClickY + ystart;
|
||||||
command << "breakif _scan==#" << scanline;
|
command << "breakif _scan==#" << scanline;
|
||||||
instance()->debugger().parser().run(command.str());
|
instance().debugger().parser().run(command.str());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -145,6 +141,6 @@ void TiaOutputWidget::handleCommand(CommandSender* sender, int cmd, int data, in
|
||||||
void TiaOutputWidget::drawWidget(bool hilite)
|
void TiaOutputWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
// FIXME - check if we're in 'greyed out mode' and act accordingly
|
// FIXME - check if we're in 'greyed out mode' and act accordingly
|
||||||
instance()->frameBuffer().refresh();
|
instance().frameBuffer().refresh();
|
||||||
instance()->frameBuffer().drawMediaSource();
|
instance().frameBuffer().drawMediaSource();
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: TiaWidget.cxx,v 1.13 2008-05-15 15:07:29 stephena Exp $
|
// $Id: TiaWidget.cxx,v 1.14 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -589,7 +589,7 @@ void TiaWidget::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
int addr, value;
|
int addr, value;
|
||||||
string buf;
|
string buf;
|
||||||
|
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
TIADebug& tia = dbg.tiaDebug();
|
TIADebug& tia = dbg.tiaDebug();
|
||||||
|
|
||||||
switch(cmd)
|
switch(cmd)
|
||||||
|
@ -872,7 +872,7 @@ void TiaWidget::fillGrid()
|
||||||
IntArray vlist;
|
IntArray vlist;
|
||||||
BoolArray blist, changed, grNew, grOld;
|
BoolArray blist, changed, grNew, grOld;
|
||||||
|
|
||||||
Debugger& dbg = instance()->debugger();
|
Debugger& dbg = instance().debugger();
|
||||||
TIADebug& tia = dbg.tiaDebug();
|
TIADebug& tia = dbg.tiaDebug();
|
||||||
TiaState& state = (TiaState&) tia.getState();
|
TiaState& state = (TiaState&) tia.getState();
|
||||||
TiaState& oldstate = (TiaState&) tia.getOldState();
|
TiaState& oldstate = (TiaState&) tia.getOldState();
|
||||||
|
@ -1051,22 +1051,22 @@ void TiaWidget::changeColorRegs()
|
||||||
switch(addr)
|
switch(addr)
|
||||||
{
|
{
|
||||||
case kCOLUP0Addr:
|
case kCOLUP0Addr:
|
||||||
instance()->debugger().tiaDebug().coluP0(value);
|
instance().debugger().tiaDebug().coluP0(value);
|
||||||
myCOLUP0Color->setColor(value);
|
myCOLUP0Color->setColor(value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kCOLUP1Addr:
|
case kCOLUP1Addr:
|
||||||
instance()->debugger().tiaDebug().coluP1(value);
|
instance().debugger().tiaDebug().coluP1(value);
|
||||||
myCOLUP1Color->setColor(value);
|
myCOLUP1Color->setColor(value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kCOLUPFAddr:
|
case kCOLUPFAddr:
|
||||||
instance()->debugger().tiaDebug().coluPF(value);
|
instance().debugger().tiaDebug().coluPF(value);
|
||||||
myCOLUPFColor->setColor(value);
|
myCOLUPFColor->setColor(value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kCOLUBKAddr:
|
case kCOLUBKAddr:
|
||||||
instance()->debugger().tiaDebug().coluBK(value);
|
instance().debugger().tiaDebug().coluBK(value);
|
||||||
myCOLUBKColor->setColor(value);
|
myCOLUBKColor->setColor(value);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: TiaZoomWidget.cxx,v 1.15 2008-02-06 13:45:20 stephena Exp $
|
// $Id: TiaZoomWidget.cxx,v 1.16 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -56,14 +56,11 @@ TiaZoomWidget::TiaZoomWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
myYCenter = myNumRows >> 1;
|
myYCenter = myNumRows >> 1;
|
||||||
|
|
||||||
// Create context menu for zoom levels
|
// Create context menu for zoom levels
|
||||||
myMenu = new ContextMenu(this, font);
|
|
||||||
|
|
||||||
StringList l;
|
StringList l;
|
||||||
l.push_back("2x zoom");
|
l.push_back("2x zoom");
|
||||||
l.push_back("4x zoom");
|
l.push_back("4x zoom");
|
||||||
l.push_back("8x zoom");
|
l.push_back("8x zoom");
|
||||||
|
myMenu = new ContextMenu(this, font, l);
|
||||||
myMenu->setList(l);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -107,8 +104,8 @@ void TiaZoomWidget::zoom(int level)
|
||||||
void TiaZoomWidget::recalc()
|
void TiaZoomWidget::recalc()
|
||||||
{
|
{
|
||||||
// Don't go past end of framebuffer
|
// Don't go past end of framebuffer
|
||||||
const int width = instance()->console().mediaSource().width(),
|
const int width = instance().console().mediaSource().width(),
|
||||||
height = instance()->console().mediaSource().height();
|
height = instance().console().mediaSource().height();
|
||||||
|
|
||||||
// Figure out the bounding rectangle for the current center coords
|
// Figure out the bounding rectangle for the current center coords
|
||||||
const int xoff = myNumCols >> 1,
|
const int xoff = myNumCols >> 1,
|
||||||
|
@ -140,10 +137,7 @@ void TiaZoomWidget::handleMouseDown(int x, int y, int button, int clickCount)
|
||||||
{
|
{
|
||||||
// Grab right mouse button for zoom context menu
|
// Grab right mouse button for zoom context menu
|
||||||
if(button == 2)
|
if(button == 2)
|
||||||
{
|
myMenu->show(x + getAbsX(), y + getAbsY());
|
||||||
myMenu->setPos(x + getAbsX(), y + getAbsY());
|
|
||||||
myMenu->show();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -222,16 +216,16 @@ void TiaZoomWidget::handleCommand(CommandSender* sender, int cmd, int data, int
|
||||||
void TiaZoomWidget::drawWidget(bool hilite)
|
void TiaZoomWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "TiaZoomWidget::drawWidget\n";
|
//cerr << "TiaZoomWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
FBSurface& s = dialog().surface();
|
||||||
|
|
||||||
fb.fillRect(_x+1, _y+1, _w-2, _h-2, kBGColor);
|
s.fillRect(_x+1, _y+1, _w-2, _h-2, kBGColor);
|
||||||
fb.box(_x, _y, _w, _h, kColor, kShadowColor);
|
s.box(_x, _y, _w, _h, kColor, kShadowColor);
|
||||||
|
|
||||||
// Draw the zoomed image
|
// Draw the zoomed image
|
||||||
// This probably isn't as efficient as it can be, but it's a small area
|
// This probably isn't as efficient as it can be, but it's a small area
|
||||||
// and I don't have time to make it faster :)
|
// and I don't have time to make it faster :)
|
||||||
uInt8* currentFrame = instance()->console().mediaSource().currentFrameBuffer();
|
uInt8* currentFrame = instance().console().mediaSource().currentFrameBuffer();
|
||||||
const int pitch = instance()->console().mediaSource().width(),
|
const int pitch = instance().console().mediaSource().width(),
|
||||||
width = myZoomLevel << 1,
|
width = myZoomLevel << 1,
|
||||||
height = myZoomLevel;
|
height = myZoomLevel;
|
||||||
|
|
||||||
|
@ -240,7 +234,7 @@ void TiaZoomWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
for(x = myXoff, col = 0; x < myNumCols+myXoff; ++x, col += width)
|
for(x = myXoff, col = 0; x < myNumCols+myXoff; ++x, col += width)
|
||||||
{
|
{
|
||||||
fb.fillRect(_x + col + 2, _y + row + 2, width, height,
|
s.fillRect(_x + col + 2, _y + row + 2, width, height,
|
||||||
currentFrame[y*pitch + x]);
|
currentFrame[y*pitch + x]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ToggleBitWidget.cxx,v 1.8 2008-02-06 13:45:20 stephena Exp $
|
// $Id: ToggleBitWidget.cxx,v 1.9 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -74,17 +74,17 @@ void ToggleBitWidget::setState(const BoolArray& state, const BoolArray& changed)
|
||||||
void ToggleBitWidget::drawWidget(bool hilite)
|
void ToggleBitWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "ToggleBitWidget::drawWidget\n";
|
//cerr << "ToggleBitWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
FBSurface& s = dialog().surface();
|
||||||
int row, col;
|
int row, col;
|
||||||
string buffer;
|
string buffer;
|
||||||
|
|
||||||
// Draw the internal grid and labels
|
// Draw the internal grid and labels
|
||||||
int linewidth = _cols * _colWidth;
|
int linewidth = _cols * _colWidth;
|
||||||
for (row = 0; row <= _rows; row++)
|
for (row = 0; row <= _rows; row++)
|
||||||
fb.hLine(_x, _y + (row * _rowHeight), _x + linewidth, kColor);
|
s.hLine(_x, _y + (row * _rowHeight), _x + linewidth, kColor);
|
||||||
int lineheight = _rows * _rowHeight;
|
int lineheight = _rows * _rowHeight;
|
||||||
for (col = 0; col <= _cols; col++)
|
for (col = 0; col <= _cols; col++)
|
||||||
fb.vLine(_x + (col * _colWidth), _y, _y + lineheight, kColor);
|
s.vLine(_x + (col * _colWidth), _y, _y + lineheight, kColor);
|
||||||
|
|
||||||
// Draw the list items
|
// Draw the list items
|
||||||
for (row = 0; row < _rows; row++)
|
for (row = 0; row < _rows; row++)
|
||||||
|
@ -97,7 +97,7 @@ void ToggleBitWidget::drawWidget(bool hilite)
|
||||||
|
|
||||||
// Draw the selected item inverted, on a highlighted background.
|
// Draw the selected item inverted, on a highlighted background.
|
||||||
if (_currentRow == row && _currentCol == col && _hasFocus)
|
if (_currentRow == row && _currentCol == col && _hasFocus)
|
||||||
fb.fillRect(x - 4, y - 2, _colWidth+1, _rowHeight+1, kTextColorHi);
|
s.fillRect(x - 4, y - 2, _colWidth+1, _rowHeight+1, kTextColorHi);
|
||||||
|
|
||||||
if(_stateList[pos])
|
if(_stateList[pos])
|
||||||
buffer = _onList[pos];
|
buffer = _onList[pos];
|
||||||
|
@ -107,11 +107,11 @@ void ToggleBitWidget::drawWidget(bool hilite)
|
||||||
// Highlight changes
|
// Highlight changes
|
||||||
if(_changedList[pos])
|
if(_changedList[pos])
|
||||||
{
|
{
|
||||||
fb.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kDbgChangedColor);
|
s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kDbgChangedColor);
|
||||||
fb.drawString(_font, buffer, x, y, _colWidth, kDbgChangedTextColor);
|
s.drawString(_font, buffer, x, y, _colWidth, kDbgChangedTextColor);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
fb.drawString(_font, buffer, x, y, _colWidth, kTextColor);
|
s.drawString(_font, buffer, x, y, _colWidth, kTextColor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: TogglePixelWidget.cxx,v 1.7 2008-02-06 13:45:20 stephena Exp $
|
// $Id: TogglePixelWidget.cxx,v 1.8 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -115,16 +115,16 @@ int TogglePixelWidget::getIntState()
|
||||||
void TogglePixelWidget::drawWidget(bool hilite)
|
void TogglePixelWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "TogglePixelWidget::drawWidget\n";
|
//cerr << "TogglePixelWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
FBSurface& s = dialog().surface();
|
||||||
int row, col;
|
int row, col;
|
||||||
|
|
||||||
// Draw the internal grid and labels
|
// Draw the internal grid and labels
|
||||||
int linewidth = _cols * _colWidth;
|
int linewidth = _cols * _colWidth;
|
||||||
for (row = 0; row <= _rows; row++)
|
for (row = 0; row <= _rows; row++)
|
||||||
fb.hLine(_x, _y + (row * _rowHeight), _x + linewidth, kColor);
|
s.hLine(_x, _y + (row * _rowHeight), _x + linewidth, kColor);
|
||||||
int lineheight = _rows * _rowHeight;
|
int lineheight = _rows * _rowHeight;
|
||||||
for (col = 0; col <= _cols; col++)
|
for (col = 0; col <= _cols; col++)
|
||||||
fb.vLine(_x + (col * _colWidth), _y, _y + lineheight, kColor);
|
s.vLine(_x + (col * _colWidth), _y, _y + lineheight, kColor);
|
||||||
|
|
||||||
// Draw the pixels
|
// Draw the pixels
|
||||||
for (row = 0; row < _rows; row++)
|
for (row = 0; row < _rows; row++)
|
||||||
|
@ -137,13 +137,13 @@ void TogglePixelWidget::drawWidget(bool hilite)
|
||||||
|
|
||||||
// Draw the selected item inverted, on a highlighted background.
|
// Draw the selected item inverted, on a highlighted background.
|
||||||
if (_currentRow == row && _currentCol == col && _hasFocus)
|
if (_currentRow == row && _currentCol == col && _hasFocus)
|
||||||
fb.fillRect(x - 4, y - 2, _colWidth+1, _rowHeight+1, kTextColorHi);
|
s.fillRect(x - 4, y - 2, _colWidth+1, _rowHeight+1, kTextColorHi);
|
||||||
|
|
||||||
// Either draw the pixel in given color, or erase (show background)
|
// Either draw the pixel in given color, or erase (show background)
|
||||||
if(_stateList[pos])
|
if(_stateList[pos])
|
||||||
fb.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, _pixelColor);
|
s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, _pixelColor);
|
||||||
else
|
else
|
||||||
fb.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kBGColor);
|
s.fillRect(x - 3, y - 1, _colWidth-1, _rowHeight-1, kBGColor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ToggleWidget.cxx,v 1.8 2008-05-14 18:04:58 stephena Exp $
|
// $Id: ToggleWidget.cxx,v 1.9 2008-06-13 13:14:50 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -99,8 +99,8 @@ int ToggleWidget::findItem(int x, int y)
|
||||||
bool ToggleWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
bool ToggleWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
{
|
{
|
||||||
// Ignore all mod keys
|
// Ignore all mod keys
|
||||||
if(instance()->eventHandler().kbdControl(modifiers) ||
|
if(instance().eventHandler().kbdControl(modifiers) ||
|
||||||
instance()->eventHandler().kbdAlt(modifiers))
|
instance().eventHandler().kbdAlt(modifiers))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
bool handled = true;
|
bool handled = true;
|
||||||
|
|
|
@ -13,7 +13,6 @@ MODULE_OBJS := \
|
||||||
src/debugger/gui/TiaOutputWidget.o \
|
src/debugger/gui/TiaOutputWidget.o \
|
||||||
src/debugger/gui/TiaZoomWidget.o \
|
src/debugger/gui/TiaZoomWidget.o \
|
||||||
src/debugger/gui/ColorWidget.o \
|
src/debugger/gui/ColorWidget.o \
|
||||||
src/debugger/gui/ContextMenu.o \
|
|
||||||
src/debugger/gui/DataGridOpsWidget.o \
|
src/debugger/gui/DataGridOpsWidget.o \
|
||||||
src/debugger/gui/DataGridWidget.o \
|
src/debugger/gui/DataGridWidget.o \
|
||||||
src/debugger/gui/DebuggerDialog.o \
|
src/debugger/gui/DebuggerDialog.o \
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: EventHandler.cxx,v 1.225 2008-05-30 19:07:55 stephena Exp $
|
// $Id: EventHandler.cxx,v 1.226 2008-06-13 13:14:50 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
@ -769,7 +769,6 @@ void EventHandler::handleMouseMotionEvent(SDL_Event& event)
|
||||||
else if(myOverlay)
|
else if(myOverlay)
|
||||||
{
|
{
|
||||||
int x = event.motion.x, y = event.motion.y;
|
int x = event.motion.x, y = event.motion.y;
|
||||||
myOSystem->frameBuffer().translateCoords(x, y);
|
|
||||||
myOverlay->handleMouseMotionEvent(x, y, 0);
|
myOverlay->handleMouseMotionEvent(x, y, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -784,7 +783,6 @@ void EventHandler::handleMouseButtonEvent(SDL_Event& event, int state)
|
||||||
{
|
{
|
||||||
// Take window zooming into account
|
// Take window zooming into account
|
||||||
Int32 x = event.button.x, y = event.button.y;
|
Int32 x = event.button.x, y = event.button.y;
|
||||||
myOSystem->frameBuffer().translateCoords(x, y);
|
|
||||||
MouseButton button;
|
MouseButton button;
|
||||||
|
|
||||||
switch(event.button.button)
|
switch(event.button.button)
|
||||||
|
@ -1913,6 +1911,7 @@ void EventHandler::leaveDebugMode()
|
||||||
void EventHandler::setEventState(State state)
|
void EventHandler::setEventState(State state)
|
||||||
{
|
{
|
||||||
myState = state;
|
myState = state;
|
||||||
|
|
||||||
switch(myState)
|
switch(myState)
|
||||||
{
|
{
|
||||||
case S_EMULATE:
|
case S_EMULATE:
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBuffer.cxx,v 1.132 2008-05-30 19:07:55 stephena Exp $
|
// $Id: FrameBuffer.cxx,v 1.133 2008-06-13 13:14:50 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
@ -117,9 +117,6 @@ bool FrameBuffer::initialize(const string& title, uInt32 width, uInt32 height)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBuffer::update()
|
void FrameBuffer::update()
|
||||||
{
|
{
|
||||||
// Do any pre-frame stuff
|
|
||||||
preFrameUpdate();
|
|
||||||
|
|
||||||
// Determine which mode we are in (from the EventHandler)
|
// Determine which mode we are in (from the EventHandler)
|
||||||
// Take care of S_EMULATE mode here, otherwise let the GUI
|
// Take care of S_EMULATE mode here, otherwise let the GUI
|
||||||
// figure out what to draw
|
// figure out what to draw
|
||||||
|
@ -135,6 +132,7 @@ void FrameBuffer::update()
|
||||||
// And update the screen
|
// And update the screen
|
||||||
drawMediaSource();
|
drawMediaSource();
|
||||||
|
|
||||||
|
#if 0
|
||||||
// Show frame statistics
|
// Show frame statistics
|
||||||
if(myFrameStatsEnabled)
|
if(myFrameStatsEnabled)
|
||||||
{
|
{
|
||||||
|
@ -146,7 +144,7 @@ void FrameBuffer::update()
|
||||||
fillRect(3, 3, 95, 9, kBGColor);
|
fillRect(3, 3, 95, 9, kBGColor);
|
||||||
drawString(&myOSystem->font(), msg, 3, 3, 95, kBtnTextColor, kTextAlignCenter);
|
drawString(&myOSystem->font(), msg, 3, 3, 95, kBtnTextColor, kTextAlignCenter);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
break; // S_EMULATE
|
break; // S_EMULATE
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -208,9 +206,6 @@ void FrameBuffer::update()
|
||||||
if(myMessage.counter > 0)
|
if(myMessage.counter > 0)
|
||||||
drawMessage();
|
drawMessage();
|
||||||
|
|
||||||
// Do any post-frame stuff
|
|
||||||
postFrameUpdate();
|
|
||||||
|
|
||||||
// The frame doesn't need to be completely redrawn anymore
|
// The frame doesn't need to be completely redrawn anymore
|
||||||
theRedrawTIAIndicator = false;
|
theRedrawTIAIndicator = false;
|
||||||
}
|
}
|
||||||
|
@ -321,6 +316,7 @@ void FrameBuffer::enableMessages(bool enable)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
inline void FrameBuffer::drawMessage()
|
inline void FrameBuffer::drawMessage()
|
||||||
{
|
{
|
||||||
|
#if 0
|
||||||
// Draw the bounded box and text
|
// Draw the bounded box and text
|
||||||
fillRect(myMessage.x+1, myMessage.y+2, myMessage.w-2, myMessage.h-4, kBGColor);
|
fillRect(myMessage.x+1, myMessage.y+2, myMessage.w-2, myMessage.h-4, kBGColor);
|
||||||
box(myMessage.x, myMessage.y+1, myMessage.w, myMessage.h-2, kColor, kShadowColor);
|
box(myMessage.x, myMessage.y+1, myMessage.w, myMessage.h-2, kColor, kShadowColor);
|
||||||
|
@ -334,6 +330,7 @@ inline void FrameBuffer::drawMessage()
|
||||||
myOSystem->eventHandler().refreshDisplay(true);
|
myOSystem->eventHandler().refreshDisplay(true);
|
||||||
else
|
else
|
||||||
addDirtyRect(myMessage.x, myMessage.y, myMessage.w, myMessage.h);
|
addDirtyRect(myMessage.x, myMessage.y, myMessage.w, myMessage.h);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -459,8 +456,8 @@ bool FrameBuffer::changeVidMode(int direction)
|
||||||
|
|
||||||
if(inTIAMode)
|
if(inTIAMode)
|
||||||
myOSystem->settings().setInt("zoom_tia", newmode.zoom);
|
myOSystem->settings().setInt("zoom_tia", newmode.zoom);
|
||||||
else
|
//FIXME else
|
||||||
myOSystem->settings().setInt("zoom_ui", newmode.zoom);
|
// myOSystem->settings().setInt("zoom_ui", newmode.zoom);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -588,133 +585,6 @@ void FrameBuffer::setWindowIcon()
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBuffer::box(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
|
||||||
int colorA, int colorB)
|
|
||||||
{
|
|
||||||
hLine(x + 1, y, x + w - 2, colorA);
|
|
||||||
hLine(x, y + 1, x + w - 1, colorA);
|
|
||||||
vLine(x, y + 1, y + h - 2, colorA);
|
|
||||||
vLine(x + 1, y, y + h - 1, colorA);
|
|
||||||
|
|
||||||
hLine(x + 1, y + h - 2, x + w - 1, colorB);
|
|
||||||
hLine(x + 1, y + h - 1, x + w - 2, colorB);
|
|
||||||
vLine(x + w - 1, y + 1, y + h - 2, colorB);
|
|
||||||
vLine(x + w - 2, y + 1, y + h - 1, colorB);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBuffer::frameRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
|
||||||
int color, FrameStyle style)
|
|
||||||
{
|
|
||||||
switch(style)
|
|
||||||
{
|
|
||||||
case kSolidLine:
|
|
||||||
hLine(x, y, x + w - 1, color);
|
|
||||||
hLine(x, y + h - 1, x + w - 1, color);
|
|
||||||
vLine(x, y, y + h - 1, color);
|
|
||||||
vLine(x + w - 1, y, y + h - 1, color);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case kDashLine:
|
|
||||||
unsigned int i, skip, lwidth = 1;
|
|
||||||
|
|
||||||
for(i = x, skip = 1; i < x+w-1; i=i+lwidth+1, ++skip)
|
|
||||||
{
|
|
||||||
if(skip % 2)
|
|
||||||
{
|
|
||||||
hLine(i, y, i + lwidth, color);
|
|
||||||
hLine(i, y + h - 1, i + lwidth, color);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for(i = y, skip = 1; i < y+h-1; i=i+lwidth+1, ++skip)
|
|
||||||
{
|
|
||||||
if(skip % 2)
|
|
||||||
{
|
|
||||||
vLine(x, i, i + lwidth, color);
|
|
||||||
vLine(x + w - 1, i, i + lwidth, color);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void FrameBuffer::drawString(const GUI::Font* font, const string& s,
|
|
||||||
int x, int y, int w,
|
|
||||||
int color, TextAlignment align,
|
|
||||||
int deltax, bool useEllipsis)
|
|
||||||
{
|
|
||||||
const int leftX = x, rightX = x + w;
|
|
||||||
unsigned int i;
|
|
||||||
int width = font->getStringWidth(s);
|
|
||||||
string str;
|
|
||||||
|
|
||||||
if(useEllipsis && width > w)
|
|
||||||
{
|
|
||||||
// String is too wide. So we shorten it "intelligently", by replacing
|
|
||||||
// parts of it by an ellipsis ("..."). There are three possibilities
|
|
||||||
// for this: replace the start, the end, or the middle of the string.
|
|
||||||
// What is best really depends on the context; but unless we want to
|
|
||||||
// make this configurable, replacing the middle probably is a good
|
|
||||||
// compromise.
|
|
||||||
const int ellipsisWidth = font->getStringWidth("...");
|
|
||||||
|
|
||||||
// SLOW algorithm to remove enough of the middle. But it is good enough for now.
|
|
||||||
const int halfWidth = (w - ellipsisWidth) / 2;
|
|
||||||
int w2 = 0;
|
|
||||||
|
|
||||||
for(i = 0; i < s.size(); ++i)
|
|
||||||
{
|
|
||||||
int charWidth = font->getCharWidth(s[i]);
|
|
||||||
if(w2 + charWidth > halfWidth)
|
|
||||||
break;
|
|
||||||
|
|
||||||
w2 += charWidth;
|
|
||||||
str += s[i];
|
|
||||||
}
|
|
||||||
|
|
||||||
// At this point we know that the first 'i' chars are together 'w2'
|
|
||||||
// pixels wide. We took the first i-1, and add "..." to them.
|
|
||||||
str += "...";
|
|
||||||
|
|
||||||
// The original string is width wide. Of those we already skipped past
|
|
||||||
// w2 pixels, which means (width - w2) remain.
|
|
||||||
// The new str is (w2+ellipsisWidth) wide, so we can accomodate about
|
|
||||||
// (w - (w2+ellipsisWidth)) more pixels.
|
|
||||||
// Thus we skip ((width - w2) - (w - (w2+ellipsisWidth))) =
|
|
||||||
// (width + ellipsisWidth - w)
|
|
||||||
int skip = width + ellipsisWidth - w;
|
|
||||||
for(; i < s.size() && skip > 0; ++i)
|
|
||||||
skip -= font->getCharWidth(s[i]);
|
|
||||||
|
|
||||||
// Append the remaining chars, if any
|
|
||||||
for(; i < s.size(); ++i)
|
|
||||||
str += s[i];
|
|
||||||
|
|
||||||
width = font->getStringWidth(str);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
str = s;
|
|
||||||
|
|
||||||
if(align == kTextAlignCenter)
|
|
||||||
x = x + (w - width - 1)/2;
|
|
||||||
else if(align == kTextAlignRight)
|
|
||||||
x = x + w - width;
|
|
||||||
|
|
||||||
x += deltax;
|
|
||||||
for(i = 0; i < str.size(); ++i)
|
|
||||||
{
|
|
||||||
w = font->getCharWidth(str[i]);
|
|
||||||
if(x+w > rightX)
|
|
||||||
break;
|
|
||||||
if(x >= leftX)
|
|
||||||
drawChar(font, str[i], x, y, color);
|
|
||||||
|
|
||||||
x += w;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
uInt8 FrameBuffer::getPhosphor(uInt8 c1, uInt8 c2)
|
uInt8 FrameBuffer::getPhosphor(uInt8 c1, uInt8 c2)
|
||||||
{
|
{
|
||||||
|
@ -851,8 +721,8 @@ VideoMode FrameBuffer::getSavedVidMode()
|
||||||
state == EventHandler::S_PAUSE ||
|
state == EventHandler::S_PAUSE ||
|
||||||
state == EventHandler::S_MENU ||
|
state == EventHandler::S_MENU ||
|
||||||
state == EventHandler::S_CMDMENU);
|
state == EventHandler::S_CMDMENU);
|
||||||
int zoom = (inTIAMode ? myOSystem->settings().getInt("zoom_tia") :
|
int zoom = (inTIAMode ? myOSystem->settings().getInt("zoom_tia") : 1);
|
||||||
myOSystem->settings().getInt("zoom_ui") );
|
//FIXME myOSystem->settings().getInt("zoom_ui") );
|
||||||
|
|
||||||
myCurrentModeList = &myWindowedModeList;
|
myCurrentModeList = &myWindowedModeList;
|
||||||
myCurrentModeList->setByZoom(zoom);
|
myCurrentModeList->setByZoom(zoom);
|
||||||
|
@ -860,3 +730,130 @@ VideoMode FrameBuffer::getSavedVidMode()
|
||||||
|
|
||||||
return myCurrentModeList->current();
|
return myCurrentModeList->current();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurface::box(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
|
int colorA, int colorB)
|
||||||
|
{
|
||||||
|
hLine(x + 1, y, x + w - 2, colorA);
|
||||||
|
hLine(x, y + 1, x + w - 1, colorA);
|
||||||
|
vLine(x, y + 1, y + h - 2, colorA);
|
||||||
|
vLine(x + 1, y, y + h - 1, colorA);
|
||||||
|
|
||||||
|
hLine(x + 1, y + h - 2, x + w - 1, colorB);
|
||||||
|
hLine(x + 1, y + h - 1, x + w - 2, colorB);
|
||||||
|
vLine(x + w - 1, y + 1, y + h - 2, colorB);
|
||||||
|
vLine(x + w - 2, y + 1, y + h - 1, colorB);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurface::frameRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
|
int color, FrameStyle style)
|
||||||
|
{
|
||||||
|
switch(style)
|
||||||
|
{
|
||||||
|
case kSolidLine:
|
||||||
|
hLine(x, y, x + w - 1, color);
|
||||||
|
hLine(x, y + h - 1, x + w - 1, color);
|
||||||
|
vLine(x, y, y + h - 1, color);
|
||||||
|
vLine(x + w - 1, y, y + h - 1, color);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case kDashLine:
|
||||||
|
unsigned int i, skip, lwidth = 1;
|
||||||
|
|
||||||
|
for(i = x, skip = 1; i < x+w-1; i=i+lwidth+1, ++skip)
|
||||||
|
{
|
||||||
|
if(skip % 2)
|
||||||
|
{
|
||||||
|
hLine(i, y, i + lwidth, color);
|
||||||
|
hLine(i, y + h - 1, i + lwidth, color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for(i = y, skip = 1; i < y+h-1; i=i+lwidth+1, ++skip)
|
||||||
|
{
|
||||||
|
if(skip % 2)
|
||||||
|
{
|
||||||
|
vLine(x, i, i + lwidth, color);
|
||||||
|
vLine(x + w - 1, i, i + lwidth, color);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void FBSurface::drawString(const GUI::Font* font, const string& s,
|
||||||
|
int x, int y, int w,
|
||||||
|
int color, TextAlignment align,
|
||||||
|
int deltax, bool useEllipsis)
|
||||||
|
{
|
||||||
|
const int leftX = x, rightX = x + w;
|
||||||
|
unsigned int i;
|
||||||
|
int width = font->getStringWidth(s);
|
||||||
|
string str;
|
||||||
|
|
||||||
|
if(useEllipsis && width > w)
|
||||||
|
{
|
||||||
|
// String is too wide. So we shorten it "intelligently", by replacing
|
||||||
|
// parts of it by an ellipsis ("..."). There are three possibilities
|
||||||
|
// for this: replace the start, the end, or the middle of the string.
|
||||||
|
// What is best really depends on the context; but unless we want to
|
||||||
|
// make this configurable, replacing the middle probably is a good
|
||||||
|
// compromise.
|
||||||
|
const int ellipsisWidth = font->getStringWidth("...");
|
||||||
|
|
||||||
|
// SLOW algorithm to remove enough of the middle. But it is good enough for now.
|
||||||
|
const int halfWidth = (w - ellipsisWidth) / 2;
|
||||||
|
int w2 = 0;
|
||||||
|
|
||||||
|
for(i = 0; i < s.size(); ++i)
|
||||||
|
{
|
||||||
|
int charWidth = font->getCharWidth(s[i]);
|
||||||
|
if(w2 + charWidth > halfWidth)
|
||||||
|
break;
|
||||||
|
|
||||||
|
w2 += charWidth;
|
||||||
|
str += s[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
// At this point we know that the first 'i' chars are together 'w2'
|
||||||
|
// pixels wide. We took the first i-1, and add "..." to them.
|
||||||
|
str += "...";
|
||||||
|
|
||||||
|
// The original string is width wide. Of those we already skipped past
|
||||||
|
// w2 pixels, which means (width - w2) remain.
|
||||||
|
// The new str is (w2+ellipsisWidth) wide, so we can accomodate about
|
||||||
|
// (w - (w2+ellipsisWidth)) more pixels.
|
||||||
|
// Thus we skip ((width - w2) - (w - (w2+ellipsisWidth))) =
|
||||||
|
// (width + ellipsisWidth - w)
|
||||||
|
int skip = width + ellipsisWidth - w;
|
||||||
|
for(; i < s.size() && skip > 0; ++i)
|
||||||
|
skip -= font->getCharWidth(s[i]);
|
||||||
|
|
||||||
|
// Append the remaining chars, if any
|
||||||
|
for(; i < s.size(); ++i)
|
||||||
|
str += s[i];
|
||||||
|
|
||||||
|
width = font->getStringWidth(str);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
str = s;
|
||||||
|
|
||||||
|
if(align == kTextAlignCenter)
|
||||||
|
x = x + (w - width - 1)/2;
|
||||||
|
else if(align == kTextAlignRight)
|
||||||
|
x = x + w - width;
|
||||||
|
|
||||||
|
x += deltax;
|
||||||
|
for(i = 0; i < str.size(); ++i)
|
||||||
|
{
|
||||||
|
w = font->getCharWidth(str[i]);
|
||||||
|
if(x+w > rightX)
|
||||||
|
break;
|
||||||
|
if(x >= leftX)
|
||||||
|
drawChar(font, str[i], x, y, color);
|
||||||
|
|
||||||
|
x += w;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBuffer.hxx,v 1.96 2008-05-30 19:07:55 stephena Exp $
|
// $Id: FrameBuffer.hxx,v 1.97 2008-06-13 13:14:51 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_HXX
|
#ifndef FRAMEBUFFER_HXX
|
||||||
|
@ -21,6 +21,7 @@
|
||||||
|
|
||||||
#include <SDL.h>
|
#include <SDL.h>
|
||||||
|
|
||||||
|
class FBSurface;
|
||||||
class OSystem;
|
class OSystem;
|
||||||
class Console;
|
class Console;
|
||||||
|
|
||||||
|
@ -33,20 +34,6 @@ namespace GUI {
|
||||||
#include "VideoModeList.hxx"
|
#include "VideoModeList.hxx"
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
|
||||||
|
|
||||||
// Text alignment modes for drawString()
|
|
||||||
enum TextAlignment {
|
|
||||||
kTextAlignLeft,
|
|
||||||
kTextAlignCenter,
|
|
||||||
kTextAlignRight
|
|
||||||
};
|
|
||||||
|
|
||||||
// Line types for drawing rectangular frames
|
|
||||||
enum FrameStyle {
|
|
||||||
kSolidLine,
|
|
||||||
kDashLine
|
|
||||||
};
|
|
||||||
|
|
||||||
// Different types of framebuffer derived objects
|
// Different types of framebuffer derived objects
|
||||||
enum BufferType {
|
enum BufferType {
|
||||||
kSoftBuffer,
|
kSoftBuffer,
|
||||||
|
@ -98,10 +85,11 @@ enum {
|
||||||
display in Stella. All graphics ports should derive from this class for
|
display in Stella. All graphics ports should derive from this class for
|
||||||
platform-specific video stuff.
|
platform-specific video stuff.
|
||||||
|
|
||||||
All GUI elements (ala ScummVM) are drawn here as well.
|
All GUI elements (ala ScummVM) are drawn into FBSurfaces, which are in
|
||||||
|
turn drawn here as well.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBuffer.hxx,v 1.96 2008-05-30 19:07:55 stephena Exp $
|
@version $Id: FrameBuffer.hxx,v 1.97 2008-06-13 13:14:51 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBuffer
|
class FrameBuffer
|
||||||
{
|
{
|
||||||
|
@ -125,8 +113,6 @@ class FrameBuffer
|
||||||
@param title The title of the window
|
@param title The title of the window
|
||||||
@param width The width of the framebuffer
|
@param width The width of the framebuffer
|
||||||
@param height The height of the framebuffer
|
@param height The height of the framebuffer
|
||||||
|
|
||||||
@return False on any errors, else true
|
|
||||||
*/
|
*/
|
||||||
bool initialize(const string& title, uInt32 width, uInt32 height);
|
bool initialize(const string& title, uInt32 width, uInt32 height);
|
||||||
|
|
||||||
|
@ -263,51 +249,6 @@ class FrameBuffer
|
||||||
*/
|
*/
|
||||||
virtual void setUIPalette(const uInt32* palette);
|
virtual void setUIPalette(const uInt32* palette);
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw a rectangular box with sides
|
|
||||||
at the specified coordinates.
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the box
|
|
||||||
@param h The height of the box
|
|
||||||
@param colorA Lighter color for outside line.
|
|
||||||
@param colorB Darker color for inside line.
|
|
||||||
*/
|
|
||||||
void box(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
|
||||||
int colorA, int colorB);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw a framed rectangle.
|
|
||||||
I'm not exactly sure what it is, so I can't explain it :)
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the area
|
|
||||||
@param h The height of the area
|
|
||||||
@param color The color of the surrounding frame
|
|
||||||
*/
|
|
||||||
void frameRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
|
||||||
int color, FrameStyle style = kSolidLine);
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw the specified string.
|
|
||||||
|
|
||||||
@param font The font to draw the string with
|
|
||||||
@param str The string to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the string area
|
|
||||||
@param h The height of the string area
|
|
||||||
@param color The color of the text
|
|
||||||
@param align The alignment of the text in the string width area
|
|
||||||
@param deltax
|
|
||||||
@param useEllipsis Whether to use '...' when the string is too long
|
|
||||||
*/
|
|
||||||
void drawString(const GUI::Font* font, const string& str, int x, int y, int w,
|
|
||||||
int color, TextAlignment align = kTextAlignLeft,
|
|
||||||
int deltax = 0, bool useEllipsis = true);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Informs the Framebuffer of a change in EventHandler state.
|
Informs the Framebuffer of a change in EventHandler state.
|
||||||
*/
|
*/
|
||||||
|
@ -318,111 +259,6 @@ class FrameBuffer
|
||||||
// in derived classes.
|
// in derived classes.
|
||||||
//////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////
|
||||||
public:
|
public:
|
||||||
/**
|
|
||||||
This method is called to get the specified scanline data.
|
|
||||||
|
|
||||||
@param row The row we are looking for
|
|
||||||
@param data The actual pixel data (in bytes)
|
|
||||||
*/
|
|
||||||
virtual void scanline(uInt32 row, uInt8* data) const = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw a horizontal line.
|
|
||||||
|
|
||||||
@param x The first x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param x2 The second x coordinate
|
|
||||||
@param color The color of the line
|
|
||||||
*/
|
|
||||||
virtual void hLine(uInt32 x, uInt32 y, uInt32 x2, int color) = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw a vertical line.
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The first y coordinate
|
|
||||||
@param y2 The second y coordinate
|
|
||||||
@param color The color of the line
|
|
||||||
*/
|
|
||||||
virtual void vLine(uInt32 x, uInt32 y, uInt32 y2, int color) = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw a filled rectangle.
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the area
|
|
||||||
@param h The height of the area
|
|
||||||
@param color The color of the area
|
|
||||||
*/
|
|
||||||
virtual void fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
|
||||||
int color) = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw the specified character.
|
|
||||||
|
|
||||||
@param font The font to use to draw the character
|
|
||||||
@param c The character to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param color The color of the character
|
|
||||||
*/
|
|
||||||
virtual void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y,
|
|
||||||
int color) = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw the bitmap image.
|
|
||||||
|
|
||||||
@param bitmap The data to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param color The color of the character
|
|
||||||
@param h The height of the data image
|
|
||||||
*/
|
|
||||||
virtual void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, int color,
|
|
||||||
Int32 h = 8) = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to draw an SDL surface.
|
|
||||||
|
|
||||||
@param surface The data to draw
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
*/
|
|
||||||
virtual void drawSurface(const GUI::Surface* surface, Int32 x, Int32 y) = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to convert and copy a given row of RGB
|
|
||||||
data into an SDL surface.
|
|
||||||
|
|
||||||
@param surface The data to draw
|
|
||||||
@param row The row of the surface the data should be placed in
|
|
||||||
@param data The data in uInt8 R/G/B format
|
|
||||||
@param rowbytes The number of bytes in row of 'data'
|
|
||||||
*/
|
|
||||||
virtual void bytesToSurface(GUI::Surface* surface, int row,
|
|
||||||
uInt8* data, int rowbytes) const = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to translate the given coordinates
|
|
||||||
to their unzoomed/unscaled equivalents.
|
|
||||||
|
|
||||||
@param x X coordinate to translate
|
|
||||||
@param y Y coordinate to translate
|
|
||||||
*/
|
|
||||||
virtual void translateCoords(Int32& x, Int32& y) const = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method should be called to add a dirty rectangle
|
|
||||||
(ie, an area of the screen that has changed)
|
|
||||||
|
|
||||||
@param x The x coordinate
|
|
||||||
@param y The y coordinate
|
|
||||||
@param w The width of the area
|
|
||||||
@param h The height of the area
|
|
||||||
*/
|
|
||||||
virtual void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h) = 0;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Enable/disable phosphor effect.
|
Enable/disable phosphor effect.
|
||||||
*/
|
*/
|
||||||
|
@ -437,20 +273,29 @@ class FrameBuffer
|
||||||
*/
|
*/
|
||||||
virtual Uint32 mapRGB(Uint8 r, Uint8 g, Uint8 b) const = 0;
|
virtual Uint32 mapRGB(Uint8 r, Uint8 g, Uint8 b) const = 0;
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called to create a surface compatible with the one
|
|
||||||
currently in use, but having the given dimensions.
|
|
||||||
|
|
||||||
@param width The requested width of the new surface.
|
|
||||||
@param height The requested height of the new surface.
|
|
||||||
*/
|
|
||||||
virtual GUI::Surface* createSurface(int width, int height) const = 0;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to query the type of the FrameBuffer.
|
This method is called to query the type of the FrameBuffer.
|
||||||
*/
|
*/
|
||||||
virtual BufferType type() const = 0;
|
virtual BufferType type() const = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method is called to create a surface compatible with the one
|
||||||
|
currently in use, but having the given dimensions.
|
||||||
|
|
||||||
|
@param w The requested width of the new surface.
|
||||||
|
@param h The requested height of the new surface.
|
||||||
|
@param useBase Use the base surface instead of creating a new one
|
||||||
|
*/
|
||||||
|
virtual FBSurface* createSurface(int w, int h, bool useBase = false) const = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method is called to get the specified scanline data.
|
||||||
|
|
||||||
|
@param row The row we are looking for
|
||||||
|
@param data The actual pixel data (in bytes)
|
||||||
|
*/
|
||||||
|
virtual void scanline(uInt32 row, uInt8* data) const = 0;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/**
|
/**
|
||||||
This method is called to initialize the video subsystem
|
This method is called to initialize the video subsystem
|
||||||
|
@ -476,16 +321,6 @@ class FrameBuffer
|
||||||
*/
|
*/
|
||||||
virtual void drawMediaSource() = 0;
|
virtual void drawMediaSource() = 0;
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called before any drawing is done (per-frame).
|
|
||||||
*/
|
|
||||||
virtual void preFrameUpdate() = 0;
|
|
||||||
|
|
||||||
/**
|
|
||||||
This method is called after any drawing is done (per-frame).
|
|
||||||
*/
|
|
||||||
virtual void postFrameUpdate() = 0;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
This method is called to provide information about the FrameBuffer.
|
This method is called to provide information about the FrameBuffer.
|
||||||
*/
|
*/
|
||||||
|
@ -495,6 +330,21 @@ class FrameBuffer
|
||||||
// The parent system for the framebuffer
|
// The parent system for the framebuffer
|
||||||
OSystem* myOSystem;
|
OSystem* myOSystem;
|
||||||
|
|
||||||
|
// The SDL video buffer
|
||||||
|
SDL_Surface* myScreen;
|
||||||
|
|
||||||
|
// SDL initialization flags
|
||||||
|
uInt32 mySDLFlags;
|
||||||
|
|
||||||
|
// Indicates if the TIA area should be redrawn
|
||||||
|
bool theRedrawTIAIndicator;
|
||||||
|
|
||||||
|
// Use phosphor effect (aka no flicker on 30Hz screens)
|
||||||
|
bool myUsePhosphor;
|
||||||
|
|
||||||
|
// Amount to blend when using phosphor effect
|
||||||
|
int myPhosphorBlend;
|
||||||
|
|
||||||
// Dimensions of the base image, before scaling.
|
// Dimensions of the base image, before scaling.
|
||||||
// All external GUI items should refer to these dimensions,
|
// All external GUI items should refer to these dimensions,
|
||||||
// since this is the *real* size of the image.
|
// since this is the *real* size of the image.
|
||||||
|
@ -507,25 +357,10 @@ class FrameBuffer
|
||||||
// Dimensions of the SDL window (not always the same as the image)
|
// Dimensions of the SDL window (not always the same as the image)
|
||||||
SDL_Rect myScreenDim;
|
SDL_Rect myScreenDim;
|
||||||
|
|
||||||
// The SDL video buffer
|
|
||||||
SDL_Surface* myScreen;
|
|
||||||
|
|
||||||
// SDL initialization flags
|
|
||||||
uInt32 mySDLFlags;
|
|
||||||
|
|
||||||
// TIA palettes for normal and phosphor modes
|
// TIA palettes for normal and phosphor modes
|
||||||
Uint32 myDefPalette[256+kNumColors];
|
Uint32 myDefPalette[256+kNumColors];
|
||||||
Uint32 myAvgPalette[256][256];
|
Uint32 myAvgPalette[256][256];
|
||||||
|
|
||||||
// Indicates if the TIA area should be redrawn
|
|
||||||
bool theRedrawTIAIndicator;
|
|
||||||
|
|
||||||
// Use phosphor effect (aka no flicker on 30Hz screens)
|
|
||||||
bool myUsePhosphor;
|
|
||||||
|
|
||||||
// Amount to blend when using phosphor effect
|
|
||||||
int myPhosphorBlend;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/**
|
/**
|
||||||
Set the icon for the main SDL window.
|
Set the icon for the main SDL window.
|
||||||
|
@ -593,4 +428,209 @@ class FrameBuffer
|
||||||
VideoModeList* myCurrentModeList;
|
VideoModeList* myCurrentModeList;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
This class is basically a thin wrapper around an SDL_Surface structure.
|
||||||
|
We do it this way so the SDL stuff won't be dragged into the depths of
|
||||||
|
the codebase. All drawing is done into FBSurfaces, which are then
|
||||||
|
drawn into the FrameBuffer. Each FrameBuffer-derived class is
|
||||||
|
responsible for extending an FBSurface object suitable to the
|
||||||
|
FrameBuffer type.
|
||||||
|
|
||||||
|
@author Stephen Anthony
|
||||||
|
@version $Id: FrameBuffer.hxx,v 1.97 2008-06-13 13:14:51 stephena Exp $
|
||||||
|
*/
|
||||||
|
// Text alignment modes for drawString()
|
||||||
|
enum TextAlignment {
|
||||||
|
kTextAlignLeft,
|
||||||
|
kTextAlignCenter,
|
||||||
|
kTextAlignRight
|
||||||
|
};
|
||||||
|
// Line types for drawing rectangular frames
|
||||||
|
enum FrameStyle {
|
||||||
|
kSolidLine,
|
||||||
|
kDashLine
|
||||||
|
};
|
||||||
|
|
||||||
|
class FBSurface
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
/**
|
||||||
|
Creates a new FBSurface object
|
||||||
|
*/
|
||||||
|
FBSurface() { }
|
||||||
|
|
||||||
|
/**
|
||||||
|
Destructor
|
||||||
|
*/
|
||||||
|
virtual ~FBSurface() { }
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw a horizontal line.
|
||||||
|
|
||||||
|
@param x The first x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param x2 The second x coordinate
|
||||||
|
@param color The color of the line
|
||||||
|
*/
|
||||||
|
virtual void hLine(uInt32 x, uInt32 y, uInt32 x2, int color) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw a vertical line.
|
||||||
|
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The first y coordinate
|
||||||
|
@param y2 The second y coordinate
|
||||||
|
@param color The color of the line
|
||||||
|
*/
|
||||||
|
virtual void vLine(uInt32 x, uInt32 y, uInt32 y2, int color) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw a filled rectangle.
|
||||||
|
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param w The width of the area
|
||||||
|
@param h The height of the area
|
||||||
|
@param color The color of the area
|
||||||
|
*/
|
||||||
|
virtual void fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
|
int color) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw the specified character.
|
||||||
|
|
||||||
|
@param font The font to use to draw the character
|
||||||
|
@param c The character to draw
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param color The color of the character
|
||||||
|
*/
|
||||||
|
virtual void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y,
|
||||||
|
int color) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw the bitmap image.
|
||||||
|
|
||||||
|
@param bitmap The data to draw
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param color The color of the character
|
||||||
|
@param h The height of the data image
|
||||||
|
*/
|
||||||
|
virtual void drawBitmap(uInt32* bitmap, Int32 x, Int32 y, int color,
|
||||||
|
Int32 h = 8) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to add a dirty rectangle
|
||||||
|
(ie, an area of the screen that has changed)
|
||||||
|
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param w The width of the area
|
||||||
|
@param h The height of the area
|
||||||
|
*/
|
||||||
|
virtual void addDirtyRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to center the position of the surface.
|
||||||
|
*/
|
||||||
|
virtual void centerPos() = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to set the position of the surface.
|
||||||
|
*/
|
||||||
|
virtual void setPos(uInt32 x, uInt32 y) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method answers the current coordinates of the surface.
|
||||||
|
*/
|
||||||
|
virtual void getPos(uInt32& x, uInt32& y) const = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to translate the given coordinates
|
||||||
|
to the surface coordinates.
|
||||||
|
|
||||||
|
@param x X coordinate to translate
|
||||||
|
@param y Y coordinate to translate
|
||||||
|
*/
|
||||||
|
virtual void translateCoords(Int32& x, Int32& y) const = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw the surface to the screen.
|
||||||
|
*/
|
||||||
|
virtual void update() = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw a rectangular box with sides
|
||||||
|
at the specified coordinates.
|
||||||
|
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param w The width of the box
|
||||||
|
@param h The height of the box
|
||||||
|
@param colorA Lighter color for outside line.
|
||||||
|
@param colorB Darker color for inside line.
|
||||||
|
*/
|
||||||
|
void box(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
|
int colorA, int colorB);
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw a framed rectangle.
|
||||||
|
I'm not exactly sure what it is, so I can't explain it :)
|
||||||
|
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param w The width of the area
|
||||||
|
@param h The height of the area
|
||||||
|
@param color The color of the surrounding frame
|
||||||
|
*/
|
||||||
|
void frameRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
|
int color, FrameStyle style = kSolidLine);
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to draw the specified string.
|
||||||
|
|
||||||
|
@param font The font to draw the string with
|
||||||
|
@param str The string to draw
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
@param w The width of the string area
|
||||||
|
@param h The height of the string area
|
||||||
|
@param color The color of the text
|
||||||
|
@param align The alignment of the text in the string width area
|
||||||
|
@param deltax
|
||||||
|
@param useEllipsis Whether to use '...' when the string is too long
|
||||||
|
*/
|
||||||
|
void drawString(const GUI::Font* font, const string& str, int x, int y, int w,
|
||||||
|
int color, TextAlignment align = kTextAlignLeft,
|
||||||
|
int deltax = 0, bool useEllipsis = true);
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
/**
|
||||||
|
This method should be called to draw an SDL surface.
|
||||||
|
|
||||||
|
@param surface The data to draw
|
||||||
|
@param x The x coordinate
|
||||||
|
@param y The y coordinate
|
||||||
|
*/
|
||||||
|
virtual void drawSurface(const GUI::Surface* surface, Int32 x, Int32 y) = 0;
|
||||||
|
|
||||||
|
/**
|
||||||
|
This method should be called to convert and copy a given row of RGB
|
||||||
|
data into an SDL surface.
|
||||||
|
|
||||||
|
@param surface The data to draw
|
||||||
|
@param row The row of the surface the data should be placed in
|
||||||
|
@param data The data in uInt8 R/G/B format
|
||||||
|
@param rowbytes The number of bytes in row of 'data'
|
||||||
|
*/
|
||||||
|
virtual void bytesToSurface(GUI::Surface* surface, int row,
|
||||||
|
uInt8* data, int rowbytes) const = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: AboutDialog.cxx,v 1.24 2008-03-23 16:22:45 stephena Exp $
|
// $Id: AboutDialog.cxx,v 1.25 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -90,7 +90,7 @@ void AboutDialog::updateStrings(int page, int lines, string& title, string* &dsc
|
||||||
case 1:
|
case 1:
|
||||||
title = string("Stella ") + STELLA_VERSION;
|
title = string("Stella ") + STELLA_VERSION;
|
||||||
ADD_ATEXT("\\CA multi-platform Atari 2600 VCS emulator");
|
ADD_ATEXT("\\CA multi-platform Atari 2600 VCS emulator");
|
||||||
ADD_ATEXT(string("\\C\\c2") + instance()->features());
|
ADD_ATEXT(string("\\C\\c2") + instance().features());
|
||||||
ADD_ALINE;
|
ADD_ALINE;
|
||||||
ADD_ATEXT("\\CCopyright (C) 1995-2008 The Stella team");
|
ADD_ATEXT("\\CCopyright (C) 1995-2008 The Stella team");
|
||||||
ADD_ATEXT("\\Chttp://stella.sourceforge.net");
|
ADD_ATEXT("\\Chttp://stella.sourceforge.net");
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: AudioDialog.cxx,v 1.27 2008-03-23 16:22:46 stephena Exp $
|
// $Id: AudioDialog.cxx,v 1.28 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -29,6 +29,7 @@
|
||||||
#include "Menu.hxx"
|
#include "Menu.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
#include "PopUpWidget.hxx"
|
#include "PopUpWidget.hxx"
|
||||||
|
#include "StringList.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
#include "Sound.hxx"
|
#include "Sound.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
@ -49,6 +50,7 @@ AudioDialog::AudioDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
int lwidth = font.getStringWidth("Fragment Size: "),
|
int lwidth = font.getStringWidth("Fragment Size: "),
|
||||||
pwidth = font.getStringWidth("4096");
|
pwidth = font.getStringWidth("4096");
|
||||||
WidgetArray wid;
|
WidgetArray wid;
|
||||||
|
StringList items;
|
||||||
|
|
||||||
// Set real dimensions
|
// Set real dimensions
|
||||||
// _w = 35 * fontWidth + 10;
|
// _w = 35 * fontWidth + 10;
|
||||||
|
@ -70,39 +72,37 @@ AudioDialog::AudioDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// Fragment size
|
// Fragment size
|
||||||
|
items.clear();
|
||||||
|
items.push_back("128");
|
||||||
|
items.push_back("256");
|
||||||
|
items.push_back("512");
|
||||||
|
items.push_back("1024");
|
||||||
|
items.push_back("2048");
|
||||||
|
items.push_back("4096");
|
||||||
myFragsizePopup = new PopUpWidget(this, font, xpos, ypos,
|
myFragsizePopup = new PopUpWidget(this, font, xpos, ypos,
|
||||||
pwidth + myVolumeLabel->getWidth() - 4, lineHeight,
|
pwidth + myVolumeLabel->getWidth() - 4, lineHeight,
|
||||||
"Fragment size: ", lwidth);
|
items, "Fragment size: ", lwidth);
|
||||||
myFragsizePopup->appendEntry("128", 1);
|
|
||||||
myFragsizePopup->appendEntry("256", 2);
|
|
||||||
myFragsizePopup->appendEntry("512", 3);
|
|
||||||
myFragsizePopup->appendEntry("1024", 4);
|
|
||||||
myFragsizePopup->appendEntry("2048", 5);
|
|
||||||
myFragsizePopup->appendEntry("4096", 6);
|
|
||||||
wid.push_back(myFragsizePopup);
|
wid.push_back(myFragsizePopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// Output frequency
|
// Output frequency
|
||||||
|
items.clear();
|
||||||
|
items.push_back("11025");
|
||||||
|
items.push_back("22050");
|
||||||
|
items.push_back("31400");
|
||||||
|
items.push_back("44100");
|
||||||
|
items.push_back("48000");
|
||||||
myFreqPopup = new PopUpWidget(this, font, xpos, ypos,
|
myFreqPopup = new PopUpWidget(this, font, xpos, ypos,
|
||||||
pwidth + myVolumeLabel->getWidth() - 4, lineHeight,
|
pwidth + myVolumeLabel->getWidth() - 4, lineHeight,
|
||||||
"Output freq: ", lwidth);
|
items, "Output freq: ", lwidth);
|
||||||
myFreqPopup->appendEntry("11025", 1);
|
|
||||||
myFreqPopup->appendEntry("22050", 2);
|
|
||||||
myFreqPopup->appendEntry("31400", 3);
|
|
||||||
myFreqPopup->appendEntry("44100", 4);
|
|
||||||
myFreqPopup->appendEntry("48000", 5);
|
|
||||||
wid.push_back(myFreqPopup);
|
wid.push_back(myFreqPopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// TIA frequency
|
// TIA frequency
|
||||||
|
// ... use same items as above
|
||||||
myTiaFreqPopup = new PopUpWidget(this, font, xpos, ypos,
|
myTiaFreqPopup = new PopUpWidget(this, font, xpos, ypos,
|
||||||
pwidth + myVolumeLabel->getWidth() - 4, lineHeight,
|
pwidth + myVolumeLabel->getWidth() - 4, lineHeight,
|
||||||
"TIA freq: ", lwidth);
|
items, "TIA freq: ", lwidth);
|
||||||
myTiaFreqPopup->appendEntry("11025", 1);
|
|
||||||
myTiaFreqPopup->appendEntry("22050", 2);
|
|
||||||
myTiaFreqPopup->appendEntry("31400", 3);
|
|
||||||
myTiaFreqPopup->appendEntry("44100", 4);
|
|
||||||
myTiaFreqPopup->appendEntry("48000", 5);
|
|
||||||
wid.push_back(myTiaFreqPopup);
|
wid.push_back(myTiaFreqPopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
|
@ -140,45 +140,46 @@ void AudioDialog::loadConfig()
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
// Volume
|
// Volume
|
||||||
myVolumeSlider->setValue(instance()->settings().getInt("volume"));
|
myVolumeSlider->setValue(instance().settings().getInt("volume"));
|
||||||
myVolumeLabel->setLabel(instance()->settings().getString("volume"));
|
myVolumeLabel->setLabel(instance().settings().getString("volume"));
|
||||||
|
|
||||||
// Fragsize
|
// Fragsize
|
||||||
i = instance()->settings().getInt("fragsize");
|
i = instance().settings().getInt("fragsize");
|
||||||
if(i == 128) i = 1;
|
if(i == 128) i = 0;
|
||||||
else if(i == 256) i = 2;
|
else if(i == 256) i = 1;
|
||||||
else if(i == 512) i = 3;
|
else if(i == 512) i = 2;
|
||||||
else if(i == 1024) i = 4;
|
else if(i == 1024) i = 3;
|
||||||
else if(i == 2048) i = 5;
|
else if(i == 2048) i = 4;
|
||||||
else if(i == 4096) i = 6;
|
else if(i == 4096) i = 5;
|
||||||
myFragsizePopup->setSelectedTag(i);
|
else i = 2; // default to '512'
|
||||||
|
myFragsizePopup->setSelected(i);
|
||||||
|
|
||||||
// Output frequency
|
// Output frequency
|
||||||
i = instance()->settings().getInt("freq");
|
i = instance().settings().getInt("freq");
|
||||||
if(i == 11025) i = 1;
|
if(i == 11025) i = 0;
|
||||||
else if(i == 22050) i = 2;
|
else if(i == 22050) i = 1;
|
||||||
else if(i == 31400) i = 3;
|
else if(i == 31400) i = 2;
|
||||||
else if(i == 44100) i = 4;
|
else if(i == 44100) i = 3;
|
||||||
else if(i == 48000) i = 5;
|
else if(i == 48000) i = 4;
|
||||||
else i = 3; // default to '31400'
|
else i = 2; // default to '31400'
|
||||||
myFreqPopup->setSelectedTag(i);
|
myFreqPopup->setSelected(i);
|
||||||
|
|
||||||
// TIA frequency
|
// TIA frequency
|
||||||
i = instance()->settings().getInt("tiafreq");
|
i = instance().settings().getInt("tiafreq");
|
||||||
if(i == 11025) i = 1;
|
if(i == 11025) i = 0;
|
||||||
else if(i == 22050) i = 2;
|
else if(i == 22050) i = 1;
|
||||||
else if(i == 31400) i = 3;
|
else if(i == 31400) i = 2;
|
||||||
else if(i == 44100) i = 4;
|
else if(i == 44100) i = 3;
|
||||||
else if(i == 48000) i = 5;
|
else if(i == 48000) i = 4;
|
||||||
else i = 3; // default to '31400'
|
else i = 2; // default to '31400'
|
||||||
myTiaFreqPopup->setSelectedTag(i);
|
myTiaFreqPopup->setSelected(i);
|
||||||
|
|
||||||
// Clip volume
|
// Clip volume
|
||||||
b = instance()->settings().getBool("clipvol");
|
b = instance().settings().getBool("clipvol");
|
||||||
myClipVolumeCheckbox->setState(b);
|
myClipVolumeCheckbox->setState(b);
|
||||||
|
|
||||||
// Enable sound
|
// Enable sound
|
||||||
b = instance()->settings().getBool("sound");
|
b = instance().settings().getBool("sound");
|
||||||
mySoundEnableCheckbox->setState(b);
|
mySoundEnableCheckbox->setState(b);
|
||||||
|
|
||||||
// Make sure that mutually-exclusive items are not enabled at the same time
|
// Make sure that mutually-exclusive items are not enabled at the same time
|
||||||
|
@ -188,14 +189,14 @@ void AudioDialog::loadConfig()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void AudioDialog::saveConfig()
|
void AudioDialog::saveConfig()
|
||||||
{
|
{
|
||||||
Settings& settings = instance()->settings();
|
Settings& settings = instance().settings();
|
||||||
string s;
|
string s;
|
||||||
bool b;
|
bool b;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
// Volume
|
// Volume
|
||||||
i = myVolumeSlider->getValue();
|
i = myVolumeSlider->getValue();
|
||||||
instance()->sound().setVolume(i);
|
instance().sound().setVolume(i);
|
||||||
|
|
||||||
// Fragsize
|
// Fragsize
|
||||||
s = myFragsizePopup->getSelectedString();
|
s = myFragsizePopup->getSelectedString();
|
||||||
|
@ -215,12 +216,12 @@ void AudioDialog::saveConfig()
|
||||||
|
|
||||||
// Enable/disable sound (requires a restart to take effect)
|
// Enable/disable sound (requires a restart to take effect)
|
||||||
b = mySoundEnableCheckbox->getState();
|
b = mySoundEnableCheckbox->getState();
|
||||||
instance()->sound().setEnabled(b);
|
instance().sound().setEnabled(b);
|
||||||
|
|
||||||
// Only force a re-initialization when necessary, since it can
|
// Only force a re-initialization when necessary, since it can
|
||||||
// be a time-consuming operation
|
// be a time-consuming operation
|
||||||
if(&instance()->console())
|
if(&instance().console())
|
||||||
instance()->console().initializeAudio();
|
instance().console().initializeAudio();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -229,13 +230,9 @@ void AudioDialog::setDefaults()
|
||||||
myVolumeSlider->setValue(100);
|
myVolumeSlider->setValue(100);
|
||||||
myVolumeLabel->setLabel("100");
|
myVolumeLabel->setLabel("100");
|
||||||
|
|
||||||
#ifdef WIN32
|
myFragsizePopup->setSelected(2); // 512 bytes
|
||||||
myFragsizePopup->setSelectedTag(5);
|
myFreqPopup->setSelected(2); // 31400 Hz
|
||||||
#else
|
myTiaFreqPopup->setSelected(2); // 31400 Hz
|
||||||
myFragsizePopup->setSelectedTag(3);
|
|
||||||
#endif
|
|
||||||
myFreqPopup->setSelectedTag(3);
|
|
||||||
myTiaFreqPopup->setSelectedTag(3);
|
|
||||||
|
|
||||||
myClipVolumeCheckbox->setState(true);
|
myClipVolumeCheckbox->setState(true);
|
||||||
mySoundEnableCheckbox->setState(true);
|
mySoundEnableCheckbox->setState(true);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: BrowserDialog.cxx,v 1.30 2008-03-23 16:22:46 stephena Exp $
|
// $Id: BrowserDialog.cxx,v 1.31 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -41,7 +41,7 @@
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
BrowserDialog::BrowserDialog(GuiObject* boss, const GUI::Font& font,
|
BrowserDialog::BrowserDialog(GuiObject* boss, const GUI::Font& font,
|
||||||
int x, int y, int w, int h)
|
int x, int y, int w, int h)
|
||||||
: Dialog(boss->instance(), boss->parent(), x, y, w, h),
|
: Dialog(&boss->instance(), &boss->parent(), x, y, w, h),
|
||||||
CommandSender(boss),
|
CommandSender(boss),
|
||||||
_fileList(NULL),
|
_fileList(NULL),
|
||||||
_currentPath(NULL),
|
_currentPath(NULL),
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CheckListWidget.cxx,v 1.16 2008-02-06 13:45:23 stephena Exp $
|
// $Id: CheckListWidget.cxx,v 1.17 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -106,17 +106,17 @@ void CheckListWidget::setLine(int line, const string& str, const bool& state)
|
||||||
void CheckListWidget::drawWidget(bool hilite)
|
void CheckListWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "CheckListWidget::drawWidget\n";
|
//cerr << "CheckListWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
int i, pos, len = _list.size();
|
int i, pos, len = _list.size();
|
||||||
string buffer;
|
string buffer;
|
||||||
int deltax;
|
int deltax;
|
||||||
|
|
||||||
// Draw a thin frame around the list and to separate columns
|
// Draw a thin frame around the list and to separate columns
|
||||||
fb.hLine(_x, _y, _x + _w - 1, kColor);
|
s.hLine(_x, _y, _x + _w - 1, kColor);
|
||||||
fb.hLine(_x, _y + _h - 1, _x + _w - 1, kShadowColor);
|
s.hLine(_x, _y + _h - 1, _x + _w - 1, kShadowColor);
|
||||||
fb.vLine(_x, _y, _y + _h - 1, kColor);
|
s.vLine(_x, _y, _y + _h - 1, kColor);
|
||||||
|
|
||||||
fb.vLine(_x + CheckboxWidget::boxSize() + 5, _y, _y + _h - 1, kColor);
|
s.vLine(_x + CheckboxWidget::boxSize() + 5, _y, _y + _h - 1, kColor);
|
||||||
|
|
||||||
// Draw the list items
|
// Draw the list items
|
||||||
for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++)
|
for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++)
|
||||||
|
@ -134,13 +134,11 @@ void CheckListWidget::drawWidget(bool hilite)
|
||||||
if (_selectedItem == pos)
|
if (_selectedItem == pos)
|
||||||
{
|
{
|
||||||
if (_hasFocus && !_editMode)
|
if (_hasFocus && !_editMode)
|
||||||
fb.fillRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
s.fillRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
||||||
_w - r.left, _fontHeight,
|
_w - r.left, _fontHeight, kTextColorHi);
|
||||||
kTextColorHi);
|
|
||||||
else
|
else
|
||||||
fb.frameRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
s.frameRect(_x + r.left - 3, _y + 1 + _fontHeight * i,
|
||||||
_w - r.left, _fontHeight,
|
_w - r.left, _fontHeight, kTextColorHi);
|
||||||
kTextColorHi);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_selectedItem == pos && _editMode)
|
if (_selectedItem == pos && _editMode)
|
||||||
|
@ -149,14 +147,14 @@ void CheckListWidget::drawWidget(bool hilite)
|
||||||
adjustOffset();
|
adjustOffset();
|
||||||
deltax = -_editScrollOffset;
|
deltax = -_editScrollOffset;
|
||||||
|
|
||||||
fb.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor,
|
s.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor,
|
||||||
kTextAlignLeft, deltax, false);
|
kTextAlignLeft, deltax, false);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
buffer = _list[pos];
|
buffer = _list[pos];
|
||||||
deltax = 0;
|
deltax = 0;
|
||||||
fb.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor);
|
s.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CommandDialog.cxx,v 1.19 2008-05-17 15:16:45 stephena Exp $
|
// $Id: CommandDialog.cxx,v 1.20 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -190,29 +190,29 @@ void CommandDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kSnapshotCmd:
|
case kSnapshotCmd:
|
||||||
instance()->eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
instance()->eventHandler().refreshDisplay(true);
|
instance().eventHandler().refreshDisplay(true);
|
||||||
instance()->eventHandler().handleEvent(Event::TakeSnapshot, 1);
|
instance().eventHandler().handleEvent(Event::TakeSnapshot, 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kFormatCmd:
|
case kFormatCmd:
|
||||||
instance()->eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
instance()->console().toggleFormat();
|
instance().console().toggleFormat();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kPaletteCmd:
|
case kPaletteCmd:
|
||||||
instance()->eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
instance()->console().togglePalette();
|
instance().console().togglePalette();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kReloadRomCmd:
|
case kReloadRomCmd:
|
||||||
instance()->eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
instance()->deleteConsole();
|
instance().deleteConsole();
|
||||||
instance()->createConsole();
|
instance().createConsole();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kExitCmd:
|
case kExitCmd:
|
||||||
instance()->eventHandler().handleEvent(Event::LauncherMode, 1);
|
instance().eventHandler().handleEvent(Event::LauncherMode, 1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -220,14 +220,14 @@ void CommandDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
// State commands require you to exit the menu manually
|
// State commands require you to exit the menu manually
|
||||||
if(consoleCmd)
|
if(consoleCmd)
|
||||||
{
|
{
|
||||||
instance()->eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
instance()->eventHandler().handleEvent(event, 1);
|
instance().eventHandler().handleEvent(event, 1);
|
||||||
instance()->console().switches().update();
|
instance().console().switches().update();
|
||||||
instance()->console().mediaSource().update();
|
instance().console().mediaSource().update();
|
||||||
instance()->eventHandler().handleEvent(event, 0);
|
instance().eventHandler().handleEvent(event, 0);
|
||||||
}
|
}
|
||||||
else if(stateCmd)
|
else if(stateCmd)
|
||||||
{
|
{
|
||||||
instance()->eventHandler().handleEvent(event, 1);
|
instance().eventHandler().handleEvent(event, 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ContextMenu.cxx,v 1.11 2008-02-06 13:45:20 stephena Exp $
|
// $Id: ContextMenu.cxx,v 1.1 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -26,35 +26,17 @@
|
||||||
#include "ContextMenu.hxx"
|
#include "ContextMenu.hxx"
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
ContextMenu::ContextMenu(GuiObject* boss, const GUI::Font& font)
|
ContextMenu::ContextMenu(GuiObject* boss, const GUI::Font& font,
|
||||||
: Dialog(boss->instance(), boss->parent(), 0, 0, 16, 16),
|
const StringList& items, int cmd)
|
||||||
|
: Dialog(&boss->instance(), &boss->parent(), 0, 0, 16, 16),
|
||||||
CommandSender(boss),
|
CommandSender(boss),
|
||||||
|
_entries(items),
|
||||||
|
_currentItem(-1),
|
||||||
_selectedItem(-1),
|
_selectedItem(-1),
|
||||||
_rowHeight(font.getLineHeight()),
|
_rowHeight(font.getLineHeight()),
|
||||||
_font(&font)
|
_font(&font),
|
||||||
|
_cmd(cmd)
|
||||||
{
|
{
|
||||||
// Context menus pop up wherever the mouse is clicked
|
|
||||||
setCenter(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
ContextMenu::~ContextMenu()
|
|
||||||
{
|
|
||||||
_entries.clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void ContextMenu::show()
|
|
||||||
{
|
|
||||||
_selectedItem = -1;
|
|
||||||
parent()->addDialog(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void ContextMenu::setList(const StringList& list)
|
|
||||||
{
|
|
||||||
_entries = list;
|
|
||||||
|
|
||||||
// Resize to largest string
|
// Resize to largest string
|
||||||
int maxwidth = 0;
|
int maxwidth = 0;
|
||||||
for(unsigned int i = 0; i < _entries.size(); ++i)
|
for(unsigned int i = 0; i < _entries.size(); ++i)
|
||||||
|
@ -64,10 +46,67 @@ void ContextMenu::setList(const StringList& list)
|
||||||
maxwidth = length;
|
maxwidth = length;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_x = _y = 0;
|
||||||
_w = maxwidth + 8;
|
_w = maxwidth + 8;
|
||||||
_h = _rowHeight * _entries.size() + 4;
|
_h = _rowHeight * _entries.size() + 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
ContextMenu::~ContextMenu()
|
||||||
|
{
|
||||||
|
_entries.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::show(uInt32 x, uInt32 y, int item)
|
||||||
|
{
|
||||||
|
// Make sure position is set *after* the dialog is added, since the surface
|
||||||
|
// may not exist before then
|
||||||
|
parent().addDialog(this);
|
||||||
|
surface().setPos(x, y);
|
||||||
|
setSelected(item);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::setSelected(int item)
|
||||||
|
{
|
||||||
|
if(item >= 0 && item < (int)_entries.size())
|
||||||
|
_selectedItem = _currentItem = item;
|
||||||
|
else
|
||||||
|
_selectedItem = _currentItem = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::setSelected(const string& name)
|
||||||
|
{
|
||||||
|
for(unsigned int item = 0; item < _entries.size(); ++item)
|
||||||
|
{
|
||||||
|
if(_entries[item] == name)
|
||||||
|
{
|
||||||
|
setSelected(item);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::setSelectedMax()
|
||||||
|
{
|
||||||
|
setSelected(_entries.size() - 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::clearSelection()
|
||||||
|
{
|
||||||
|
_selectedItem = _currentItem = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
int ContextMenu::getSelected() const
|
||||||
|
{
|
||||||
|
return _selectedItem;
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
const string& ContextMenu::getSelectedString() const
|
const string& ContextMenu::getSelectedString() const
|
||||||
{
|
{
|
||||||
|
@ -84,7 +123,7 @@ void ContextMenu::handleMouseDown(int x, int y, int button, int clickCount)
|
||||||
if(x >= _x && x <= _x+_w && y >= _y && y <= _y+_h)
|
if(x >= _x && x <= _x+_w && y >= _y && y <= _y+_h)
|
||||||
sendSelection();
|
sendSelection();
|
||||||
else
|
else
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,32 +145,61 @@ void ContextMenu::handleMouseMoved(int x, int y, int button)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// ...and update the selection accordingly
|
// ...and update the selection accordingly
|
||||||
setSelection(item);
|
drawCurrentSelection(item);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ContextMenu::handleKeyDown(int ascii, int keycode, int modifiers)
|
void ContextMenu::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
{
|
{
|
||||||
switch(ascii)
|
handleEvent(instance().eventHandler().eventForKey(keycode, kMenuMode));
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::handleJoyDown(int stick, int button)
|
||||||
{
|
{
|
||||||
case 27: // escape
|
handleEvent(instance().eventHandler().eventForJoyButton(stick, button, kMenuMode));
|
||||||
parent()->removeDialog();
|
}
|
||||||
break;
|
|
||||||
case '\n': // enter/return
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
case '\r':
|
void ContextMenu::handleJoyAxis(int stick, int axis, int value)
|
||||||
|
{
|
||||||
|
if(value != 0) // we don't care about 'axis up' events
|
||||||
|
handleEvent(instance().eventHandler().eventForJoyAxis(stick, axis, value, kMenuMode));
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
bool ContextMenu::handleJoyHat(int stick, int hat, int value)
|
||||||
|
{
|
||||||
|
handleEvent(instance().eventHandler().eventForJoyHat(stick, hat, value, kMenuMode));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::handleEvent(Event::Type e)
|
||||||
|
{
|
||||||
|
switch(e)
|
||||||
|
{
|
||||||
|
case Event::UISelect:
|
||||||
sendSelection();
|
sendSelection();
|
||||||
break;
|
break;
|
||||||
case 256+17: // up arrow
|
case Event::UIUp:
|
||||||
|
case Event::UILeft:
|
||||||
moveUp();
|
moveUp();
|
||||||
break;
|
break;
|
||||||
case 256+18: // down arrow
|
case Event::UIDown:
|
||||||
|
case Event::UIRight:
|
||||||
moveDown();
|
moveDown();
|
||||||
break;
|
break;
|
||||||
case 256+22: // home
|
case Event::UIHome:
|
||||||
setSelection(0);
|
drawCurrentSelection(0);
|
||||||
break;
|
break;
|
||||||
case 256+23: // end
|
case Event::UIEnd:
|
||||||
setSelection(_entries.size()-1);
|
drawCurrentSelection(_entries.size()-1);
|
||||||
|
break;
|
||||||
|
case Event::UICancel:
|
||||||
|
parent().removeDialog();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -146,12 +214,12 @@ int ContextMenu::findItem(int x, int y) const
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ContextMenu::setSelection(int item)
|
void ContextMenu::drawCurrentSelection(int item)
|
||||||
{
|
{
|
||||||
if(item != _selectedItem)
|
if(item != _currentItem)
|
||||||
{
|
{
|
||||||
// Change selection
|
// Change selection
|
||||||
_selectedItem = item;
|
_currentItem = item;
|
||||||
setDirty(); draw();
|
setDirty(); draw();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -159,26 +227,36 @@ void ContextMenu::setSelection(int item)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ContextMenu::sendSelection()
|
void ContextMenu::sendSelection()
|
||||||
{
|
{
|
||||||
// We remove the dialog when the user has selected an item
|
// Send any command associated with the selection
|
||||||
parent()->removeDialog();
|
_selectedItem = _currentItem;
|
||||||
|
sendCommand(_cmd ? _cmd : kCMenuItemSelectedCmd, _selectedItem, -1);
|
||||||
|
|
||||||
sendCommand(kCMenuItemSelectedCmd, _selectedItem, -1);
|
// We remove the dialog when the user has selected an item
|
||||||
|
parent().removeDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ContextMenu::moveUp()
|
void ContextMenu::moveUp()
|
||||||
{
|
{
|
||||||
int item = _selectedItem;
|
int item = _currentItem;
|
||||||
if(item > 0)
|
if(item > 0)
|
||||||
setSelection(--item);
|
drawCurrentSelection(--item);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ContextMenu::moveDown()
|
void ContextMenu::moveDown()
|
||||||
{
|
{
|
||||||
int item = _selectedItem;
|
int item = _currentItem;
|
||||||
if(item < (int)_entries.size() - 1)
|
if(item < (int)_entries.size() - 1)
|
||||||
setSelection(++item);
|
drawCurrentSelection(++item);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void ContextMenu::center()
|
||||||
|
{
|
||||||
|
// Adjust dialog, making sure it doesn't fall outside screen area
|
||||||
|
|
||||||
|
// FIXME - add code to do this ...
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -187,29 +265,32 @@ void ContextMenu::drawDialog()
|
||||||
// Normally we add widgets and let Dialog::draw() take care of this
|
// Normally we add widgets and let Dialog::draw() take care of this
|
||||||
// logic. But for some reason, this Dialog was written differently
|
// logic. But for some reason, this Dialog was written differently
|
||||||
// by the ScummVM guys, so I'm not going to mess with it.
|
// by the ScummVM guys, so I'm not going to mess with it.
|
||||||
|
FBSurface& s = surface();
|
||||||
|
|
||||||
if(_dirty)
|
if(_dirty)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
FBSurface& s = surface();
|
||||||
|
|
||||||
fb.fillRect(_x+1, _y+1, _w-2, _h-2, kWidColor);
|
s.fillRect(_x+1, _y+1, _w-2, _h-2, kWidColor);
|
||||||
fb.box(_x, _y, _w, _h, kColor, kShadowColor);
|
s.box(_x, _y, _w, _h, kColor, kShadowColor);
|
||||||
|
|
||||||
// Draw the entries
|
// Draw the entries
|
||||||
int count = _entries.size();
|
int count = _entries.size();
|
||||||
for(int i = 0; i < count; i++)
|
for(int i = 0; i < count; i++)
|
||||||
{
|
{
|
||||||
bool hilite = i == _selectedItem;
|
bool hilite = i == _currentItem;
|
||||||
int x = _x + 2;
|
int x = _x + 2;
|
||||||
int y = _y + 2 + i * _rowHeight;
|
int y = _y + 2 + i * _rowHeight;
|
||||||
int w = _w - 4;
|
int w = _w - 4;
|
||||||
string& name = _entries[i];
|
|
||||||
|
|
||||||
fb.fillRect(x, y, w, _rowHeight, hilite ? kTextColorHi : kWidColor);
|
if(hilite) s.fillRect(x, y, w, _rowHeight, kTextColorHi);
|
||||||
|
s.drawString(_font, _entries[i], x + 1, y + 2, w - 2,
|
||||||
fb.drawString(_font, name, x + 1, y + 2, w - 2,
|
|
||||||
hilite ? kWidColor : kTextColor);
|
hilite ? kWidColor : kTextColor);
|
||||||
}
|
}
|
||||||
|
s.addDirtyRect(_x, _y, _w, _h);
|
||||||
_dirty = false;
|
_dirty = false;
|
||||||
fb.addDirtyRect(_x, _y, _w, _h);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Commit surface changes to screen
|
||||||
|
s.update();
|
||||||
}
|
}
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ContextMenu.hxx,v 1.7 2008-02-06 13:45:20 stephena Exp $
|
// $Id: ContextMenu.hxx,v 1.1 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -36,27 +36,47 @@ enum {
|
||||||
* Popup context menu which, when clicked, "pop up" a list of items and
|
* Popup context menu which, when clicked, "pop up" a list of items and
|
||||||
* lets the user pick on of them.
|
* lets the user pick on of them.
|
||||||
*
|
*
|
||||||
* Implementation wise, when the user selects an item, then a kCMenuItemSelectedCmd
|
* Implementation wise, when the user selects an item, then the given 'cmd'
|
||||||
* is broadcast, with data being equal to the tag value of the selected entry.
|
* is broadcast, with data being equal to the tag value of the selected entry.
|
||||||
*/
|
*/
|
||||||
class ContextMenu : public Dialog, public CommandSender
|
class ContextMenu : public Dialog, public CommandSender
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ContextMenu(GuiObject* boss, const GUI::Font& font);
|
ContextMenu(GuiObject* boss, const GUI::Font& font,
|
||||||
|
const StringList& items, int cmd = 0);
|
||||||
virtual ~ContextMenu();
|
virtual ~ContextMenu();
|
||||||
|
|
||||||
/** Show context menu onscreen */
|
/** Show context menu onscreen at the specified coordinates */
|
||||||
void show();
|
void show(uInt32 x, uInt32 y, int item = -1);
|
||||||
|
|
||||||
void setList(const StringList& list);
|
/** Select the entry at the given index. */
|
||||||
|
void setSelected(int item);
|
||||||
|
|
||||||
|
/** Select the first entry matching the given name. */
|
||||||
|
void setSelected(const string& name);
|
||||||
|
|
||||||
|
/** Select the highest/last entry in the internal list. */
|
||||||
|
void setSelectedMax();
|
||||||
|
|
||||||
|
/** Clear selection (reset to default). */
|
||||||
|
void clearSelection();
|
||||||
|
|
||||||
|
/** Accessor methods for the currently selected item. */
|
||||||
|
int getSelected() const;
|
||||||
const string& getSelectedString() const;
|
const string& getSelectedString() const;
|
||||||
int getSelected() const { return _selectedItem; }
|
|
||||||
|
/** This dialog uses its own positioning, so we override Dialog::center() */
|
||||||
|
void center();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void handleMouseDown(int x, int y, int button, int clickCount);
|
void handleMouseDown(int x, int y, int button, int clickCount);
|
||||||
void handleMouseWheel(int x, int y, int direction);
|
void handleMouseWheel(int x, int y, int direction);
|
||||||
void handleMouseMoved(int x, int y, int button);
|
void handleMouseMoved(int x, int y, int button);
|
||||||
void handleKeyDown(int ascii, int keycode, int modifiers);
|
void handleKeyDown(int ascii, int keycode, int modifiers); // Scroll through entries with arrow keys etc
|
||||||
|
void handleJoyDown(int stick, int button);
|
||||||
|
void handleJoyAxis(int stick, int axis, int value);
|
||||||
|
bool handleJoyHat(int stick, int hat, int value);
|
||||||
|
void handleEvent(Event::Type e);
|
||||||
|
|
||||||
void drawDialog();
|
void drawDialog();
|
||||||
|
|
||||||
|
@ -64,7 +84,7 @@ class ContextMenu : public Dialog, public CommandSender
|
||||||
void drawMenuEntry(int entry, bool hilite);
|
void drawMenuEntry(int entry, bool hilite);
|
||||||
|
|
||||||
int findItem(int x, int y) const;
|
int findItem(int x, int y) const;
|
||||||
void setSelection(int item);
|
void drawCurrentSelection(int item);
|
||||||
|
|
||||||
void moveUp();
|
void moveUp();
|
||||||
void moveDown();
|
void moveDown();
|
||||||
|
@ -74,11 +94,13 @@ class ContextMenu : public Dialog, public CommandSender
|
||||||
protected:
|
protected:
|
||||||
StringList _entries;
|
StringList _entries;
|
||||||
|
|
||||||
|
int _currentItem;
|
||||||
int _selectedItem;
|
int _selectedItem;
|
||||||
int _rowHeight;
|
int _rowHeight;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
const GUI::Font* _font;
|
const GUI::Font* _font;
|
||||||
|
int _cmd;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Dialog.cxx,v 1.60 2008-03-25 13:11:34 stephena Exp $
|
// $Id: Dialog.cxx,v 1.61 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -36,8 +36,8 @@
|
||||||
*/
|
*/
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
Dialog::Dialog(OSystem* instance, DialogContainer* parent,
|
Dialog::Dialog(OSystem* instance, DialogContainer* parent,
|
||||||
int x, int y, int w, int h)
|
int x, int y, int w, int h, bool isBase)
|
||||||
: GuiObject(instance, parent, x, y, w, h),
|
: GuiObject(*instance, *parent, *this, x, y, w, h),
|
||||||
_mouseWidget(0),
|
_mouseWidget(0),
|
||||||
_focusedWidget(0),
|
_focusedWidget(0),
|
||||||
_dragWidget(0),
|
_dragWidget(0),
|
||||||
|
@ -45,7 +45,9 @@ Dialog::Dialog(OSystem* instance, DialogContainer* parent,
|
||||||
_cancelWidget(0),
|
_cancelWidget(0),
|
||||||
_visible(true),
|
_visible(true),
|
||||||
_center(true),
|
_center(true),
|
||||||
|
_isBase(isBase),
|
||||||
_ourTab(NULL),
|
_ourTab(NULL),
|
||||||
|
_surface(NULL),
|
||||||
_focusID(0)
|
_focusID(0)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -60,6 +62,8 @@ Dialog::~Dialog()
|
||||||
_firstWidget = NULL;
|
_firstWidget = NULL;
|
||||||
|
|
||||||
_ourButtonGroup.clear();
|
_ourButtonGroup.clear();
|
||||||
|
|
||||||
|
delete _surface;
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -68,6 +72,17 @@ void Dialog::open()
|
||||||
_result = 0;
|
_result = 0;
|
||||||
_visible = true;
|
_visible = true;
|
||||||
|
|
||||||
|
// Make sure we have a valid surface to draw into
|
||||||
|
// Technically, this shouldn't be needed until drawDialog(), but some
|
||||||
|
// dialogs cause drawing to occur within loadConfig()
|
||||||
|
// Base surfaces are typically large, and will probably cause slow
|
||||||
|
// performance if we update the whole area each frame
|
||||||
|
// Instead, dirty rectangle updates should be performed
|
||||||
|
if(_surface == NULL)
|
||||||
|
_surface = instance().frameBuffer().createSurface(_w, _h, _isBase);
|
||||||
|
|
||||||
|
center();
|
||||||
|
|
||||||
loadConfig();
|
loadConfig();
|
||||||
|
|
||||||
// (Re)-build the focus list to use for the widgets which are currently
|
// (Re)-build the focus list to use for the widgets which are currently
|
||||||
|
@ -85,18 +100,14 @@ void Dialog::close()
|
||||||
}
|
}
|
||||||
|
|
||||||
releaseFocus();
|
releaseFocus();
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void Dialog::center()
|
void Dialog::center()
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
if(_center && _surface)
|
||||||
if(_center && &fb)
|
_surface->centerPos();
|
||||||
{
|
|
||||||
_x = (fb.baseWidth() - _w) / 2;
|
|
||||||
_y = (fb.baseHeight() - _h) / 2;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -225,13 +236,14 @@ void Dialog::drawDialog()
|
||||||
if(!isVisible())
|
if(!isVisible())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
FBSurface& s = surface();
|
||||||
|
|
||||||
if(_dirty)
|
if(_dirty)
|
||||||
{
|
{
|
||||||
// cerr << "Dialog::drawDialog()\n";
|
cerr << "Dialog::drawDialog(): w = " << _w << ", h = " << _h << endl << endl;
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
|
||||||
|
|
||||||
fb.fillRect(_x+1, _y+1, _w-2, _h-2, kDlgColor);
|
s.fillRect(_x+1, _y+1, _w-2, _h-2, kDlgColor);
|
||||||
fb.box(_x, _y, _w, _h, kColor, kShadowColor);
|
s.box(_x, _y, _w, _h, kColor, kShadowColor);
|
||||||
|
|
||||||
// Make all child widget dirty
|
// Make all child widget dirty
|
||||||
Widget* w = _firstWidget;
|
Widget* w = _firstWidget;
|
||||||
|
@ -248,12 +260,13 @@ void Dialog::drawDialog()
|
||||||
// Draw outlines for focused widgets
|
// Draw outlines for focused widgets
|
||||||
redrawFocus();
|
redrawFocus();
|
||||||
|
|
||||||
// Tell the framebuffer this area is dirty
|
// Tell the surface this area is dirty
|
||||||
fb.addDirtyRect(_x, _y, _w, _h);
|
s.addDirtyRect(_x, _y, _w, _h);
|
||||||
//cerr << "dirty: x = " << _x << ", y = " << _y << ", w = " << _w << ", h = " << _h << endl;
|
|
||||||
|
|
||||||
_dirty = false;
|
_dirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Commit surface changes to screen
|
||||||
|
s.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -318,7 +331,7 @@ void Dialog::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
// Detect selection of previous and next tab headers and objects
|
// Detect selection of previous and next tab headers and objects
|
||||||
// For some strange reason, 'tab' needs to be interpreted as keycode,
|
// For some strange reason, 'tab' needs to be interpreted as keycode,
|
||||||
// not ascii??
|
// not ascii??
|
||||||
if(instance()->eventHandler().kbdShift(modifiers))
|
if(instance().eventHandler().kbdShift(modifiers))
|
||||||
{
|
{
|
||||||
if(ascii == 256+20 && _ourTab) // left arrow
|
if(ascii == 256+20 && _ourTab) // left arrow
|
||||||
{
|
{
|
||||||
|
@ -339,7 +352,7 @@ void Dialog::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
// Check the keytable now, since we might get one of the above events,
|
// Check the keytable now, since we might get one of the above events,
|
||||||
// which must always be processed before any widget sees it.
|
// which must always be processed before any widget sees it.
|
||||||
if(e == Event::NoType)
|
if(e == Event::NoType)
|
||||||
e = instance()->eventHandler().eventForKey(keycode, kMenuMode);
|
e = instance().eventHandler().eventForKey(keycode, kMenuMode);
|
||||||
|
|
||||||
// Unless a widget has claimed all responsibility for data, we assume
|
// Unless a widget has claimed all responsibility for data, we assume
|
||||||
// that if an event exists for the given data, it should have priority.
|
// that if an event exists for the given data, it should have priority.
|
||||||
|
@ -414,7 +427,7 @@ void Dialog::handleMouseMoved(int x, int y, int button)
|
||||||
void Dialog::handleJoyDown(int stick, int button)
|
void Dialog::handleJoyDown(int stick, int button)
|
||||||
{
|
{
|
||||||
Event::Type e =
|
Event::Type e =
|
||||||
instance()->eventHandler().eventForJoyButton(stick, button, kMenuMode);
|
instance().eventHandler().eventForJoyButton(stick, button, kMenuMode);
|
||||||
|
|
||||||
// Unless a widget has claimed all responsibility for data, we assume
|
// Unless a widget has claimed all responsibility for data, we assume
|
||||||
// that if an event exists for the given data, it should have priority.
|
// that if an event exists for the given data, it should have priority.
|
||||||
|
@ -439,7 +452,7 @@ void Dialog::handleJoyUp(int stick, int button)
|
||||||
void Dialog::handleJoyAxis(int stick, int axis, int value)
|
void Dialog::handleJoyAxis(int stick, int axis, int value)
|
||||||
{
|
{
|
||||||
Event::Type e =
|
Event::Type e =
|
||||||
instance()->eventHandler().eventForJoyAxis(stick, axis, value, kMenuMode);
|
instance().eventHandler().eventForJoyAxis(stick, axis, value, kMenuMode);
|
||||||
|
|
||||||
// Unless a widget has claimed all responsibility for data, we assume
|
// Unless a widget has claimed all responsibility for data, we assume
|
||||||
// that if an event exists for the given data, it should have priority.
|
// that if an event exists for the given data, it should have priority.
|
||||||
|
@ -456,7 +469,7 @@ void Dialog::handleJoyAxis(int stick, int axis, int value)
|
||||||
bool Dialog::handleJoyHat(int stick, int hat, int value)
|
bool Dialog::handleJoyHat(int stick, int hat, int value)
|
||||||
{
|
{
|
||||||
Event::Type e =
|
Event::Type e =
|
||||||
instance()->eventHandler().eventForJoyHat(stick, hat, value, kMenuMode);
|
instance().eventHandler().eventForJoyHat(stick, hat, value, kMenuMode);
|
||||||
|
|
||||||
// Unless a widget has claimed all responsibility for data, we assume
|
// Unless a widget has claimed all responsibility for data, we assume
|
||||||
// that if an event exists for the given data, it should have priority.
|
// that if an event exists for the given data, it should have priority.
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Dialog.hxx,v 1.37 2008-03-23 16:22:46 stephena Exp $
|
// $Id: Dialog.hxx,v 1.38 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -22,6 +22,7 @@
|
||||||
#ifndef DIALOG_HXX
|
#ifndef DIALOG_HXX
|
||||||
#define DIALOG_HXX
|
#define DIALOG_HXX
|
||||||
|
|
||||||
|
class FBSurface;
|
||||||
class OSystem;
|
class OSystem;
|
||||||
class DialogContainer;
|
class DialogContainer;
|
||||||
class TabWidget;
|
class TabWidget;
|
||||||
|
@ -46,7 +47,7 @@ class TabWidget;
|
||||||
This is the base class for all dialog boxes.
|
This is the base class for all dialog boxes.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: Dialog.hxx,v 1.37 2008-03-23 16:22:46 stephena Exp $
|
@version $Id: Dialog.hxx,v 1.38 2008-06-13 13:14:51 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class Dialog : public GuiObject
|
class Dialog : public GuiObject
|
||||||
{
|
{
|
||||||
|
@ -60,11 +61,12 @@ class Dialog : public GuiObject
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Dialog(OSystem* instance, DialogContainer* parent,
|
Dialog(OSystem* instance, DialogContainer* parent,
|
||||||
int x, int y, int w, int h);
|
int x, int y, int w, int h, bool isBase = false);
|
||||||
|
|
||||||
virtual ~Dialog();
|
virtual ~Dialog();
|
||||||
|
|
||||||
bool isVisible() const { return _visible; }
|
bool isVisible() const { return _visible; }
|
||||||
|
bool isBase() const { return _isBase; }
|
||||||
|
|
||||||
virtual void open();
|
virtual void open();
|
||||||
virtual void close();
|
virtual void close();
|
||||||
|
@ -84,6 +86,8 @@ class Dialog : public GuiObject
|
||||||
void setFocus(Widget* w);
|
void setFocus(Widget* w);
|
||||||
void setCenter(bool state) { _center = state; }
|
void setCenter(bool state) { _center = state; }
|
||||||
|
|
||||||
|
inline FBSurface& surface() { return *_surface; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void draw();
|
virtual void draw();
|
||||||
void releaseFocus();
|
void releaseFocus();
|
||||||
|
@ -123,11 +127,13 @@ class Dialog : public GuiObject
|
||||||
Widget* _cancelWidget;
|
Widget* _cancelWidget;
|
||||||
bool _visible;
|
bool _visible;
|
||||||
bool _center;
|
bool _center;
|
||||||
|
bool _isBase;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
FocusList _ourFocusList;
|
FocusList _ourFocusList;
|
||||||
TabWidget* _ourTab;
|
TabWidget* _ourTab;
|
||||||
WidgetArray _ourButtonGroup;
|
WidgetArray _ourButtonGroup;
|
||||||
|
FBSurface* _surface;
|
||||||
|
|
||||||
int _result;
|
int _result;
|
||||||
int _focusID;
|
int _focusID;
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: DialogContainer.cxx,v 1.44 2008-05-21 14:01:31 stephena Exp $
|
// $Id: DialogContainer.cxx,v 1.45 2008-06-13 13:14:51 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "OSystem.hxx"
|
#include "OSystem.hxx"
|
||||||
|
@ -94,6 +94,7 @@ void DialogContainer::draw()
|
||||||
{
|
{
|
||||||
for(int i = 0; i < myDialogStack.size(); i++)
|
for(int i = 0; i < myDialogStack.size(); i++)
|
||||||
{
|
{
|
||||||
|
myDialogStack[i]->center();
|
||||||
myDialogStack[i]->setDirty();
|
myDialogStack[i]->setDirty();
|
||||||
myDialogStack[i]->drawDialog();
|
myDialogStack[i]->drawDialog();
|
||||||
}
|
}
|
||||||
|
@ -101,6 +102,7 @@ void DialogContainer::draw()
|
||||||
}
|
}
|
||||||
else if(!myDialogStack.empty())
|
else if(!myDialogStack.empty())
|
||||||
{
|
{
|
||||||
|
myDialogStack.top()->center();
|
||||||
myDialogStack.top()->drawDialog();
|
myDialogStack.top()->drawDialog();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -110,7 +112,6 @@ void DialogContainer::addDialog(Dialog* d)
|
||||||
{
|
{
|
||||||
myDialogStack.push(d);
|
myDialogStack.push(d);
|
||||||
|
|
||||||
d->center();
|
|
||||||
d->open();
|
d->open();
|
||||||
d->setDirty(); // Next update() will take care of drawing
|
d->setDirty(); // Next update() will take care of drawing
|
||||||
}
|
}
|
||||||
|
@ -175,6 +176,7 @@ void DialogContainer::handleMouseMotionEvent(int x, int y, int button)
|
||||||
|
|
||||||
// Send the event to the dialog box on the top of the stack
|
// Send the event to the dialog box on the top of the stack
|
||||||
Dialog* activeDialog = myDialogStack.top();
|
Dialog* activeDialog = myDialogStack.top();
|
||||||
|
activeDialog->surface().translateCoords(x, y);
|
||||||
activeDialog->handleMouseMoved(x - activeDialog->_x,
|
activeDialog->handleMouseMoved(x - activeDialog->_x,
|
||||||
y - activeDialog->_y,
|
y - activeDialog->_y,
|
||||||
button);
|
button);
|
||||||
|
@ -191,6 +193,7 @@ void DialogContainer::handleMouseButtonEvent(MouseButton b, int x, int y, uInt8
|
||||||
|
|
||||||
// Send the event to the dialog box on the top of the stack
|
// Send the event to the dialog box on the top of the stack
|
||||||
Dialog* activeDialog = myDialogStack.top();
|
Dialog* activeDialog = myDialogStack.top();
|
||||||
|
activeDialog->surface().translateCoords(x, y);
|
||||||
|
|
||||||
int button = (b == EVENT_LBUTTONDOWN || b == EVENT_LBUTTONUP) ? 1 : 2;
|
int button = (b == EVENT_LBUTTONDOWN || b == EVENT_LBUTTONUP) ? 1 : 2;
|
||||||
switch(b)
|
switch(b)
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: EditTextWidget.cxx,v 1.19 2008-02-06 13:45:23 stephena Exp $
|
// $Id: EditTextWidget.cxx,v 1.20 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -72,17 +72,17 @@ void EditTextWidget::handleMouseDown(int x, int y, int button, int clickCount)
|
||||||
void EditTextWidget::drawWidget(bool hilite)
|
void EditTextWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "EditTextWidget::drawWidget\n";
|
//cerr << "EditTextWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
|
|
||||||
// Draw a thin frame around us.
|
// Draw a thin frame around us.
|
||||||
fb.hLine(_x, _y, _x + _w - 1, kColor);
|
s.hLine(_x, _y, _x + _w - 1, kColor);
|
||||||
fb.hLine(_x, _y + _h - 1, _x +_w - 1, kShadowColor);
|
s.hLine(_x, _y + _h - 1, _x +_w - 1, kShadowColor);
|
||||||
fb.vLine(_x, _y, _y + _h - 1, kColor);
|
s.vLine(_x, _y, _y + _h - 1, kColor);
|
||||||
fb.vLine(_x + _w - 1, _y, _y + _h - 1, kShadowColor);
|
s.vLine(_x + _w - 1, _y, _y + _h - 1, kShadowColor);
|
||||||
|
|
||||||
// Draw the text
|
// Draw the text
|
||||||
adjustOffset();
|
adjustOffset();
|
||||||
fb.drawString(_font, _editString, _x + 2, _y + 2, getEditRect().width(),
|
s.drawString(_font, _editString, _x + 2, _y + 2, getEditRect().width(),
|
||||||
_textcolor, kTextAlignLeft, -_editScrollOffset, false);
|
_textcolor, kTextAlignLeft, -_editScrollOffset, false);
|
||||||
|
|
||||||
// Draw the caret
|
// Draw the caret
|
||||||
|
|
|
@ -13,12 +13,13 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: EditableWidget.cxx,v 1.27 2008-02-06 13:45:23 stephena Exp $
|
// $Id: EditableWidget.cxx,v 1.28 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
|
#include "Dialog.hxx"
|
||||||
#include "EditableWidget.hxx"
|
#include "EditableWidget.hxx"
|
||||||
|
|
||||||
|
|
||||||
|
@ -91,7 +92,7 @@ bool EditableWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// Ignore all alt-mod keys
|
// Ignore all alt-mod keys
|
||||||
if(instance()->eventHandler().kbdAlt(modifiers))
|
if(instance().eventHandler().kbdAlt(modifiers))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
bool handled = true;
|
bool handled = true;
|
||||||
|
@ -122,14 +123,14 @@ bool EditableWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 256 + 20: // left arrow
|
case 256 + 20: // left arrow
|
||||||
if(instance()->eventHandler().kbdControl(modifiers))
|
if(instance().eventHandler().kbdControl(modifiers))
|
||||||
dirty = specialKeys(keycode);
|
dirty = specialKeys(keycode);
|
||||||
else if(_caretPos > 0)
|
else if(_caretPos > 0)
|
||||||
dirty = setCaretPos(_caretPos - 1);
|
dirty = setCaretPos(_caretPos - 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 256 + 19: // right arrow
|
case 256 + 19: // right arrow
|
||||||
if(instance()->eventHandler().kbdControl(modifiers))
|
if(instance().eventHandler().kbdControl(modifiers))
|
||||||
dirty = specialKeys(keycode);
|
dirty = specialKeys(keycode);
|
||||||
else if(_caretPos < (int)_editString.size())
|
else if(_caretPos < (int)_editString.size())
|
||||||
dirty = setCaretPos(_caretPos + 1);
|
dirty = setCaretPos(_caretPos + 1);
|
||||||
|
@ -144,7 +145,7 @@ bool EditableWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
if (instance()->eventHandler().kbdControl(modifiers))
|
if (instance().eventHandler().kbdControl(modifiers))
|
||||||
{
|
{
|
||||||
dirty = specialKeys(keycode);
|
dirty = specialKeys(keycode);
|
||||||
}
|
}
|
||||||
|
@ -197,8 +198,8 @@ void EditableWidget::drawCaret()
|
||||||
x += _x;
|
x += _x;
|
||||||
y += _y;
|
y += _y;
|
||||||
|
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
fb.vLine(x, y+2, y + editRect.height() - 3, color);
|
s.vLine(x, y+2, y + editRect.height() - 3, color);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: EventMappingWidget.cxx,v 1.23 2008-03-23 16:22:46 stephena Exp $
|
// $Id: EventMappingWidget.cxx,v 1.24 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -133,7 +133,7 @@ void EventMappingWidget::startRemapping()
|
||||||
// And show a message indicating which key is being remapped
|
// And show a message indicating which key is being remapped
|
||||||
ostringstream buf;
|
ostringstream buf;
|
||||||
buf << "Select action for '"
|
buf << "Select action for '"
|
||||||
<< instance()->eventHandler().actionAtIndex(myActionSelected, myEventMode)
|
<< instance().eventHandler().actionAtIndex(myActionSelected, myEventMode)
|
||||||
<< "' event";
|
<< "' event";
|
||||||
myKeyMapping->setTextColor(kTextColorEm);
|
myKeyMapping->setTextColor(kTextColorEm);
|
||||||
myKeyMapping->setLabel(buf.str());
|
myKeyMapping->setLabel(buf.str());
|
||||||
|
@ -150,8 +150,8 @@ void EventMappingWidget::eraseRemapping()
|
||||||
return;
|
return;
|
||||||
|
|
||||||
Event::Type event =
|
Event::Type event =
|
||||||
instance()->eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
instance().eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
||||||
instance()->eventHandler().eraseMapping(event, myEventMode);
|
instance().eventHandler().eraseMapping(event, myEventMode);
|
||||||
|
|
||||||
drawKeyMapping();
|
drawKeyMapping();
|
||||||
}
|
}
|
||||||
|
@ -188,7 +188,7 @@ void EventMappingWidget::drawKeyMapping()
|
||||||
{
|
{
|
||||||
ostringstream buf;
|
ostringstream buf;
|
||||||
buf << "Action: "
|
buf << "Action: "
|
||||||
<< instance()->eventHandler().keyAtIndex(myActionSelected, myEventMode);
|
<< instance().eventHandler().keyAtIndex(myActionSelected, myEventMode);
|
||||||
myKeyMapping->setTextColor(kTextColor);
|
myKeyMapping->setTextColor(kTextColor);
|
||||||
myKeyMapping->setLabel(buf.str());
|
myKeyMapping->setLabel(buf.str());
|
||||||
}
|
}
|
||||||
|
@ -201,8 +201,8 @@ bool EventMappingWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
if(myRemapStatus && myActionSelected >= 0)
|
if(myRemapStatus && myActionSelected >= 0)
|
||||||
{
|
{
|
||||||
Event::Type event =
|
Event::Type event =
|
||||||
instance()->eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
instance().eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
||||||
if(instance()->eventHandler().addKeyMapping(event, myEventMode, keycode))
|
if(instance().eventHandler().addKeyMapping(event, myEventMode, keycode))
|
||||||
stopRemapping();
|
stopRemapping();
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
|
@ -215,8 +215,8 @@ void EventMappingWidget::handleJoyDown(int stick, int button)
|
||||||
if(myRemapStatus && myActionSelected >= 0)
|
if(myRemapStatus && myActionSelected >= 0)
|
||||||
{
|
{
|
||||||
Event::Type event =
|
Event::Type event =
|
||||||
instance()->eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
instance().eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
||||||
if(instance()->eventHandler().addJoyMapping(event, myEventMode, stick, button))
|
if(instance().eventHandler().addJoyMapping(event, myEventMode, stick, button))
|
||||||
stopRemapping();
|
stopRemapping();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -228,8 +228,8 @@ void EventMappingWidget::handleJoyAxis(int stick, int axis, int value)
|
||||||
if(myRemapStatus && myActionSelected >= 0)
|
if(myRemapStatus && myActionSelected >= 0)
|
||||||
{
|
{
|
||||||
Event::Type event =
|
Event::Type event =
|
||||||
instance()->eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
instance().eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
||||||
if(instance()->eventHandler().addJoyAxisMapping(event, myEventMode,
|
if(instance().eventHandler().addJoyAxisMapping(event, myEventMode,
|
||||||
stick, axis, value))
|
stick, axis, value))
|
||||||
stopRemapping();
|
stopRemapping();
|
||||||
}
|
}
|
||||||
|
@ -244,8 +244,8 @@ bool EventMappingWidget::handleJoyHat(int stick, int hat, int value)
|
||||||
if(myRemapStatus && myActionSelected >= 0)
|
if(myRemapStatus && myActionSelected >= 0)
|
||||||
{
|
{
|
||||||
Event::Type event =
|
Event::Type event =
|
||||||
instance()->eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
instance().eventHandler().eventAtIndex(myActionSelected, myEventMode);
|
||||||
if(instance()->eventHandler().addJoyHatMapping(event, myEventMode,
|
if(instance().eventHandler().addJoyHatMapping(event, myEventMode,
|
||||||
stick, hat, value))
|
stick, hat, value))
|
||||||
{
|
{
|
||||||
stopRemapping();
|
stopRemapping();
|
||||||
|
@ -296,7 +296,7 @@ void EventMappingWidget::handleCommand(CommandSender* sender, int cmd,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kDefaultsCmd:
|
case kDefaultsCmd:
|
||||||
instance()->eventHandler().setDefaultMapping(myEventMode);
|
instance().eventHandler().setDefaultMapping(myEventMode);
|
||||||
drawKeyMapping();
|
drawKeyMapping();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FileSnapDialog.cxx,v 1.18 2008-03-30 15:01:38 stephena Exp $
|
// $Id: FileSnapDialog.cxx,v 1.19 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -149,35 +149,35 @@ FileSnapDialog::~FileSnapDialog()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FileSnapDialog::loadConfig()
|
void FileSnapDialog::loadConfig()
|
||||||
{
|
{
|
||||||
myRomPath->setEditString(instance()->settings().getString("romdir"));
|
myRomPath->setEditString(instance().settings().getString("romdir"));
|
||||||
myStatePath->setEditString(instance()->stateDir());
|
myStatePath->setEditString(instance().stateDir());
|
||||||
myCheatFile->setEditString(instance()->cheatFile());
|
myCheatFile->setEditString(instance().cheatFile());
|
||||||
myPaletteFile->setEditString(instance()->paletteFile());
|
myPaletteFile->setEditString(instance().paletteFile());
|
||||||
myPropsFile->setEditString(instance()->propertiesFile());
|
myPropsFile->setEditString(instance().propertiesFile());
|
||||||
mySnapPath->setEditString(instance()->settings().getString("ssdir"));
|
mySnapPath->setEditString(instance().settings().getString("ssdir"));
|
||||||
mySnapSingleCheckbox->setState(!instance()->settings().getBool("sssingle"));
|
mySnapSingleCheckbox->setState(!instance().settings().getBool("sssingle"));
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FileSnapDialog::saveConfig()
|
void FileSnapDialog::saveConfig()
|
||||||
{
|
{
|
||||||
instance()->settings().setString("romdir", myRomPath->getEditString());
|
instance().settings().setString("romdir", myRomPath->getEditString());
|
||||||
instance()->settings().setString("statedir", myStatePath->getEditString());
|
instance().settings().setString("statedir", myStatePath->getEditString());
|
||||||
instance()->settings().setString("cheatfile", myCheatFile->getEditString());
|
instance().settings().setString("cheatfile", myCheatFile->getEditString());
|
||||||
instance()->settings().setString("palettefile", myPaletteFile->getEditString());
|
instance().settings().setString("palettefile", myPaletteFile->getEditString());
|
||||||
instance()->settings().setString("propsfile", myPropsFile->getEditString());
|
instance().settings().setString("propsfile", myPropsFile->getEditString());
|
||||||
instance()->settings().setString("ssdir", mySnapPath->getEditString());
|
instance().settings().setString("ssdir", mySnapPath->getEditString());
|
||||||
instance()->settings().setBool("sssingle", !mySnapSingleCheckbox->getState());
|
instance().settings().setBool("sssingle", !mySnapSingleCheckbox->getState());
|
||||||
|
|
||||||
// Flush changes to disk and inform the OSystem
|
// Flush changes to disk and inform the OSystem
|
||||||
instance()->settings().saveConfig();
|
instance().settings().saveConfig();
|
||||||
instance()->setConfigPaths();
|
instance().setConfigPaths();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FileSnapDialog::setDefaults()
|
void FileSnapDialog::setDefaults()
|
||||||
{
|
{
|
||||||
const string& basedir = instance()->baseDir();
|
const string& basedir = instance().baseDir();
|
||||||
const string& romdir = "roms";
|
const string& romdir = "roms";
|
||||||
const string& statedir = basedir + BSPF_PATH_SEPARATOR + "state";
|
const string& statedir = basedir + BSPF_PATH_SEPARATOR + "state";
|
||||||
const string& cheatfile = basedir + BSPF_PATH_SEPARATOR + "stella.cht";
|
const string& cheatfile = basedir + BSPF_PATH_SEPARATOR + "stella.cht";
|
||||||
|
@ -199,7 +199,7 @@ void FileSnapDialog::setDefaults()
|
||||||
void FileSnapDialog::openBrowser(const string& title, const string& startpath,
|
void FileSnapDialog::openBrowser(const string& title, const string& startpath,
|
||||||
FilesystemNode::ListMode mode, int cmd)
|
FilesystemNode::ListMode mode, int cmd)
|
||||||
{
|
{
|
||||||
parent()->addDialog(myBrowser);
|
parent().addDialog(myBrowser);
|
||||||
|
|
||||||
myBrowser->setTitle(title);
|
myBrowser->setTitle(title);
|
||||||
myBrowser->setEmitSignal(cmd);
|
myBrowser->setEmitSignal(cmd);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: GameInfoDialog.cxx,v 1.56 2008-05-16 12:17:23 stephena Exp $
|
// $Id: GameInfoDialog.cxx,v 1.57 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -27,6 +27,7 @@
|
||||||
#include "PopUpWidget.hxx"
|
#include "PopUpWidget.hxx"
|
||||||
#include "Props.hxx"
|
#include "Props.hxx"
|
||||||
#include "PropsSet.hxx"
|
#include "PropsSet.hxx"
|
||||||
|
#include "StringList.hxx"
|
||||||
#include "TabWidget.hxx"
|
#include "TabWidget.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
|
||||||
|
@ -49,6 +50,7 @@ GameInfoDialog::GameInfoDialog(
|
||||||
int xpos, ypos, lwidth, fwidth, pwidth, tabID;
|
int xpos, ypos, lwidth, fwidth, pwidth, tabID;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
WidgetArray wid;
|
WidgetArray wid;
|
||||||
|
StringList items;
|
||||||
|
|
||||||
// The tab widget
|
// The tab widget
|
||||||
xpos = 2; ypos = vBorder;
|
xpos = 2; ypos = vBorder;
|
||||||
|
@ -108,20 +110,22 @@ GameInfoDialog::GameInfoDialog(
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Sound:", kTextAlignLeft);
|
"Sound:", kTextAlignLeft);
|
||||||
pwidth = font.getStringWidth("Stereo");
|
pwidth = font.getStringWidth("Stereo");
|
||||||
|
items.clear();
|
||||||
|
items.push_back("Mono");
|
||||||
|
items.push_back("Stereo");
|
||||||
mySound = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
mySound = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
pwidth, lineHeight, "", 0, 0);
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
mySound->appendEntry("Mono", 1);
|
|
||||||
mySound->appendEntry("Stereo", 2);
|
|
||||||
wid.push_back(mySound);
|
wid.push_back(mySound);
|
||||||
|
|
||||||
ypos += lineHeight + 3;
|
ypos += lineHeight + 3;
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Type:", kTextAlignLeft);
|
"Type:", kTextAlignLeft);
|
||||||
pwidth = font.getStringWidth("SB (128-256k SUPERbanking)");
|
pwidth = font.getStringWidth("SB (128-256k SUPERbanking)");
|
||||||
myType = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "", 0, 0);
|
|
||||||
for(i = 0; i < kNumCartTypes; ++i)
|
for(i = 0; i < kNumCartTypes; ++i)
|
||||||
myType->appendEntry(ourCartridgeList[i][0], i+1);
|
items.push_back(ourCartridgeList[i][0]);
|
||||||
|
myType = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
wid.push_back(myType);
|
wid.push_back(myType);
|
||||||
|
|
||||||
// Add items for tab 0
|
// Add items for tab 0
|
||||||
|
@ -137,28 +141,29 @@ GameInfoDialog::GameInfoDialog(
|
||||||
pwidth = font.getStringWidth("B & W");
|
pwidth = font.getStringWidth("B & W");
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Left Difficulty:", kTextAlignLeft);
|
"Left Difficulty:", kTextAlignLeft);
|
||||||
|
items.clear();
|
||||||
|
items.push_back("B");
|
||||||
|
items.push_back("A");
|
||||||
myLeftDiff = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
myLeftDiff = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
pwidth, lineHeight, "", 0, 0);
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
myLeftDiff->appendEntry("B", 1);
|
|
||||||
myLeftDiff->appendEntry("A", 2);
|
|
||||||
wid.push_back(myLeftDiff);
|
wid.push_back(myLeftDiff);
|
||||||
|
|
||||||
ypos += lineHeight + 5;
|
ypos += lineHeight + 5;
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Right Difficulty:", kTextAlignLeft);
|
"Right Difficulty:", kTextAlignLeft);
|
||||||
|
// ... use same items as above
|
||||||
myRightDiff = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
myRightDiff = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
pwidth, lineHeight, "", 0, 0);
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
myRightDiff->appendEntry("B", 1);
|
|
||||||
myRightDiff->appendEntry("A", 2);
|
|
||||||
wid.push_back(myRightDiff);
|
wid.push_back(myRightDiff);
|
||||||
|
|
||||||
ypos += lineHeight + 5;
|
ypos += lineHeight + 5;
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"TV Type:", kTextAlignLeft);
|
"TV Type:", kTextAlignLeft);
|
||||||
|
items.clear();
|
||||||
|
items.push_back("Color");
|
||||||
|
items.push_back("B & W");
|
||||||
myTVType = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
myTVType = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
pwidth, lineHeight, "", 0, 0);
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
myTVType->appendEntry("Color", 1);
|
|
||||||
myTVType->appendEntry("B & W", 2);
|
|
||||||
wid.push_back(myTVType);
|
wid.push_back(myTVType);
|
||||||
|
|
||||||
// Add items for tab 1
|
// Add items for tab 1
|
||||||
|
@ -174,49 +179,54 @@ GameInfoDialog::GameInfoDialog(
|
||||||
pwidth = font.getStringWidth("CX-22 Trakball");
|
pwidth = font.getStringWidth("CX-22 Trakball");
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"P0 Controller:", kTextAlignLeft);
|
"P0 Controller:", kTextAlignLeft);
|
||||||
myP0Controller = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "", 0, 0);
|
|
||||||
for(i = 0; i < kNumControllerTypes; ++i)
|
for(i = 0; i < kNumControllerTypes; ++i)
|
||||||
myP0Controller->appendEntry(ourControllerList[i][0], i+1);
|
items.push_back(ourControllerList[i][0]);
|
||||||
|
myP0Controller = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
wid.push_back(myP0Controller);
|
wid.push_back(myP0Controller);
|
||||||
|
|
||||||
xpos += lwidth+myP0Controller->getWidth() + 4;
|
xpos += lwidth+myP0Controller->getWidth() + 4;
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, font.getStringWidth("in "),
|
new StaticTextWidget(myTab, font, xpos, ypos+1, font.getStringWidth("in "),
|
||||||
fontHeight, "in ", kTextAlignLeft);
|
fontHeight, "in ", kTextAlignLeft);
|
||||||
xpos += font.getStringWidth("in ");
|
xpos += font.getStringWidth("in ");
|
||||||
|
items.clear();
|
||||||
|
items.push_back("left port");
|
||||||
|
items.push_back("right port");
|
||||||
myLeftPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
myLeftPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
||||||
"", 0, kLeftCChanged);
|
items, "", 0, kLeftCChanged);
|
||||||
myLeftPort->appendEntry("left port", 1);
|
|
||||||
myLeftPort->appendEntry("right port", 2);
|
|
||||||
wid.push_back(myLeftPort);
|
wid.push_back(myLeftPort);
|
||||||
|
|
||||||
xpos = 10; ypos += lineHeight + 5;
|
xpos = 10; ypos += lineHeight + 5;
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"P1 Controller:", kTextAlignLeft);
|
"P1 Controller:", kTextAlignLeft);
|
||||||
myP1Controller = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "", 0, 0);
|
|
||||||
for(i = 0; i < kNumControllerTypes; ++i)
|
for(i = 0; i < kNumControllerTypes; ++i)
|
||||||
myP1Controller->appendEntry(ourControllerList[i][0], i+1);
|
items.push_back(ourControllerList[i][0]);
|
||||||
|
myP1Controller = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
wid.push_back(myP1Controller);
|
wid.push_back(myP1Controller);
|
||||||
|
|
||||||
xpos += lwidth+myP1Controller->getWidth() + 4;
|
xpos += lwidth+myP1Controller->getWidth() + 4;
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, font.getStringWidth("in "),
|
new StaticTextWidget(myTab, font, xpos, ypos+1, font.getStringWidth("in "),
|
||||||
fontHeight, "in ", kTextAlignLeft);
|
fontHeight, "in ", kTextAlignLeft);
|
||||||
xpos += font.getStringWidth("in ");
|
xpos += font.getStringWidth("in ");
|
||||||
|
items.clear();
|
||||||
|
items.push_back("left port");
|
||||||
|
items.push_back("right port");
|
||||||
myRightPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
myRightPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
||||||
"", 0, kRightCChanged);
|
items, "", 0, kRightCChanged);
|
||||||
myRightPort->appendEntry("left port", 1);
|
|
||||||
myRightPort->appendEntry("right port", 2);
|
|
||||||
wid.push_back(myRightPort);
|
wid.push_back(myRightPort);
|
||||||
|
|
||||||
xpos = 10; ypos += lineHeight + 5;
|
xpos = 10; ypos += lineHeight + 5;
|
||||||
pwidth = font.getStringWidth("Yes");
|
pwidth = font.getStringWidth("Yes");
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Swap Paddles:", kTextAlignLeft);
|
"Swap Paddles:", kTextAlignLeft);
|
||||||
|
items.clear();
|
||||||
|
items.push_back("Yes");
|
||||||
|
items.push_back("No");
|
||||||
mySwapPaddles = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
mySwapPaddles = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
pwidth, lineHeight, "", 0, 0);
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
mySwapPaddles->appendEntry("Yes", 1);
|
|
||||||
mySwapPaddles->appendEntry("No", 2);
|
|
||||||
wid.push_back(mySwapPaddles);
|
wid.push_back(mySwapPaddles);
|
||||||
|
|
||||||
|
|
||||||
|
@ -233,16 +243,16 @@ GameInfoDialog::GameInfoDialog(
|
||||||
pwidth = font.getStringWidth("Auto-detect");
|
pwidth = font.getStringWidth("Auto-detect");
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Format:", kTextAlignLeft);
|
"Format:", kTextAlignLeft);
|
||||||
|
items.clear();
|
||||||
|
items.push_back("Auto-detect");
|
||||||
|
items.push_back("NTSC");
|
||||||
|
items.push_back("PAL");
|
||||||
|
items.push_back("SECAM");
|
||||||
|
items.push_back("NTSC50");
|
||||||
|
items.push_back("PAL60");
|
||||||
|
items.push_back("SECAM60");
|
||||||
myFormat = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
myFormat = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
||||||
pwidth, lineHeight, "", 0, 0);
|
pwidth, lineHeight, items, "", 0, 0);
|
||||||
myFormat->appendEntry("Auto-detect", 1);
|
|
||||||
myFormat->appendEntry("NTSC", 2);
|
|
||||||
myFormat->appendEntry("PAL", 3);
|
|
||||||
myFormat->appendEntry("SECAM", 4);
|
|
||||||
myFormat->appendEntry("NTSC50", 5);
|
|
||||||
myFormat->appendEntry("PAL60", 6);
|
|
||||||
myFormat->appendEntry("SECAM60", 7);
|
|
||||||
|
|
||||||
wid.push_back(myFormat);
|
wid.push_back(myFormat);
|
||||||
|
|
||||||
ypos += lineHeight + 5;
|
ypos += lineHeight + 5;
|
||||||
|
@ -263,10 +273,11 @@ GameInfoDialog::GameInfoDialog(
|
||||||
pwidth = font.getStringWidth("Yes");
|
pwidth = font.getStringWidth("Yes");
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Use Phosphor:", kTextAlignLeft);
|
"Use Phosphor:", kTextAlignLeft);
|
||||||
myPhosphor = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "", 0, kPhosphorChanged);
|
items.push_back("Yes");
|
||||||
myPhosphor->appendEntry("Yes", 1);
|
items.push_back("No");
|
||||||
myPhosphor->appendEntry("No", 2);
|
myPhosphor = new PopUpWidget(myTab, font, xpos+lwidth, ypos, pwidth,
|
||||||
|
lineHeight, items, "", 0, kPhosphorChanged);
|
||||||
wid.push_back(myPhosphor);
|
wid.push_back(myPhosphor);
|
||||||
|
|
||||||
myPPBlend = new SliderWidget(myTab, font, xpos + lwidth + myPhosphor->getWidth() + 10,
|
myPPBlend = new SliderWidget(myTab, font, xpos + lwidth + myPhosphor->getWidth() + 10,
|
||||||
|
@ -285,10 +296,11 @@ GameInfoDialog::GameInfoDialog(
|
||||||
ypos += lineHeight + 5;
|
ypos += lineHeight + 5;
|
||||||
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
new StaticTextWidget(myTab, font, xpos, ypos+1, lwidth, fontHeight,
|
||||||
"Use HMBlanks:", kTextAlignLeft);
|
"Use HMBlanks:", kTextAlignLeft);
|
||||||
myHmoveBlanks = new PopUpWidget(myTab, font, xpos+lwidth, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "", 0, 0);
|
items.push_back("Yes");
|
||||||
myHmoveBlanks->appendEntry("Yes", 1);
|
items.push_back("No");
|
||||||
myHmoveBlanks->appendEntry("No", 2);
|
myHmoveBlanks = new PopUpWidget(myTab, font, xpos+lwidth, ypos, pwidth,
|
||||||
|
lineHeight, items, "", 0, 0);
|
||||||
wid.push_back(myHmoveBlanks);
|
wid.push_back(myHmoveBlanks);
|
||||||
|
|
||||||
// Add items for tab 3
|
// Add items for tab 3
|
||||||
|
@ -322,21 +334,22 @@ GameInfoDialog::~GameInfoDialog()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void GameInfoDialog::loadConfig()
|
void GameInfoDialog::loadConfig()
|
||||||
{
|
{
|
||||||
|
// FIXME - check comparisons
|
||||||
myPropertiesLoaded = false;
|
myPropertiesLoaded = false;
|
||||||
myDefaultsSelected = false;
|
myDefaultsSelected = false;
|
||||||
|
|
||||||
if(&myOSystem->console())
|
if(&instance().console())
|
||||||
{
|
{
|
||||||
myGameProperties = myOSystem->console().properties();
|
myGameProperties = instance().console().properties();
|
||||||
myPropertiesLoaded = true;
|
myPropertiesLoaded = true;
|
||||||
loadView();
|
loadView();
|
||||||
}
|
}
|
||||||
else if(&myOSystem->launcher())
|
else if(&instance().launcher())
|
||||||
{
|
{
|
||||||
const string& md5 = myOSystem->launcher().selectedRomMD5();
|
const string& md5 = instance().launcher().selectedRomMD5();
|
||||||
if(md5 != "")
|
if(md5 != "")
|
||||||
{
|
{
|
||||||
instance()->propSet().getMD5(md5, myGameProperties);
|
instance().propSet().getMD5(md5, myGameProperties);
|
||||||
myPropertiesLoaded = true;
|
myPropertiesLoaded = true;
|
||||||
loadView();
|
loadView();
|
||||||
}
|
}
|
||||||
|
@ -372,96 +385,75 @@ void GameInfoDialog::loadView()
|
||||||
myNote->setEditString(s);
|
myNote->setEditString(s);
|
||||||
|
|
||||||
s = myGameProperties.get(Cartridge_Sound);
|
s = myGameProperties.get(Cartridge_Sound);
|
||||||
if(s == "MONO")
|
mySound->clearSelection();
|
||||||
mySound->setSelectedTag(1);
|
if(s == "MONO") mySound->setSelected(0);
|
||||||
else if(s == "STEREO")
|
else if(s == "STEREO") mySound->setSelected(1);
|
||||||
mySound->setSelectedTag(2);
|
|
||||||
else
|
|
||||||
mySound->setSelectedTag(0);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Cartridge_Type);
|
s = myGameProperties.get(Cartridge_Type);
|
||||||
|
myType->clearSelection();
|
||||||
for(i = 0; i < kNumCartTypes; ++i)
|
for(i = 0; i < kNumCartTypes; ++i)
|
||||||
{
|
{
|
||||||
if(s == ourCartridgeList[i][1])
|
if(s == ourCartridgeList[i][1])
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
i = (i == kNumCartTypes) ? 0: i + 1;
|
myType->setSelected(i);
|
||||||
myType->setSelectedTag(i);
|
|
||||||
|
|
||||||
// Console properties
|
// Console properties
|
||||||
s = myGameProperties.get(Console_LeftDifficulty);
|
s = myGameProperties.get(Console_LeftDifficulty);
|
||||||
if(s == "B")
|
myLeftDiff->clearSelection();
|
||||||
myLeftDiff->setSelectedTag(1);
|
if(s == "B") myLeftDiff->setSelected(0);
|
||||||
else if(s == "A")
|
else if(s == "A") myLeftDiff->setSelected(1);
|
||||||
myLeftDiff->setSelectedTag(2);
|
|
||||||
else
|
|
||||||
myLeftDiff->setSelectedTag(0);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Console_RightDifficulty);
|
s = myGameProperties.get(Console_RightDifficulty);
|
||||||
if(s == "B")
|
myRightDiff->clearSelection();
|
||||||
myRightDiff->setSelectedTag(1);
|
if(s == "B") myRightDiff->setSelected(0);
|
||||||
else if(s == "A")
|
else if(s == "A") myRightDiff->setSelected(1);
|
||||||
myRightDiff->setSelectedTag(2);
|
|
||||||
else
|
|
||||||
myRightDiff->setSelectedTag(0);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Console_TelevisionType);
|
s = myGameProperties.get(Console_TelevisionType);
|
||||||
if(s == "COLOR")
|
myTVType->clearSelection();
|
||||||
myTVType->setSelectedTag(1);
|
if(s == "COLOR") myTVType->setSelected(0);
|
||||||
else if(s == "BLACKANDWHITE")
|
else if(s == "BLACKANDWHITE") myTVType->setSelected(1);
|
||||||
myTVType->setSelectedTag(2);
|
|
||||||
else
|
|
||||||
myTVType->setSelectedTag(0);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Console_SwapPorts);
|
s = myGameProperties.get(Console_SwapPorts);
|
||||||
myLeftPort->setSelectedTag(s == "NO" ? 1 : 2);
|
myLeftPort->clearSelection();
|
||||||
myRightPort->setSelectedTag(s == "NO" ? 2 : 1);
|
myRightPort->clearSelection();
|
||||||
|
myLeftPort->setSelected(s == "NO" ? 0 : 1);
|
||||||
|
myRightPort->setSelected(s == "NO" ? 1 : 0);
|
||||||
|
|
||||||
// Controller properties
|
// Controller properties
|
||||||
s = myGameProperties.get(Controller_Left);
|
s = myGameProperties.get(Controller_Left);
|
||||||
|
myP0Controller->clearSelection();
|
||||||
for(i = 0; i < kNumControllerTypes; ++i)
|
for(i = 0; i < kNumControllerTypes; ++i)
|
||||||
{
|
{
|
||||||
if(s == ourControllerList[i][1])
|
if(s == ourControllerList[i][1])
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
i = (i == kNumControllerTypes) ? 0: i + 1;
|
myP0Controller->setSelected(i);
|
||||||
myP0Controller->setSelectedTag(i);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Controller_Right);
|
s = myGameProperties.get(Controller_Right);
|
||||||
|
myP1Controller->clearSelection();
|
||||||
for(i = 0; i < kNumControllerTypes; ++i)
|
for(i = 0; i < kNumControllerTypes; ++i)
|
||||||
{
|
{
|
||||||
if(s == ourControllerList[i][1])
|
if(s == ourControllerList[i][1])
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
i = (i == kNumControllerTypes) ? 0: i + 1;
|
myP1Controller->setSelected(i);
|
||||||
myP1Controller->setSelectedTag(i);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Controller_SwapPaddles);
|
s = myGameProperties.get(Controller_SwapPaddles);
|
||||||
if(s == "YES")
|
mySwapPaddles->clearSelection();
|
||||||
mySwapPaddles->setSelectedTag(1);
|
if(s == "YES") mySwapPaddles->setSelected(0);
|
||||||
else if(s == "NO")
|
else if(s == "NO") mySwapPaddles->setSelected(1);
|
||||||
mySwapPaddles->setSelectedTag(2);
|
|
||||||
else
|
|
||||||
mySwapPaddles->setSelectedTag(0);
|
|
||||||
|
|
||||||
// Display properties
|
// Display properties
|
||||||
s = myGameProperties.get(Display_Format);
|
s = myGameProperties.get(Display_Format);
|
||||||
if(s == "AUTO-DETECT")
|
myFormat->clearSelection();
|
||||||
myFormat->setSelectedTag(1);
|
if(s == "AUTO-DETECT") myFormat->setSelected(0);
|
||||||
else if(s == "NTSC")
|
else if(s == "NTSC") myFormat->setSelected(1);
|
||||||
myFormat->setSelectedTag(2);
|
else if(s == "PAL") myFormat->setSelected(2);
|
||||||
else if(s == "PAL")
|
else if(s == "SECAM") myFormat->setSelected(3);
|
||||||
myFormat->setSelectedTag(3);
|
else if(s == "NTSC50") myFormat->setSelected(4);
|
||||||
else if(s == "SECAM")
|
else if(s == "PAL60") myFormat->setSelected(5);
|
||||||
myFormat->setSelectedTag(4);
|
else if(s == "SECAM60") myFormat->setSelected(6);
|
||||||
else if(s == "NTSC50")
|
|
||||||
myFormat->setSelectedTag(5);
|
|
||||||
else if(s == "PAL60")
|
|
||||||
myFormat->setSelectedTag(6);
|
|
||||||
else if(s == "SECAM60")
|
|
||||||
myFormat->setSelectedTag(7);
|
|
||||||
else
|
|
||||||
myFormat->setSelectedTag(0);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Display_YStart);
|
s = myGameProperties.get(Display_YStart);
|
||||||
myYStart->setEditString(s);
|
myYStart->setEditString(s);
|
||||||
|
@ -469,31 +461,27 @@ void GameInfoDialog::loadView()
|
||||||
s = myGameProperties.get(Display_Height);
|
s = myGameProperties.get(Display_Height);
|
||||||
myHeight->setEditString(s);
|
myHeight->setEditString(s);
|
||||||
|
|
||||||
|
s = myGameProperties.get(Display_Phosphor);
|
||||||
|
myPhosphor->clearSelection();
|
||||||
myPPBlend->setEnabled(false);
|
myPPBlend->setEnabled(false);
|
||||||
myPPBlendLabel->setEnabled(false);
|
myPPBlendLabel->setEnabled(false);
|
||||||
s = myGameProperties.get(Display_Phosphor);
|
|
||||||
if(s == "YES")
|
if(s == "YES")
|
||||||
{
|
{
|
||||||
myPhosphor->setSelectedTag(1);
|
myPhosphor->setSelected(0);
|
||||||
myPPBlend->setEnabled(true);
|
myPPBlend->setEnabled(true);
|
||||||
myPPBlendLabel->setEnabled(true);
|
myPPBlendLabel->setEnabled(true);
|
||||||
}
|
}
|
||||||
else if(s == "NO")
|
else if(s == "NO")
|
||||||
myPhosphor->setSelectedTag(2);
|
myPhosphor->setSelected(1);
|
||||||
else
|
|
||||||
myPhosphor->setSelectedTag(0);
|
|
||||||
|
|
||||||
s = myGameProperties.get(Display_PPBlend);
|
s = myGameProperties.get(Display_PPBlend);
|
||||||
myPPBlend->setValue(atoi(s.c_str()));
|
myPPBlend->setValue(atoi(s.c_str()));
|
||||||
myPPBlendLabel->setLabel(s);
|
myPPBlendLabel->setLabel(s);
|
||||||
|
|
||||||
s = myGameProperties.get(Emulation_HmoveBlanks);
|
s = myGameProperties.get(Emulation_HmoveBlanks);
|
||||||
if(s == "YES")
|
myHmoveBlanks->clearSelection();
|
||||||
myHmoveBlanks->setSelectedTag(1);
|
if(s == "YES") myHmoveBlanks->setSelected(0);
|
||||||
else if(s == "NO")
|
else if(s == "NO") myHmoveBlanks->setSelected(1);
|
||||||
myHmoveBlanks->setSelectedTag(2);
|
|
||||||
else
|
|
||||||
myHmoveBlanks->setSelectedTag(0);
|
|
||||||
|
|
||||||
myTab->loadConfig();
|
myTab->loadConfig();
|
||||||
}
|
}
|
||||||
|
@ -523,14 +511,14 @@ void GameInfoDialog::saveConfig()
|
||||||
s = myNote->getEditString();
|
s = myNote->getEditString();
|
||||||
myGameProperties.set(Cartridge_Note, s);
|
myGameProperties.set(Cartridge_Note, s);
|
||||||
|
|
||||||
tag = mySound->getSelectedTag();
|
tag = mySound->getSelected();
|
||||||
s = (tag == 1) ? "Mono" : "Stereo";
|
s = (tag == 0) ? "Mono" : "Stereo";
|
||||||
myGameProperties.set(Cartridge_Sound, s);
|
myGameProperties.set(Cartridge_Sound, s);
|
||||||
|
|
||||||
tag = myType->getSelectedTag();
|
tag = myType->getSelected();
|
||||||
for(i = 0; i < kNumCartTypes; ++i)
|
for(i = 0; i < kNumCartTypes; ++i)
|
||||||
{
|
{
|
||||||
if(i == tag-1)
|
if(i == tag)
|
||||||
{
|
{
|
||||||
myGameProperties.set(Cartridge_Type, ourCartridgeList[i][1]);
|
myGameProperties.set(Cartridge_Type, ourCartridgeList[i][1]);
|
||||||
break;
|
break;
|
||||||
|
@ -538,52 +526,49 @@ void GameInfoDialog::saveConfig()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Console properties
|
// Console properties
|
||||||
tag = myLeftDiff->getSelectedTag();
|
tag = myLeftDiff->getSelected();
|
||||||
s = (tag == 1) ? "B" : "A";
|
s = (tag == 0) ? "B" : "A";
|
||||||
myGameProperties.set(Console_LeftDifficulty, s);
|
myGameProperties.set(Console_LeftDifficulty, s);
|
||||||
|
|
||||||
tag = myRightDiff->getSelectedTag();
|
tag = myRightDiff->getSelected();
|
||||||
s = (tag == 1) ? "B" : "A";
|
s = (tag == 0) ? "B" : "A";
|
||||||
myGameProperties.set(Console_RightDifficulty, s);
|
myGameProperties.set(Console_RightDifficulty, s);
|
||||||
|
|
||||||
tag = myTVType->getSelectedTag();
|
tag = myTVType->getSelected();
|
||||||
s = (tag == 1) ? "Color" : "BlackAndWhite";
|
s = (tag == 0) ? "Color" : "BlackAndWhite";
|
||||||
myGameProperties.set(Console_TelevisionType, s);
|
myGameProperties.set(Console_TelevisionType, s);
|
||||||
|
|
||||||
// Controller properties
|
// Controller properties
|
||||||
tag = myP0Controller->getSelectedTag();
|
tag = myP0Controller->getSelected();
|
||||||
for(i = 0; i < kNumControllerTypes; ++i)
|
for(i = 0; i < kNumControllerTypes; ++i)
|
||||||
{
|
{
|
||||||
if(i == tag-1)
|
if(i == tag)
|
||||||
{
|
{
|
||||||
myGameProperties.set(Controller_Left, ourControllerList[i][1]);
|
myGameProperties.set(Controller_Left, ourControllerList[i][1]);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag = myP1Controller->getSelectedTag();
|
tag = myP1Controller->getSelected();
|
||||||
for(i = 0; i < kNumControllerTypes; ++i)
|
for(i = 0; i < kNumControllerTypes; ++i)
|
||||||
{
|
{
|
||||||
if(i == tag-1)
|
if(i == tag)
|
||||||
{
|
{
|
||||||
myGameProperties.set(Controller_Right, ourControllerList[i][1]);
|
myGameProperties.set(Controller_Right, ourControllerList[i][1]);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tag = myLeftPort->getSelectedTag();
|
tag = myLeftPort->getSelected();
|
||||||
s = (tag == 1) ? "No" : "Yes";
|
s = (tag == 0) ? "No" : "Yes";
|
||||||
myGameProperties.set(Console_SwapPorts, s);
|
myGameProperties.set(Console_SwapPorts, s);
|
||||||
|
|
||||||
tag = mySwapPaddles->getSelectedTag();
|
tag = mySwapPaddles->getSelected();
|
||||||
s = (tag == 1) ? "Yes" : "No";
|
s = (tag == 0) ? "Yes" : "No";
|
||||||
myGameProperties.set(Controller_SwapPaddles, s);
|
myGameProperties.set(Controller_SwapPaddles, s);
|
||||||
|
|
||||||
// Display properties
|
// Display properties
|
||||||
tag = myFormat->getSelectedTag();
|
s = myFormat->getSelectedString(); // use string directly
|
||||||
s = (tag == 7) ? "SECAM60" : (tag == 6) ? "PAL60" : (tag == 5) ? "NTSC50" :
|
|
||||||
(tag == 4) ? "SECAM" : (tag == 3) ? "PAL" : (tag == 2) ? "NTSC" :
|
|
||||||
"AUTO-DETECT";
|
|
||||||
myGameProperties.set(Display_Format, s);
|
myGameProperties.set(Display_Format, s);
|
||||||
|
|
||||||
s = myYStart->getEditString();
|
s = myYStart->getEditString();
|
||||||
|
@ -592,27 +577,27 @@ void GameInfoDialog::saveConfig()
|
||||||
s = myHeight->getEditString();
|
s = myHeight->getEditString();
|
||||||
myGameProperties.set(Display_Height, s);
|
myGameProperties.set(Display_Height, s);
|
||||||
|
|
||||||
tag = myPhosphor->getSelectedTag();
|
tag = myPhosphor->getSelected();
|
||||||
s = (tag == 1) ? "Yes" : "No";
|
s = (tag == 0) ? "Yes" : "No";
|
||||||
myGameProperties.set(Display_Phosphor, s);
|
myGameProperties.set(Display_Phosphor, s);
|
||||||
|
|
||||||
s = myPPBlendLabel->getLabel();
|
s = myPPBlendLabel->getLabel();
|
||||||
myGameProperties.set(Display_PPBlend, s);
|
myGameProperties.set(Display_PPBlend, s);
|
||||||
|
|
||||||
tag = myHmoveBlanks->getSelectedTag();
|
tag = myHmoveBlanks->getSelected();
|
||||||
s = (tag == 1) ? "Yes" : "No";
|
s = (tag == 0) ? "Yes" : "No";
|
||||||
myGameProperties.set(Emulation_HmoveBlanks, s);
|
myGameProperties.set(Emulation_HmoveBlanks, s);
|
||||||
|
|
||||||
// Determine whether to add or remove an entry from the properties set
|
// Determine whether to add or remove an entry from the properties set
|
||||||
if(myDefaultsSelected)
|
if(myDefaultsSelected)
|
||||||
instance()->propSet().removeMD5(myGameProperties.get(Cartridge_MD5));
|
instance().propSet().removeMD5(myGameProperties.get(Cartridge_MD5));
|
||||||
else
|
else
|
||||||
instance()->propSet().insert(myGameProperties, true);
|
instance().propSet().insert(myGameProperties, true);
|
||||||
|
|
||||||
// In any event, inform the Console and save the properties
|
// In any event, inform the Console and save the properties
|
||||||
if(&myOSystem->console())
|
if(&instance().console())
|
||||||
instance()->console().setProperties(myGameProperties);
|
instance().console().setProperties(myGameProperties);
|
||||||
instance()->propSet().save(myOSystem->propertiesFile());
|
instance().propSet().save(instance().propertiesFile());
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -620,7 +605,7 @@ void GameInfoDialog::setDefaults()
|
||||||
{
|
{
|
||||||
// Load the default properties
|
// Load the default properties
|
||||||
string md5 = myGameProperties.get(Cartridge_MD5);
|
string md5 = myGameProperties.get(Cartridge_MD5);
|
||||||
instance()->propSet().getMD5(md5, myGameProperties, true);
|
instance().propSet().getMD5(md5, myGameProperties, true);
|
||||||
|
|
||||||
// Reload the current dialog
|
// Reload the current dialog
|
||||||
loadView();
|
loadView();
|
||||||
|
@ -643,18 +628,18 @@ void GameInfoDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kLeftCChanged:
|
case kLeftCChanged:
|
||||||
myRightPort->setSelectedTag(
|
myRightPort->setSelected(
|
||||||
myLeftPort->getSelectedTag() == 2 ? 1 : 2);
|
myLeftPort->getSelected() == 1 ? 0 : 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kRightCChanged:
|
case kRightCChanged:
|
||||||
myLeftPort->setSelectedTag(
|
myLeftPort->setSelected(
|
||||||
myRightPort->getSelectedTag() == 2 ? 1 : 2);
|
myRightPort->getSelected() == 1 ? 0 : 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kPhosphorChanged:
|
case kPhosphorChanged:
|
||||||
{
|
{
|
||||||
bool status = myPhosphor->getSelectedTag() == 1 ? true : false;
|
bool status = myPhosphor->getSelected() == 0 ? true : false;
|
||||||
myPPBlend->setEnabled(status);
|
myPPBlend->setEnabled(status);
|
||||||
myPPBlendLabel->setEnabled(status);
|
myPPBlendLabel->setEnabled(status);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: GuiObject.hxx,v 1.24 2008-02-06 13:45:23 stephena Exp $
|
// $Id: GuiObject.hxx,v 1.25 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -22,6 +22,7 @@
|
||||||
#ifndef GUI_OBJECT_HXX
|
#ifndef GUI_OBJECT_HXX
|
||||||
#define GUI_OBJECT_HXX
|
#define GUI_OBJECT_HXX
|
||||||
|
|
||||||
|
class Dialog;
|
||||||
class DialogContainer;
|
class DialogContainer;
|
||||||
class Widget;
|
class Widget;
|
||||||
|
|
||||||
|
@ -54,7 +55,7 @@ enum {
|
||||||
This is the base class for all GUI objects/widgets.
|
This is the base class for all GUI objects/widgets.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: GuiObject.hxx,v 1.24 2008-02-06 13:45:23 stephena Exp $
|
@version $Id: GuiObject.hxx,v 1.25 2008-06-13 13:14:51 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class GuiObject : public CommandReceiver
|
class GuiObject : public CommandReceiver
|
||||||
{
|
{
|
||||||
|
@ -62,9 +63,11 @@ class GuiObject : public CommandReceiver
|
||||||
friend class DialogContainer;
|
friend class DialogContainer;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
GuiObject(OSystem* osystem, DialogContainer* parent, int x, int y, int w, int h)
|
GuiObject(OSystem& osystem, DialogContainer& parent, Dialog& dialog,
|
||||||
|
int x, int y, int w, int h)
|
||||||
: myOSystem(osystem),
|
: myOSystem(osystem),
|
||||||
myParent(parent),
|
myParent(parent),
|
||||||
|
myDialog(dialog),
|
||||||
_x(x),
|
_x(x),
|
||||||
_y(y),
|
_y(y),
|
||||||
_w(w),
|
_w(w),
|
||||||
|
@ -74,8 +77,9 @@ class GuiObject : public CommandReceiver
|
||||||
|
|
||||||
virtual ~GuiObject() {}
|
virtual ~GuiObject() {}
|
||||||
|
|
||||||
OSystem* instance() { return myOSystem; }
|
OSystem& instance() { return myOSystem; }
|
||||||
DialogContainer* parent() { return myParent; }
|
DialogContainer& parent() { return myParent; }
|
||||||
|
Dialog& dialog() { return myDialog; }
|
||||||
|
|
||||||
virtual int getAbsX() const { return _x; }
|
virtual int getAbsX() const { return _x; }
|
||||||
virtual int getAbsY() const { return _y; }
|
virtual int getAbsY() const { return _y; }
|
||||||
|
@ -84,7 +88,6 @@ class GuiObject : public CommandReceiver
|
||||||
virtual int getWidth() const { return _w; }
|
virtual int getWidth() const { return _w; }
|
||||||
virtual int getHeight() const { return _h; }
|
virtual int getHeight() const { return _h; }
|
||||||
|
|
||||||
virtual void setPos(int x, int y) { _x = x; _y = y; }
|
|
||||||
virtual void setWidth(int w) { _w = w; }
|
virtual void setWidth(int w) { _w = w; }
|
||||||
virtual void setHeight(int h) { _h = h; }
|
virtual void setHeight(int h) { _h = h; }
|
||||||
|
|
||||||
|
@ -105,10 +108,12 @@ class GuiObject : public CommandReceiver
|
||||||
protected:
|
protected:
|
||||||
virtual void releaseFocus() = 0;
|
virtual void releaseFocus() = 0;
|
||||||
|
|
||||||
protected:
|
private:
|
||||||
OSystem* myOSystem;
|
OSystem& myOSystem;
|
||||||
DialogContainer* myParent;
|
DialogContainer& myParent;
|
||||||
|
Dialog& myDialog;
|
||||||
|
|
||||||
|
protected:
|
||||||
int _x, _y;
|
int _x, _y;
|
||||||
int _w, _h;
|
int _w, _h;
|
||||||
bool _dirty;
|
bool _dirty;
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: InputDialog.cxx,v 1.32 2008-05-11 21:18:35 stephena Exp $
|
// $Id: InputDialog.cxx,v 1.33 2008-06-13 13:14:51 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
@ -23,6 +23,7 @@
|
||||||
#include "Joystick.hxx"
|
#include "Joystick.hxx"
|
||||||
#include "Paddles.hxx"
|
#include "Paddles.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
|
#include "StringList.hxx"
|
||||||
#include "EventMappingWidget.hxx"
|
#include "EventMappingWidget.hxx"
|
||||||
#include "EditTextWidget.hxx"
|
#include "EditTextWidget.hxx"
|
||||||
#include "PopUpWidget.hxx"
|
#include "PopUpWidget.hxx"
|
||||||
|
@ -55,7 +56,7 @@ InputDialog::InputDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
|
|
||||||
// 1) Event mapper for emulation actions
|
// 1) Event mapper for emulation actions
|
||||||
tabID = myTab->addTab("Emul. Events");
|
tabID = myTab->addTab("Emul. Events");
|
||||||
const StringList& eactions = instance()->eventHandler().getActionList(kEmulationMode);
|
const StringList& eactions = instance().eventHandler().getActionList(kEmulationMode);
|
||||||
myEmulEventMapper = new EventMappingWidget(myTab, font, 2, 2,
|
myEmulEventMapper = new EventMappingWidget(myTab, font, 2, 2,
|
||||||
myTab->getWidth(),
|
myTab->getWidth(),
|
||||||
myTab->getHeight() - ypos,
|
myTab->getHeight() - ypos,
|
||||||
|
@ -65,7 +66,7 @@ InputDialog::InputDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
|
|
||||||
// 2) Event mapper for UI actions
|
// 2) Event mapper for UI actions
|
||||||
tabID = myTab->addTab("UI Events");
|
tabID = myTab->addTab("UI Events");
|
||||||
const StringList& mactions = instance()->eventHandler().getActionList(kMenuMode);
|
const StringList& mactions = instance().eventHandler().getActionList(kMenuMode);
|
||||||
myMenuEventMapper = new EventMappingWidget(myTab, font, 2, 2,
|
myMenuEventMapper = new EventMappingWidget(myTab, font, 2, 2,
|
||||||
myTab->getWidth(),
|
myTab->getWidth(),
|
||||||
myTab->getHeight() - ypos,
|
myTab->getHeight() - ypos,
|
||||||
|
@ -98,6 +99,7 @@ void InputDialog::addVDeviceTab(const GUI::Font& font)
|
||||||
fontHeight = font.getFontHeight();
|
fontHeight = font.getFontHeight();
|
||||||
int xpos, ypos, lwidth, pwidth, tabID;
|
int xpos, ypos, lwidth, pwidth, tabID;
|
||||||
WidgetArray wid;
|
WidgetArray wid;
|
||||||
|
StringList items;
|
||||||
|
|
||||||
// Virtual device/ports
|
// Virtual device/ports
|
||||||
tabID = myTab->addTab("Virtual Devs");
|
tabID = myTab->addTab("Virtual Devs");
|
||||||
|
@ -107,17 +109,17 @@ void InputDialog::addVDeviceTab(const GUI::Font& font)
|
||||||
lwidth = font.getStringWidth("Stelladaptor 2 is: ");
|
lwidth = font.getStringWidth("Stelladaptor 2 is: ");
|
||||||
pwidth = font.getStringWidth("right virtual port");
|
pwidth = font.getStringWidth("right virtual port");
|
||||||
|
|
||||||
myLeftPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
items.clear();
|
||||||
|
items.push_back("left virtual port");
|
||||||
|
items.push_back("right virtual port");
|
||||||
|
myLeftPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight, items,
|
||||||
"Stelladaptor 1 is: ", lwidth, kLeftChanged);
|
"Stelladaptor 1 is: ", lwidth, kLeftChanged);
|
||||||
myLeftPort->appendEntry("left virtual port", 1);
|
|
||||||
myLeftPort->appendEntry("right virtual port", 2);
|
|
||||||
wid.push_back(myLeftPort);
|
wid.push_back(myLeftPort);
|
||||||
|
|
||||||
ypos += lineHeight + 5;
|
ypos += lineHeight + 5;
|
||||||
myRightPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
// ... use items from above
|
||||||
|
myRightPort = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight, items,
|
||||||
"Stelladaptor 2 is: ", lwidth, kRightChanged);
|
"Stelladaptor 2 is: ", lwidth, kRightChanged);
|
||||||
myRightPort->appendEntry("left virtual port", 1);
|
|
||||||
myRightPort->appendEntry("right virtual port", 2);
|
|
||||||
wid.push_back(myRightPort);
|
wid.push_back(myRightPort);
|
||||||
|
|
||||||
lwidth = font.getStringWidth("Paddle threshold: ");
|
lwidth = font.getStringWidth("Paddle threshold: ");
|
||||||
|
@ -174,27 +176,27 @@ void InputDialog::addVDeviceTab(const GUI::Font& font)
|
||||||
void InputDialog::loadConfig()
|
void InputDialog::loadConfig()
|
||||||
{
|
{
|
||||||
// Left & right ports
|
// Left & right ports
|
||||||
const string& sa1 = instance()->settings().getString("sa1");
|
const string& sa1 = instance().settings().getString("sa1");
|
||||||
int lport = sa1 == "right" ? 2 : 1;
|
int lport = sa1 == "right" ? 1 : 0;
|
||||||
myLeftPort->setSelectedTag(lport);
|
myLeftPort->setSelected(lport);
|
||||||
const string& sa2 = instance()->settings().getString("sa2");
|
const string& sa2 = instance().settings().getString("sa2");
|
||||||
int rport = sa2 == "right" ? 2 : 1;
|
int rport = sa2 == "right" ? 1 : 0;
|
||||||
myRightPort->setSelectedTag(rport);
|
myRightPort->setSelected(rport);
|
||||||
|
|
||||||
// Joystick deadzone
|
// Joystick deadzone
|
||||||
myDeadzone->setValue(instance()->settings().getInt("joydeadzone"));
|
myDeadzone->setValue(instance().settings().getInt("joydeadzone"));
|
||||||
myDeadzoneLabel->setLabel(instance()->settings().getString("joydeadzone"));
|
myDeadzoneLabel->setLabel(instance().settings().getString("joydeadzone"));
|
||||||
|
|
||||||
// Paddle mode
|
// Paddle mode
|
||||||
myPaddleMode->setValue(0);
|
myPaddleMode->setValue(0);
|
||||||
myPaddleModeLabel->setLabel("0");
|
myPaddleModeLabel->setLabel("0");
|
||||||
|
|
||||||
// Paddle speed
|
// Paddle speed
|
||||||
myPaddleSpeed->setValue(instance()->settings().getInt("pspeed"));
|
myPaddleSpeed->setValue(instance().settings().getInt("pspeed"));
|
||||||
myPaddleLabel->setLabel(instance()->settings().getString("pspeed"));
|
myPaddleLabel->setLabel(instance().settings().getString("pspeed"));
|
||||||
|
|
||||||
// AtariVox serial port
|
// AtariVox serial port
|
||||||
myAVoxPort->setEditString(instance()->settings().getString("avoxport"));
|
myAVoxPort->setEditString(instance().settings().getString("avoxport"));
|
||||||
|
|
||||||
myTab->loadConfig();
|
myTab->loadConfig();
|
||||||
}
|
}
|
||||||
|
@ -203,13 +205,13 @@ void InputDialog::loadConfig()
|
||||||
void InputDialog::saveConfig()
|
void InputDialog::saveConfig()
|
||||||
{
|
{
|
||||||
// Left & right ports
|
// Left & right ports
|
||||||
const string& sa1 = myLeftPort->getSelectedTag() == 2 ? "right" : "left";
|
const string& sa1 = myLeftPort->getSelected() == 1 ? "right" : "left";
|
||||||
const string& sa2 = myRightPort->getSelectedTag() == 2 ? "right" : "left";
|
const string& sa2 = myRightPort->getSelected() == 1 ? "right" : "left";
|
||||||
instance()->eventHandler().mapStelladaptors(sa1, sa2);
|
instance().eventHandler().mapStelladaptors(sa1, sa2);
|
||||||
|
|
||||||
// Joystick deadzone
|
// Joystick deadzone
|
||||||
int deadzone = myDeadzone->getValue();
|
int deadzone = myDeadzone->getValue();
|
||||||
instance()->settings().setInt("joydeadzone", deadzone);
|
instance().settings().setInt("joydeadzone", deadzone);
|
||||||
Joystick::setDeadZone(deadzone);
|
Joystick::setDeadZone(deadzone);
|
||||||
|
|
||||||
// Paddle mode
|
// Paddle mode
|
||||||
|
@ -217,11 +219,11 @@ void InputDialog::saveConfig()
|
||||||
|
|
||||||
// Paddle speed
|
// Paddle speed
|
||||||
int speed = myPaddleSpeed->getValue();
|
int speed = myPaddleSpeed->getValue();
|
||||||
instance()->settings().setInt("pspeed", speed);
|
instance().settings().setInt("pspeed", speed);
|
||||||
Paddles::setDigitalSpeed(speed);
|
Paddles::setDigitalSpeed(speed);
|
||||||
|
|
||||||
// AtariVox serial port
|
// AtariVox serial port
|
||||||
instance()->settings().setString("avoxport", myAVoxPort->getEditString());
|
instance().settings().setString("avoxport", myAVoxPort->getEditString());
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -289,13 +291,13 @@ void InputDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kLeftChanged:
|
case kLeftChanged:
|
||||||
myRightPort->setSelectedTag(
|
myRightPort->setSelected(
|
||||||
myLeftPort->getSelectedTag() == 2 ? 1 : 2);
|
myLeftPort->getSelected() == 1 ? 0 : 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kRightChanged:
|
case kRightChanged:
|
||||||
myLeftPort->setSelectedTag(
|
myLeftPort->setSelected(
|
||||||
myRightPort->getSelectedTag() == 2 ? 1 : 2);
|
myRightPort->getSelected() == 1 ? 0 : 1);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kDeadzoneChanged:
|
case kDeadzoneChanged:
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: InputTextDialog.cxx,v 1.20 2008-02-06 13:45:23 stephena Exp $
|
// $Id: InputTextDialog.cxx,v 1.21 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -32,7 +32,7 @@
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
InputTextDialog::InputTextDialog(GuiObject* boss, const GUI::Font& font,
|
InputTextDialog::InputTextDialog(GuiObject* boss, const GUI::Font& font,
|
||||||
const StringList& labels, int x, int y)
|
const StringList& labels, int x, int y)
|
||||||
: Dialog(boss->instance(), boss->parent(), x, y, 16, 16),
|
: Dialog(&boss->instance(), &boss->parent(), x, y, 16, 16),
|
||||||
CommandSender(boss),
|
CommandSender(boss),
|
||||||
myErrorFlag(false)
|
myErrorFlag(false)
|
||||||
{
|
{
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: LauncherDialog.cxx,v 1.87 2008-05-30 19:07:55 stephena Exp $
|
// $Id: LauncherDialog.cxx,v 1.88 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -44,7 +44,7 @@
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
LauncherDialog::LauncherDialog(OSystem* osystem, DialogContainer* parent,
|
LauncherDialog::LauncherDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
int x, int y, int w, int h)
|
int x, int y, int w, int h)
|
||||||
: Dialog(osystem, parent, x, y, w, h),
|
: Dialog(osystem, parent, x, y, w, h, true), // use base surface
|
||||||
myStartButton(NULL),
|
myStartButton(NULL),
|
||||||
myPrevDirButton(NULL),
|
myPrevDirButton(NULL),
|
||||||
myOptionsButton(NULL),
|
myOptionsButton(NULL),
|
||||||
|
@ -56,7 +56,7 @@ LauncherDialog::LauncherDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
mySelectedItem(0),
|
mySelectedItem(0),
|
||||||
myRomInfoFlag(false)
|
myRomInfoFlag(false)
|
||||||
{
|
{
|
||||||
const GUI::Font& font = instance()->launcherFont();
|
const GUI::Font& font = instance().launcherFont();
|
||||||
|
|
||||||
const int fontHeight = font.getFontHeight();
|
const int fontHeight = font.getFontHeight();
|
||||||
const int bwidth = (_w - 2 * 10 - 8 * (4 - 1)) / 4;
|
const int bwidth = (_w - 2 * 10 - 8 * (4 - 1)) / 4;
|
||||||
|
@ -66,7 +66,7 @@ LauncherDialog::LauncherDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
|
|
||||||
// Check if we want the ROM info viewer
|
// Check if we want the ROM info viewer
|
||||||
// Make sure it will fit within the current bounds
|
// Make sure it will fit within the current bounds
|
||||||
myRomInfoFlag = instance()->settings().getBool("romviewer");
|
myRomInfoFlag = instance().settings().getBool("romviewer");
|
||||||
if((w < 640 || h < 480) && myRomInfoFlag)
|
if((w < 640 || h < 480) && myRomInfoFlag)
|
||||||
{
|
{
|
||||||
cerr << "ERROR: ROM launcher too small, deactivating ROM info viewer" << endl;
|
cerr << "ERROR: ROM launcher too small, deactivating ROM info viewer" << endl;
|
||||||
|
@ -98,7 +98,7 @@ LauncherDialog::LauncherDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
if(myRomInfoFlag)
|
if(myRomInfoFlag)
|
||||||
{
|
{
|
||||||
xpos += myList->getWidth() + 15;
|
xpos += myList->getWidth() + 15;
|
||||||
myRomInfoWidget = new RomInfoWidget(this, instance()->font(), xpos, ypos,
|
myRomInfoWidget = new RomInfoWidget(this, instance().font(), xpos, ypos,
|
||||||
326, myList->getHeight());
|
326, myList->getHeight());
|
||||||
wid.push_back(myRomInfoWidget);
|
wid.push_back(myRomInfoWidget);
|
||||||
}
|
}
|
||||||
|
@ -176,13 +176,13 @@ string LauncherDialog::selectedRomMD5()
|
||||||
string extension;
|
string extension;
|
||||||
int item = myList->getSelected();
|
int item = myList->getSelected();
|
||||||
if(item < 0 || myGameList->isDir(item) ||
|
if(item < 0 || myGameList->isDir(item) ||
|
||||||
!instance()->isValidRomName(myGameList->name(item), extension))
|
!instance().isValidRomName(myGameList->name(item), extension))
|
||||||
return "";
|
return "";
|
||||||
|
|
||||||
// Make sure we have a valid md5 for this ROM
|
// Make sure we have a valid md5 for this ROM
|
||||||
if(myGameList->md5(item) == "")
|
if(myGameList->md5(item) == "")
|
||||||
{
|
{
|
||||||
const string& md5 = instance()->MD5FromFile(myGameList->path(item));
|
const string& md5 = instance().MD5FromFile(myGameList->path(item));
|
||||||
myGameList->setMd5(item, md5);
|
myGameList->setMd5(item, md5);
|
||||||
}
|
}
|
||||||
return myGameList->md5(item);
|
return myGameList->md5(item);
|
||||||
|
@ -196,7 +196,7 @@ void LauncherDialog::loadConfig()
|
||||||
if(myList->getList().isEmpty())
|
if(myList->getList().isEmpty())
|
||||||
{
|
{
|
||||||
myPrevDirButton->setEnabled(false);
|
myPrevDirButton->setEnabled(false);
|
||||||
myCurrentNode = instance()->settings().getString("romdir");
|
myCurrentNode = instance().settings().getString("romdir");
|
||||||
|
|
||||||
updateListing();
|
updateListing();
|
||||||
}
|
}
|
||||||
|
@ -222,7 +222,7 @@ void LauncherDialog::updateListing(bool fullReload)
|
||||||
myGameList->clear();
|
myGameList->clear();
|
||||||
myDir->setLabel("");
|
myDir->setLabel("");
|
||||||
|
|
||||||
string romdir = instance()->settings().getString("romdir");
|
string romdir = instance().settings().getString("romdir");
|
||||||
loadDirListing();
|
loadDirListing();
|
||||||
|
|
||||||
// Only hilite the 'up' button if there's a parent directory
|
// Only hilite the 'up' button if there's a parent directory
|
||||||
|
@ -247,7 +247,7 @@ void LauncherDialog::updateListing(bool fullReload)
|
||||||
int selected = -1;
|
int selected = -1;
|
||||||
if(!myList->getList().isEmpty())
|
if(!myList->getList().isEmpty())
|
||||||
{
|
{
|
||||||
string lastrom = instance()->settings().getString("lastrom");
|
string lastrom = instance().settings().getString("lastrom");
|
||||||
if(lastrom == "")
|
if(lastrom == "")
|
||||||
selected = 0;
|
selected = 0;
|
||||||
else
|
else
|
||||||
|
@ -306,16 +306,16 @@ void LauncherDialog::loadRomInfo()
|
||||||
|
|
||||||
string extension;
|
string extension;
|
||||||
if(!myGameList->isDir(item) &&
|
if(!myGameList->isDir(item) &&
|
||||||
instance()->isValidRomName(myGameList->name(item), extension))
|
instance().isValidRomName(myGameList->name(item), extension))
|
||||||
{
|
{
|
||||||
// Make sure we have a valid md5 for this ROM
|
// Make sure we have a valid md5 for this ROM
|
||||||
if(myGameList->md5(item) == "")
|
if(myGameList->md5(item) == "")
|
||||||
myGameList->setMd5(item, instance()->MD5FromFile(myGameList->path(item)));
|
myGameList->setMd5(item, instance().MD5FromFile(myGameList->path(item)));
|
||||||
|
|
||||||
// Get the properties for this entry
|
// Get the properties for this entry
|
||||||
Properties props;
|
Properties props;
|
||||||
const string& md5 = myGameList->md5(item);
|
const string& md5 = myGameList->md5(item);
|
||||||
instance()->propSet().getMD5(md5, props);
|
instance().propSet().getMD5(md5, props);
|
||||||
|
|
||||||
myRomInfoWidget->setProperties(props);
|
myRomInfoWidget->setProperties(props);
|
||||||
}
|
}
|
||||||
|
@ -349,15 +349,15 @@ void LauncherDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
myCurrentNode = rom;
|
myCurrentNode = rom;
|
||||||
updateListing();
|
updateListing();
|
||||||
}
|
}
|
||||||
else if(!instance()->isValidRomName(rom, extension) ||
|
else if(!instance().isValidRomName(rom, extension) ||
|
||||||
!instance()->createConsole(rom, md5))
|
!instance().createConsole(rom, md5))
|
||||||
{
|
{
|
||||||
instance()->frameBuffer().showMessage("Not a valid ROM file", kMiddleCenter);
|
instance().frameBuffer().showMessage("Not a valid ROM file", kMiddleCenter);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
#if !defined(GP2X) // Quick GP2X hack to spare flash-card saves
|
#if !defined(GP2X) // Quick GP2X hack to spare flash-card saves
|
||||||
instance()->settings().setString("lastrom", myList->getSelectedString());
|
instance().settings().setString("lastrom", myList->getSelectedString());
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -365,7 +365,7 @@ void LauncherDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
}
|
}
|
||||||
|
|
||||||
case kOptionsCmd:
|
case kOptionsCmd:
|
||||||
parent()->addDialog(myOptions);
|
parent().addDialog(myOptions);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kPrevDirCmd:
|
case kPrevDirCmd:
|
||||||
|
@ -379,11 +379,11 @@ void LauncherDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
|
|
||||||
case kQuitCmd:
|
case kQuitCmd:
|
||||||
close();
|
close();
|
||||||
instance()->eventHandler().quit();
|
instance().eventHandler().quit();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kRomDirChosenCmd:
|
case kRomDirChosenCmd:
|
||||||
myCurrentNode = instance()->settings().getString("romdir");
|
myCurrentNode = instance().settings().getString("romdir");
|
||||||
updateListing();
|
updateListing();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ListWidget.cxx,v 1.50 2008-02-06 13:45:24 stephena Exp $
|
// $Id: ListWidget.cxx,v 1.51 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -223,7 +223,7 @@ static bool matchingCharsIgnoringCase(string s, string pattern)
|
||||||
bool ListWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
bool ListWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
{
|
{
|
||||||
// Ignore all Alt-mod keys
|
// Ignore all Alt-mod keys
|
||||||
if(instance()->eventHandler().kbdAlt(modifiers))
|
if(instance().eventHandler().kbdAlt(modifiers))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
bool handled = true;
|
bool handled = true;
|
||||||
|
@ -236,7 +236,7 @@ bool ListWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
// Only works in a useful fashion if the list entries are sorted.
|
// Only works in a useful fashion if the list entries are sorted.
|
||||||
// TODO: Maybe this should be off by default, and instead we add a
|
// TODO: Maybe this should be off by default, and instead we add a
|
||||||
// method "enableQuickSelect()" or so ?
|
// method "enableQuickSelect()" or so ?
|
||||||
int time = instance()->getTicks() / 1000;
|
int time = instance().getTicks() / 1000;
|
||||||
if (_quickSelectTime < time)
|
if (_quickSelectTime < time)
|
||||||
_quickSelectStr = (char)ascii;
|
_quickSelectStr = (char)ascii;
|
||||||
else
|
else
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: OptionsDialog.cxx,v 1.69 2008-03-23 16:22:46 stephena Exp $
|
// $Id: OptionsDialog.cxx,v 1.70 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -60,7 +60,7 @@ OptionsDialog::OptionsDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
myAboutDialog(NULL),
|
myAboutDialog(NULL),
|
||||||
myIsGlobal(global)
|
myIsGlobal(global)
|
||||||
{
|
{
|
||||||
const GUI::Font& font = instance()->font();
|
const GUI::Font& font = instance().font();
|
||||||
const int buttonWidth = font.getStringWidth("Game Properties") + 20,
|
const int buttonWidth = font.getStringWidth("Game Properties") + 20,
|
||||||
buttonHeight = font.getLineHeight() + 6,
|
buttonHeight = font.getLineHeight() + 6,
|
||||||
rowHeight = font.getLineHeight() + 10;
|
rowHeight = font.getLineHeight() + 10;
|
||||||
|
@ -120,44 +120,44 @@ OptionsDialog::OptionsDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
|
|
||||||
// Now create all the dialogs attached to each menu button
|
// Now create all the dialogs attached to each menu button
|
||||||
w = 240; h = 185;
|
w = 240; h = 185;
|
||||||
myVideoDialog = new VideoDialog(myOSystem, parent, font, x, y, w, h);
|
myVideoDialog = new VideoDialog(osystem, parent, font, x, y, w, h);
|
||||||
|
|
||||||
w = 200; h = 140;
|
w = 200; h = 140;
|
||||||
myAudioDialog = new AudioDialog(myOSystem, parent, font, x, y, w, h);
|
myAudioDialog = new AudioDialog(osystem, parent, font, x, y, w, h);
|
||||||
|
|
||||||
#ifdef _WIN32_WCE
|
#ifdef _WIN32_WCE
|
||||||
// we scale the input dialog down a bit in low res devices.
|
// we scale the input dialog down a bit in low res devices.
|
||||||
// looks only a little ugly, but the functionality is very welcome
|
// looks only a little ugly, but the functionality is very welcome
|
||||||
if(myOSystem->desktopWidth() < 320) { w = 220; h = 176; }
|
if(instance().desktopWidth() < 320) { w = 220; h = 176; }
|
||||||
else { w = 230; h = 185; }
|
else { w = 230; h = 185; }
|
||||||
#else
|
#else
|
||||||
w = 230; h = 185;
|
w = 230; h = 185;
|
||||||
#endif
|
#endif
|
||||||
myInputDialog = new InputDialog(myOSystem, parent, font, x, y, w, h);
|
myInputDialog = new InputDialog(osystem, parent, font, x, y, w, h);
|
||||||
|
|
||||||
w = 200; h = 155;
|
w = 200; h = 155;
|
||||||
myUIDialog = new UIDialog(myOSystem, parent, font, x, y, w, h);
|
myUIDialog = new UIDialog(osystem, parent, font, x, y, w, h);
|
||||||
|
|
||||||
w = 280; h = 180;
|
w = 280; h = 180;
|
||||||
myFileSnapDialog = new FileSnapDialog(myOSystem, parent, font,
|
myFileSnapDialog = new FileSnapDialog(osystem, parent, font,
|
||||||
boss, x, y, w, h);
|
boss, x, y, w, h);
|
||||||
|
|
||||||
w = 240; h = 115;
|
w = 240; h = 115;
|
||||||
myRomAuditDialog = new RomAuditDialog(myOSystem, parent, font, x, y, w, h);
|
myRomAuditDialog = new RomAuditDialog(osystem, parent, font, x, y, w, h);
|
||||||
|
|
||||||
w = 255; h = 190;
|
w = 255; h = 190;
|
||||||
myGameInfoDialog = new GameInfoDialog(myOSystem, parent, font, this, x, y, w, h);
|
myGameInfoDialog = new GameInfoDialog(osystem, parent, font, this, x, y, w, h);
|
||||||
|
|
||||||
#ifdef CHEATCODE_SUPPORT
|
#ifdef CHEATCODE_SUPPORT
|
||||||
w = 230; h = 150;
|
w = 230; h = 150;
|
||||||
myCheatCodeDialog = new CheatCodeDialog(myOSystem, parent, font, x, y, w, h);
|
myCheatCodeDialog = new CheatCodeDialog(osystem, parent, font, x, y, w, h);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
w = 255; h = 150;
|
w = 255; h = 150;
|
||||||
myHelpDialog = new HelpDialog(myOSystem, parent, font, x, y, w, h);
|
myHelpDialog = new HelpDialog(osystem, parent, font, x, y, w, h);
|
||||||
|
|
||||||
w = 255; h = 150;
|
w = 255; h = 150;
|
||||||
myAboutDialog = new AboutDialog(myOSystem, parent, font, x, y, w, h);
|
myAboutDialog = new AboutDialog(osystem, parent, font, x, y, w, h);
|
||||||
|
|
||||||
addToFocusList(wid);
|
addToFocusList(wid);
|
||||||
|
|
||||||
|
@ -173,7 +173,7 @@ OptionsDialog::OptionsDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
#ifdef _WIN32_WCE
|
#ifdef _WIN32_WCE
|
||||||
myAudioSettingsButton->clearFlags(WIDGET_ENABLED); // not honored in wince port
|
myAudioSettingsButton->clearFlags(WIDGET_ENABLED); // not honored in wince port
|
||||||
#endif
|
#endif
|
||||||
if(myOSystem->desktopWidth() < 320)
|
if(instance().desktopWidth() < 320)
|
||||||
{
|
{
|
||||||
// These cannot be displayed in low res devices
|
// These cannot be displayed in low res devices
|
||||||
myVideoSettingsButton->clearFlags(WIDGET_ENABLED);
|
myVideoSettingsButton->clearFlags(WIDGET_ENABLED);
|
||||||
|
@ -207,13 +207,13 @@ void OptionsDialog::loadConfig()
|
||||||
// Determine whether we should show the 'Game Information' button
|
// Determine whether we should show the 'Game Information' button
|
||||||
// We always show it in emulation mode, or if a valid ROM is selected
|
// We always show it in emulation mode, or if a valid ROM is selected
|
||||||
// in launcher mode
|
// in launcher mode
|
||||||
switch(instance()->eventHandler().state())
|
switch(instance().eventHandler().state())
|
||||||
{
|
{
|
||||||
case EventHandler::S_EMULATE:
|
case EventHandler::S_EMULATE:
|
||||||
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
||||||
break;
|
break;
|
||||||
case EventHandler::S_LAUNCHER:
|
case EventHandler::S_LAUNCHER:
|
||||||
if(instance()->launcher().selectedRomMD5() != "")
|
if(instance().launcher().selectedRomMD5() != "")
|
||||||
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
myGameInfoButton->setFlags(WIDGET_ENABLED);
|
||||||
else
|
else
|
||||||
myGameInfoButton->clearFlags(WIDGET_ENABLED);
|
myGameInfoButton->clearFlags(WIDGET_ENABLED);
|
||||||
|
@ -230,52 +230,52 @@ void OptionsDialog::handleCommand(CommandSender* sender, int cmd,
|
||||||
switch(cmd)
|
switch(cmd)
|
||||||
{
|
{
|
||||||
case kVidCmd:
|
case kVidCmd:
|
||||||
parent()->addDialog(myVideoDialog);
|
parent().addDialog(myVideoDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kAudCmd:
|
case kAudCmd:
|
||||||
parent()->addDialog(myAudioDialog);
|
parent().addDialog(myAudioDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kInptCmd:
|
case kInptCmd:
|
||||||
parent()->addDialog(myInputDialog);
|
parent().addDialog(myInputDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kUsrIfaceCmd:
|
case kUsrIfaceCmd:
|
||||||
parent()->addDialog(myUIDialog);
|
parent().addDialog(myUIDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kFileSnapCmd:
|
case kFileSnapCmd:
|
||||||
parent()->addDialog(myFileSnapDialog);
|
parent().addDialog(myFileSnapDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kAuditCmd:
|
case kAuditCmd:
|
||||||
parent()->addDialog(myRomAuditDialog);
|
parent().addDialog(myRomAuditDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kInfoCmd:
|
case kInfoCmd:
|
||||||
parent()->addDialog(myGameInfoDialog);
|
parent().addDialog(myGameInfoDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
#ifdef CHEATCODE_SUPPORT
|
#ifdef CHEATCODE_SUPPORT
|
||||||
case kCheatCmd:
|
case kCheatCmd:
|
||||||
parent()->addDialog(myCheatCodeDialog);
|
parent().addDialog(myCheatCodeDialog);
|
||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
case kHelpCmd:
|
case kHelpCmd:
|
||||||
parent()->addDialog(myHelpDialog);
|
parent().addDialog(myHelpDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kAboutCmd:
|
case kAboutCmd:
|
||||||
parent()->addDialog(myAboutDialog);
|
parent().addDialog(myAboutDialog);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kExitCmd:
|
case kExitCmd:
|
||||||
if(myIsGlobal)
|
if(myIsGlobal)
|
||||||
close();
|
close();
|
||||||
else
|
else
|
||||||
instance()->eventHandler().leaveMenuMode();
|
instance().eventHandler().leaveMenuMode();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: PopUpWidget.cxx,v 1.39 2008-02-06 13:45:24 stephena Exp $
|
// $Id: PopUpWidget.cxx,v 1.40 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -21,12 +21,9 @@
|
||||||
|
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
|
||||||
#include "DialogContainer.hxx"
|
|
||||||
#include "Dialog.hxx"
|
|
||||||
#include "FrameBuffer.hxx"
|
#include "FrameBuffer.hxx"
|
||||||
#include "OSystem.hxx"
|
#include "ContextMenu.hxx"
|
||||||
#include "Stack.hxx"
|
#include "DialogContainer.hxx"
|
||||||
#include "StringListWidget.hxx"
|
|
||||||
|
|
||||||
#include "PopUpWidget.hxx"
|
#include "PopUpWidget.hxx"
|
||||||
|
|
||||||
|
@ -44,390 +41,14 @@ static unsigned int up_down_arrows[8] = {
|
||||||
0x00001000,
|
0x00001000,
|
||||||
};
|
};
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
PopUpDialog::PopUpDialog(PopUpWidget* boss, int clickX, int clickY)
|
|
||||||
: Dialog(boss->instance(), boss->parent(), 0, 0, 16, 16),
|
|
||||||
_popUpBoss(boss)
|
|
||||||
{
|
|
||||||
// Copy the selection index
|
|
||||||
_selection = _popUpBoss->_selectedItem;
|
|
||||||
|
|
||||||
// Calculate real popup dimensions
|
|
||||||
_x = _popUpBoss->getAbsX() + _popUpBoss->_labelWidth;
|
|
||||||
_y = _popUpBoss->getAbsY() - _popUpBoss->_selectedItem * _popUpBoss->_fontHeight;
|
|
||||||
_w = _popUpBoss->_w - _popUpBoss->_labelWidth - 10;
|
|
||||||
_h = 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::drawDialog()
|
|
||||||
{
|
|
||||||
// Normally we add widgets and let Dialog::draw() take care of this
|
|
||||||
// logic. But for some reason, this Dialog was written differently
|
|
||||||
// by the ScummVM guys, so I'm not going to mess with it.
|
|
||||||
if(_dirty)
|
|
||||||
{
|
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
|
||||||
|
|
||||||
// Draw the menu border
|
|
||||||
fb.hLine(_x, _y, _x + _w - 1, kColor);
|
|
||||||
fb.hLine(_x, _y + _h - 1, _x + _w - 1, kShadowColor);
|
|
||||||
fb.vLine(_x, _y, _y + _h - 1, kColor);
|
|
||||||
fb.vLine(_x + _w - 1, _y, _y + _h - 1, kShadowColor);
|
|
||||||
|
|
||||||
// If necessary, draw dividing line
|
|
||||||
if(_twoColumns)
|
|
||||||
fb.vLine(_x + _w / 2, _y, _y + _h - 2, kColor);
|
|
||||||
|
|
||||||
// Draw the entries
|
|
||||||
int count = _popUpBoss->_entries.size();
|
|
||||||
for(int i = 0; i < count; i++)
|
|
||||||
drawMenuEntry(i, i == _selection);
|
|
||||||
|
|
||||||
// The last entry may be empty. Fill it with black.
|
|
||||||
if(_twoColumns && (count & 1))
|
|
||||||
fb.fillRect(_x + 1 + _w / 2, _y + 1 + _popUpBoss->_fontHeight * (_entriesPerColumn - 1),
|
|
||||||
_w / 2 - 1, _popUpBoss->_fontHeight, kWidColor);
|
|
||||||
|
|
||||||
_dirty = false;
|
|
||||||
fb.addDirtyRect(_x, _y, _w, _h);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::handleMouseDown(int x, int y, int button, int clickCount)
|
|
||||||
{
|
|
||||||
// Only make a selection if we're in the dialog area
|
|
||||||
if(x >= 0 && x < _w && y >= 0 && y < _h)
|
|
||||||
sendSelection();
|
|
||||||
else
|
|
||||||
cancelSelection();
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::handleMouseWheel(int x, int y, int direction)
|
|
||||||
{
|
|
||||||
if(direction < 0)
|
|
||||||
moveUp();
|
|
||||||
else if(direction > 0)
|
|
||||||
moveDown();
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::handleMouseMoved(int x, int y, int button)
|
|
||||||
{
|
|
||||||
// Compute over which item the mouse is...
|
|
||||||
int item = findItem(x, y);
|
|
||||||
|
|
||||||
if(item >= 0 && _popUpBoss->_entries[item].name.size() == 0)
|
|
||||||
item = -1;
|
|
||||||
|
|
||||||
if(item == -1 && !isMouseDown())
|
|
||||||
return;
|
|
||||||
|
|
||||||
// ...and update the selection accordingly
|
|
||||||
setSelection(item);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::handleKeyDown(int ascii, int keycode, int modifiers)
|
|
||||||
{
|
|
||||||
if(isMouseDown())
|
|
||||||
return;
|
|
||||||
|
|
||||||
Event::Type e = instance()->eventHandler().eventForKey(keycode, kMenuMode);
|
|
||||||
handleEvent(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::handleJoyDown(int stick, int button)
|
|
||||||
{
|
|
||||||
Event::Type e =
|
|
||||||
instance()->eventHandler().eventForJoyButton(stick, button, kMenuMode);
|
|
||||||
handleEvent(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::handleJoyAxis(int stick, int axis, int value)
|
|
||||||
{
|
|
||||||
if(value != 0) // we don't care about 'axis up' events
|
|
||||||
{
|
|
||||||
Event::Type e =
|
|
||||||
instance()->eventHandler().eventForJoyAxis(stick, axis, value, kMenuMode);
|
|
||||||
handleEvent(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
bool PopUpDialog::handleJoyHat(int stick, int hat, int value)
|
|
||||||
{
|
|
||||||
Event::Type e =
|
|
||||||
instance()->eventHandler().eventForJoyHat(stick, hat, value, kMenuMode);
|
|
||||||
handleEvent(e);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::handleEvent(Event::Type e)
|
|
||||||
{
|
|
||||||
switch(e)
|
|
||||||
{
|
|
||||||
case Event::UISelect:
|
|
||||||
sendSelection();
|
|
||||||
break;
|
|
||||||
case Event::UIUp:
|
|
||||||
case Event::UILeft:
|
|
||||||
moveUp();
|
|
||||||
break;
|
|
||||||
case Event::UIDown:
|
|
||||||
case Event::UIRight:
|
|
||||||
moveDown();
|
|
||||||
break;
|
|
||||||
case Event::UIHome:
|
|
||||||
setSelection(0);
|
|
||||||
break;
|
|
||||||
case Event::UIEnd:
|
|
||||||
setSelection(_popUpBoss->_entries.size()-1);
|
|
||||||
break;
|
|
||||||
case Event::UICancel:
|
|
||||||
cancelSelection();
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::drawMenuEntry(int entry, bool hilite)
|
|
||||||
{
|
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
|
||||||
|
|
||||||
// Draw one entry of the popup menu, including selection
|
|
||||||
int x, y, w;
|
|
||||||
|
|
||||||
if(_twoColumns)
|
|
||||||
{
|
|
||||||
int n = _popUpBoss->_entries.size() / 2;
|
|
||||||
|
|
||||||
if(_popUpBoss->_entries.size() & 1)
|
|
||||||
n++;
|
|
||||||
|
|
||||||
if (entry >= n)
|
|
||||||
{
|
|
||||||
x = _x + 1 + _w / 2;
|
|
||||||
y = _y + 1 + _popUpBoss->_fontHeight * (entry - n);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
x = _x + 1;
|
|
||||||
y = _y + 1 + _popUpBoss->_fontHeight * entry;
|
|
||||||
}
|
|
||||||
|
|
||||||
w = _w / 2 - 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
x = _x + 1;
|
|
||||||
y = _y + 1 + _popUpBoss->_fontHeight * entry;
|
|
||||||
w = _w - 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
string& name = _popUpBoss->_entries[entry].name;
|
|
||||||
fb.fillRect(x, y, w, _popUpBoss->_fontHeight, hilite ? kTextColorHi : kWidColor);
|
|
||||||
|
|
||||||
if(name.size() == 0)
|
|
||||||
{
|
|
||||||
// Draw a separator
|
|
||||||
fb.hLine(x - 1, y + _popUpBoss->_fontHeight / 2, x + w, kShadowColor);
|
|
||||||
fb.hLine(x, y + 1 + _popUpBoss->_fontHeight / 2, x + w, kColor);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
fb.drawString(_popUpBoss->font(), name, x + 1, y + 2, w - 2,
|
|
||||||
hilite ? _popUpBoss->_textcolorhi : _popUpBoss->_textcolor);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::recalc()
|
|
||||||
{
|
|
||||||
// Perform clipping / switch to scrolling mode if we don't fit on the screen
|
|
||||||
const int height = instance()->frameBuffer().baseHeight();
|
|
||||||
|
|
||||||
_x = _popUpBoss->getAbsX() + _popUpBoss->_labelWidth;
|
|
||||||
_y = _popUpBoss->getAbsY() + _popUpBoss->getHeight();
|
|
||||||
|
|
||||||
_h = _popUpBoss->_entries.size() * _popUpBoss->_fontHeight + 2;
|
|
||||||
|
|
||||||
// HACK: For now, we do not do scrolling. Instead, we draw the dialog
|
|
||||||
// in two columns if it's too tall.
|
|
||||||
if(_h >= height)
|
|
||||||
{
|
|
||||||
const int width = instance()->frameBuffer().baseWidth();
|
|
||||||
|
|
||||||
_twoColumns = true;
|
|
||||||
_entriesPerColumn = _popUpBoss->_entries.size() / 2;
|
|
||||||
|
|
||||||
if(_popUpBoss->_entries.size() & 1)
|
|
||||||
_entriesPerColumn++;
|
|
||||||
|
|
||||||
_h = _entriesPerColumn * _popUpBoss->_fontHeight + 2;
|
|
||||||
_w = 0;
|
|
||||||
|
|
||||||
// Find width of largest item
|
|
||||||
for(unsigned int i = 0; i < _popUpBoss->_entries.size(); i++)
|
|
||||||
{
|
|
||||||
int width = _popUpBoss->_font->getStringWidth(_popUpBoss->_entries[i].name);
|
|
||||||
|
|
||||||
if(width > _w)
|
|
||||||
_w = width;
|
|
||||||
}
|
|
||||||
|
|
||||||
_w = 2 * _w + 10;
|
|
||||||
|
|
||||||
if (!(_w & 1))
|
|
||||||
_w++;
|
|
||||||
|
|
||||||
if(_popUpBoss->_selectedItem >= _entriesPerColumn)
|
|
||||||
{
|
|
||||||
_x -= _w / 2;
|
|
||||||
_y = _popUpBoss->getAbsY() - (_popUpBoss->_selectedItem - _entriesPerColumn) *
|
|
||||||
_popUpBoss->_fontHeight;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(_w >= width)
|
|
||||||
_w = width - 1;
|
|
||||||
if(_x < 0)
|
|
||||||
_x = 0;
|
|
||||||
if(_x + _w >= width)
|
|
||||||
_x = width - 1 - _w;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
_twoColumns = false;
|
|
||||||
|
|
||||||
if(_h >= height)
|
|
||||||
_h = height - 1;
|
|
||||||
if(_y < 0)
|
|
||||||
_y = 0;
|
|
||||||
else if(_y + _h >= height)
|
|
||||||
_y = height - 1 - _h;
|
|
||||||
|
|
||||||
// TODO - implement scrolling if we had to move the menu, or if there are too many entries
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
int PopUpDialog::findItem(int x, int y) const
|
|
||||||
{
|
|
||||||
if(x >= 0 && x < _w && y >= 0 && y < _h)
|
|
||||||
{
|
|
||||||
if(_twoColumns)
|
|
||||||
{
|
|
||||||
unsigned int entry = (y - 2) / _popUpBoss->_fontHeight;
|
|
||||||
if(x > _w / 2)
|
|
||||||
{
|
|
||||||
entry += _entriesPerColumn;
|
|
||||||
|
|
||||||
if(entry >= _popUpBoss->_entries.size())
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
return entry;
|
|
||||||
}
|
|
||||||
return (y - 2) / _popUpBoss->_fontHeight;
|
|
||||||
}
|
|
||||||
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::setSelection(int item)
|
|
||||||
{
|
|
||||||
if(item != _selection)
|
|
||||||
{
|
|
||||||
// Change selection
|
|
||||||
_selection = item;
|
|
||||||
_popUpBoss->_selectedItem = item;
|
|
||||||
|
|
||||||
setDirty(); _popUpBoss->setDirty(); _popUpBoss->draw();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::sendSelection()
|
|
||||||
{
|
|
||||||
if(_popUpBoss->_cmd)
|
|
||||||
_popUpBoss->sendCommand(_popUpBoss->_cmd,
|
|
||||||
_popUpBoss->_entries[_selection].tag,
|
|
||||||
_popUpBoss->_id);
|
|
||||||
|
|
||||||
// We remove the dialog when the user has selected an item
|
|
||||||
parent()->removeDialog();
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::cancelSelection()
|
|
||||||
{
|
|
||||||
setSelection(_oldSelection);
|
|
||||||
parent()->removeDialog();
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
bool PopUpDialog::isMouseDown()
|
|
||||||
{
|
|
||||||
// TODO - need a way to determine whether any mouse buttons are pressed or not.
|
|
||||||
// Sure, we could just count mouse button up/down events, but that is cumbersome and
|
|
||||||
// error prone. Would be much nicer to add an API to OSystem for this...
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::moveUp()
|
|
||||||
{
|
|
||||||
if(_selection < 0)
|
|
||||||
{
|
|
||||||
setSelection(_popUpBoss->_entries.size() - 1);
|
|
||||||
}
|
|
||||||
else if(_selection > 0)
|
|
||||||
{
|
|
||||||
int item = _selection;
|
|
||||||
do {
|
|
||||||
item--;
|
|
||||||
} while (item >= 0 && _popUpBoss->_entries[item].name.size() == 0);
|
|
||||||
if(item >= 0)
|
|
||||||
setSelection(item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpDialog::moveDown()
|
|
||||||
{
|
|
||||||
int lastItem = _popUpBoss->_entries.size() - 1;
|
|
||||||
|
|
||||||
if(_selection < 0)
|
|
||||||
{
|
|
||||||
setSelection(0);
|
|
||||||
}
|
|
||||||
else if(_selection < lastItem)
|
|
||||||
{
|
|
||||||
int item = _selection;
|
|
||||||
do {
|
|
||||||
item++;
|
|
||||||
} while (item <= lastItem && _popUpBoss->_entries[item].name.size() == 0);
|
|
||||||
if(item <= lastItem)
|
|
||||||
setSelection(item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// PopUpWidget
|
|
||||||
//
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
PopUpWidget::PopUpWidget(GuiObject* boss, const GUI::Font& font,
|
PopUpWidget::PopUpWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
int x, int y, int w, int h,
|
int x, int y, int w, int h, const StringList& list,
|
||||||
const string& label, int labelWidth, int cmd)
|
const string& label, int labelWidth, int cmd)
|
||||||
: Widget(boss, font, x, y - 1, w, h + 2),
|
: Widget(boss, font, x, y - 1, w, h + 2),
|
||||||
CommandSender(boss),
|
CommandSender(boss),
|
||||||
_label(label),
|
_label(label),
|
||||||
_labelWidth(labelWidth),
|
_labelWidth(labelWidth)
|
||||||
_cmd(cmd)
|
|
||||||
{
|
{
|
||||||
_flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS;
|
_flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS;
|
||||||
_type = kPopUpWidget;
|
_type = kPopUpWidget;
|
||||||
|
@ -436,8 +57,6 @@ PopUpWidget::PopUpWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
_textcolor = kTextColor;
|
_textcolor = kTextColor;
|
||||||
_textcolorhi = kTextColor;
|
_textcolorhi = kTextColor;
|
||||||
|
|
||||||
_selectedItem = -1;
|
|
||||||
|
|
||||||
if(!_label.empty() && _labelWidth == 0)
|
if(!_label.empty() && _labelWidth == 0)
|
||||||
_labelWidth = _font->getStringWidth(_label);
|
_labelWidth = _font->getStringWidth(_label);
|
||||||
|
|
||||||
|
@ -447,14 +66,13 @@ PopUpWidget::PopUpWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
myTextY = (_h - _font->getFontHeight()) / 2;
|
myTextY = (_h - _font->getFontHeight()) / 2;
|
||||||
myArrowsY = (_h - 8) / 2;
|
myArrowsY = (_h - 8) / 2;
|
||||||
|
|
||||||
myPopUpDialog = new PopUpDialog(this, x + getAbsX(), y + getAbsY());
|
myMenu = new ContextMenu(this, font, list, cmd);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
PopUpWidget::~PopUpWidget()
|
PopUpWidget::~PopUpWidget()
|
||||||
{
|
{
|
||||||
delete myPopUpDialog;
|
delete myMenu;
|
||||||
myPopUpDialog = NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -462,8 +80,13 @@ void PopUpWidget::handleMouseDown(int x, int y, int button, int clickCount)
|
||||||
{
|
{
|
||||||
if(isEnabled())
|
if(isEnabled())
|
||||||
{
|
{
|
||||||
myPopUpDialog->_oldSelection = _selectedItem;
|
// Add menu just underneath parent widget
|
||||||
parent()->addDialog(myPopUpDialog);
|
uInt32 x, y;
|
||||||
|
dialog().surface().getPos(x, y);
|
||||||
|
x += getAbsX() + _labelWidth;
|
||||||
|
y += getAbsY() + getHeight();
|
||||||
|
|
||||||
|
myMenu->show(x, y, myMenu->getSelected());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -483,102 +106,37 @@ bool PopUpWidget::handleEvent(Event::Type e)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpWidget::appendEntry(const string& entry, int tag)
|
|
||||||
{
|
|
||||||
Entry e;
|
|
||||||
e.name = entry;
|
|
||||||
e.tag = tag;
|
|
||||||
_entries.push_back(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpWidget::clearEntries()
|
|
||||||
{
|
|
||||||
_entries.clear();
|
|
||||||
_selectedItem = -1;
|
|
||||||
|
|
||||||
// Reset the height of the popup dialog to be empty
|
|
||||||
myPopUpDialog->setHeight(2);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpWidget::setSelected(int item)
|
|
||||||
{
|
|
||||||
if(item != _selectedItem)
|
|
||||||
{
|
|
||||||
if(item >= 0 && item < (int)_entries.size())
|
|
||||||
_selectedItem = item;
|
|
||||||
else
|
|
||||||
_selectedItem = -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpWidget::setSelectedName(const string& name)
|
|
||||||
{
|
|
||||||
for(unsigned int item = 0; item < _entries.size(); ++item)
|
|
||||||
{
|
|
||||||
if(_entries[item].name == name)
|
|
||||||
{
|
|
||||||
setSelected(item);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpWidget::setSelectedTag(int tag)
|
|
||||||
{
|
|
||||||
for(unsigned int item = 0; item < _entries.size(); ++item)
|
|
||||||
{
|
|
||||||
if(_entries[item].tag == tag)
|
|
||||||
{
|
|
||||||
setSelected(item);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
|
||||||
void PopUpWidget::setSelectedMax()
|
|
||||||
{
|
|
||||||
setSelected(_entries.size() - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void PopUpWidget::drawWidget(bool hilite)
|
void PopUpWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "PopUpWidget::drawWidget\n";
|
//cerr << "PopUpWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
FBSurface& s = dialog().surface();
|
||||||
|
|
||||||
int x = _x + _labelWidth;
|
int x = _x + _labelWidth;
|
||||||
int w = _w - _labelWidth;
|
int w = _w - _labelWidth;
|
||||||
|
|
||||||
// Draw the label, if any
|
// Draw the label, if any
|
||||||
if (_labelWidth > 0)
|
if (_labelWidth > 0)
|
||||||
fb.drawString(_font, _label, _x, _y + myTextY, _labelWidth,
|
s.drawString(_font, _label, _x, _y + myTextY, _labelWidth,
|
||||||
isEnabled() ? _textcolor : kColor, kTextAlignRight);
|
isEnabled() ? _textcolor : kColor, kTextAlignRight);
|
||||||
|
|
||||||
// Draw a thin frame around us.
|
// Draw a thin frame around us.
|
||||||
fb.hLine(x, _y, x + w - 1, kColor);
|
s.hLine(x, _y, x + w - 1, kColor);
|
||||||
fb.hLine(x, _y +_h-1, x + w - 1, kShadowColor);
|
s.hLine(x, _y +_h-1, x + w - 1, kShadowColor);
|
||||||
fb.vLine(x, _y, _y+_h-1, kColor);
|
s.vLine(x, _y, _y+_h-1, kColor);
|
||||||
fb.vLine(x + w - 1, _y, _y +_h - 1, kShadowColor);
|
s.vLine(x + w - 1, _y, _y +_h - 1, kShadowColor);
|
||||||
|
|
||||||
// Fill the background
|
// Fill the background
|
||||||
fb.fillRect(x + 1, _y + 1, w - 2, _h - 2, kWidColor);
|
s.fillRect(x + 1, _y + 1, w - 2, _h - 2, kWidColor);
|
||||||
|
|
||||||
// Draw an arrow pointing down at the right end to signal this is a dropdown/popup
|
// Draw an arrow pointing down at the right end to signal this is a dropdown/popup
|
||||||
fb.drawBitmap(up_down_arrows, x+w - 10, _y + myArrowsY,
|
s.drawBitmap(up_down_arrows, x+w - 10, _y + myArrowsY,
|
||||||
!isEnabled() ? kColor : hilite ? kTextColorHi : kTextColor);
|
!isEnabled() ? kColor : hilite ? kTextColorHi : kTextColor);
|
||||||
|
|
||||||
// Draw the selected entry, if any
|
// Draw the selected entry, if any
|
||||||
if(_selectedItem >= 0)
|
const string& name = myMenu->getSelectedString();
|
||||||
{
|
TextAlignment align = (_font->getStringWidth(name) > w-6) ?
|
||||||
TextAlignment align = (_font->getStringWidth(_entries[_selectedItem].name) > w-6) ?
|
|
||||||
kTextAlignRight : kTextAlignLeft;
|
kTextAlignRight : kTextAlignLeft;
|
||||||
fb.drawString(_font, _entries[_selectedItem].name, x+2, _y+myTextY, w-6,
|
s.drawString(_font, name, x+2, _y+myTextY, w-6,
|
||||||
!isEnabled() ? kColor : kTextColor, align);
|
!isEnabled() ? kColor : kTextColor, align);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: PopUpWidget.hxx,v 1.20 2008-02-06 13:45:24 stephena Exp $
|
// $Id: PopUpWidget.hxx,v 1.21 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -23,13 +23,13 @@
|
||||||
#define POPUP_WIDGET_HXX
|
#define POPUP_WIDGET_HXX
|
||||||
|
|
||||||
class GUIObject;
|
class GUIObject;
|
||||||
class PopUpDialog;
|
|
||||||
|
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
|
||||||
#include "Array.hxx"
|
#include "Array.hxx"
|
||||||
#include "Command.hxx"
|
#include "Command.hxx"
|
||||||
#include "Dialog.hxx"
|
#include "ContextMenu.hxx"
|
||||||
|
#include "StringList.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
|
||||||
|
|
||||||
|
@ -42,111 +42,36 @@ class PopUpDialog;
|
||||||
*/
|
*/
|
||||||
class PopUpWidget : public Widget, public CommandSender
|
class PopUpWidget : public Widget, public CommandSender
|
||||||
{
|
{
|
||||||
friend class PopUpDialog;
|
|
||||||
|
|
||||||
struct Entry {
|
|
||||||
string name;
|
|
||||||
int tag;
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef Common::Array<Entry> EntryList;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
EntryList _entries;
|
|
||||||
int _selectedItem;
|
|
||||||
string _label;
|
|
||||||
int _labelWidth;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
PopUpWidget(GuiObject* boss, const GUI::Font& font,
|
PopUpWidget(GuiObject* boss, const GUI::Font& font,
|
||||||
int x, int y, int w, int h,
|
int x, int y, int w, int h, const StringList& items,
|
||||||
const string& label, int labelWidth = 0, int cmd = 0);
|
const string& label, int labelWidth = 0, int cmd = 0);
|
||||||
~PopUpWidget();
|
~PopUpWidget();
|
||||||
|
|
||||||
|
/** Various selection methods passed directly to the underlying menu
|
||||||
|
See ContextMenu.hxx for more information. */
|
||||||
|
void setSelected(int item) { myMenu->setSelected(item); }
|
||||||
|
void setSelected(const string& name) { myMenu->setSelected(name); }
|
||||||
|
void setSelectedMax() { myMenu->setSelectedMax(); }
|
||||||
|
void clearSelection() { myMenu->clearSelection(); }
|
||||||
|
|
||||||
|
int getSelected() const { return myMenu->getSelected(); }
|
||||||
|
const string& getSelectedString() const { return myMenu->getSelectedString(); }
|
||||||
|
|
||||||
bool wantsFocus() { return true; }
|
bool wantsFocus() { return true; }
|
||||||
|
|
||||||
void appendEntry(const string& entry, int tag = (int)-1);
|
|
||||||
void clearEntries();
|
|
||||||
|
|
||||||
/** Select the entry at the given index. */
|
|
||||||
void setSelected(int item);
|
|
||||||
|
|
||||||
/** Select the first entry matching the given name. */
|
|
||||||
void setSelectedName(const string& name);
|
|
||||||
|
|
||||||
/** Select the first entry matching the given tag. */
|
|
||||||
void setSelectedTag(int tag);
|
|
||||||
|
|
||||||
/** Select the highest/last entry in the internal list. */
|
|
||||||
void setSelectedMax();
|
|
||||||
|
|
||||||
int getSelected() const
|
|
||||||
{ return _selectedItem; }
|
|
||||||
int getSelectedTag() const
|
|
||||||
{ return (_selectedItem >= 0) ? _entries[_selectedItem].tag : (int)-1; }
|
|
||||||
const string& getSelectedString() const
|
|
||||||
{ return (_selectedItem >= 0) ? _entries[_selectedItem].name : EmptyString; }
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void handleMouseDown(int x, int y, int button, int clickCount);
|
void handleMouseDown(int x, int y, int button, int clickCount);
|
||||||
bool handleEvent(Event::Type e);
|
bool handleEvent(Event::Type e);
|
||||||
void drawWidget(bool hilite);
|
void drawWidget(bool hilite);
|
||||||
|
|
||||||
protected:
|
|
||||||
int _cmd;
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
PopUpDialog* myPopUpDialog;
|
ContextMenu* myMenu;
|
||||||
int myArrowsY;
|
int myArrowsY;
|
||||||
int myTextY;
|
int myTextY;
|
||||||
};
|
|
||||||
|
|
||||||
//
|
string _label;
|
||||||
// PopUpDialog
|
int _labelWidth;
|
||||||
//
|
|
||||||
class PopUpDialog : public Dialog
|
|
||||||
{
|
|
||||||
friend class PopUpWidget;
|
|
||||||
|
|
||||||
public:
|
|
||||||
PopUpDialog(PopUpWidget* boss, int clickX, int clickY);
|
|
||||||
|
|
||||||
void drawDialog();
|
|
||||||
void center() { recalc(); }
|
|
||||||
|
|
||||||
protected:
|
|
||||||
void handleMouseDown(int x, int y, int button, int clickCount);
|
|
||||||
void handleMouseWheel(int x, int y, int direction);
|
|
||||||
void handleMouseMoved(int x, int y, int button);
|
|
||||||
void handleKeyDown(int ascii, int keycode, int modifiers); // Scroll through entries with arrow keys etc
|
|
||||||
void handleJoyDown(int stick, int button);
|
|
||||||
void handleJoyAxis(int stick, int axis, int value);
|
|
||||||
bool handleJoyHat(int stick, int hat, int value);
|
|
||||||
void handleEvent(Event::Type e);
|
|
||||||
|
|
||||||
void drawMenuEntry(int entry, bool hilite);
|
|
||||||
|
|
||||||
void recalc();
|
|
||||||
int findItem(int x, int y) const;
|
|
||||||
void setSelection(int item);
|
|
||||||
bool isMouseDown();
|
|
||||||
|
|
||||||
void moveUp();
|
|
||||||
void moveDown();
|
|
||||||
|
|
||||||
private:
|
|
||||||
void sendSelection();
|
|
||||||
void cancelSelection();
|
|
||||||
|
|
||||||
protected:
|
|
||||||
PopUpWidget* _popUpBoss;
|
|
||||||
int _clickX, _clickY;
|
|
||||||
uInt8* _buffer;
|
|
||||||
int _selection;
|
|
||||||
int _oldSelection;
|
|
||||||
int _openTime;
|
|
||||||
bool _twoColumns;
|
|
||||||
int _entriesPerColumn;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ProgressDialog.cxx,v 1.12 2008-03-14 23:52:17 stephena Exp $
|
// $Id: ProgressDialog.cxx,v 1.13 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -30,7 +30,7 @@
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
ProgressDialog::ProgressDialog(GuiObject* boss, const GUI::Font& font,
|
ProgressDialog::ProgressDialog(GuiObject* boss, const GUI::Font& font,
|
||||||
const string& message)
|
const string& message)
|
||||||
: Dialog(boss->instance(), boss->parent(), 0, 0, 16, 16),
|
: Dialog(&boss->instance(), &boss->parent(), 0, 0, 16, 16),
|
||||||
myMessage(NULL),
|
myMessage(NULL),
|
||||||
mySlider(NULL),
|
mySlider(NULL),
|
||||||
myStart(0),
|
myStart(0),
|
||||||
|
@ -59,8 +59,8 @@ ProgressDialog::ProgressDialog(GuiObject* boss, const GUI::Font& font,
|
||||||
mySlider->setMinValue(1);
|
mySlider->setMinValue(1);
|
||||||
mySlider->setMaxValue(100);
|
mySlider->setMaxValue(100);
|
||||||
|
|
||||||
parent()->addDialog(this);
|
parent().addDialog(this);
|
||||||
instance()->frameBuffer().update();
|
instance().frameBuffer().update();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -71,7 +71,7 @@ ProgressDialog::~ProgressDialog()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ProgressDialog::done()
|
void ProgressDialog::done()
|
||||||
{
|
{
|
||||||
parent()->removeDialog();
|
parent().removeDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -98,6 +98,6 @@ void ProgressDialog::setProgress(int progress)
|
||||||
if(progress - mySlider->getValue() > myStep)
|
if(progress - mySlider->getValue() > myStep)
|
||||||
{
|
{
|
||||||
mySlider->setValue(progress);
|
mySlider->setValue(progress);
|
||||||
instance()->frameBuffer().update();
|
instance().frameBuffer().update();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: RomAuditDialog.cxx,v 1.3 2008-03-14 23:52:17 stephena Exp $
|
// $Id: RomAuditDialog.cxx,v 1.4 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -111,7 +111,7 @@ RomAuditDialog::~RomAuditDialog()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void RomAuditDialog::loadConfig()
|
void RomAuditDialog::loadConfig()
|
||||||
{
|
{
|
||||||
myRomPath->setEditString(instance()->settings().getString("romdir"));
|
myRomPath->setEditString(instance().settings().getString("romdir"));
|
||||||
myResults1->setLabel("");
|
myResults1->setLabel("");
|
||||||
myResults2->setLabel("");
|
myResults2->setLabel("");
|
||||||
}
|
}
|
||||||
|
@ -128,7 +128,7 @@ void RomAuditDialog::auditRoms()
|
||||||
|
|
||||||
// Create a progress dialog box to show the progress of processing
|
// Create a progress dialog box to show the progress of processing
|
||||||
// the ROMs, since this is usually a time-consuming operation
|
// the ROMs, since this is usually a time-consuming operation
|
||||||
ProgressDialog progress(this, instance()->launcherFont(),
|
ProgressDialog progress(this, instance().launcherFont(),
|
||||||
"Auditing ROM files ...");
|
"Auditing ROM files ...");
|
||||||
progress.setRange(0, files.size() - 1, 5);
|
progress.setRange(0, files.size() - 1, 5);
|
||||||
|
|
||||||
|
@ -139,12 +139,12 @@ void RomAuditDialog::auditRoms()
|
||||||
{
|
{
|
||||||
string extension;
|
string extension;
|
||||||
if(!files[idx].isDirectory() &&
|
if(!files[idx].isDirectory() &&
|
||||||
instance()->isValidRomName(files[idx].path(), extension))
|
instance().isValidRomName(files[idx].path(), extension))
|
||||||
{
|
{
|
||||||
// Calculate the MD5 so we can get the rest of the info
|
// Calculate the MD5 so we can get the rest of the info
|
||||||
// from the PropertiesSet (stella.pro)
|
// from the PropertiesSet (stella.pro)
|
||||||
const string& md5 = instance()->MD5FromFile(files[idx].path());
|
const string& md5 = instance().MD5FromFile(files[idx].path());
|
||||||
instance()->propSet().getMD5(md5, props);
|
instance().propSet().getMD5(md5, props);
|
||||||
const string& name = props.get(Cartridge_Name);
|
const string& name = props.get(Cartridge_Name);
|
||||||
|
|
||||||
// Only rename the file if we found a valid properties entry
|
// Only rename the file if we found a valid properties entry
|
||||||
|
@ -172,7 +172,7 @@ void RomAuditDialog::auditRoms()
|
||||||
void RomAuditDialog::openBrowser(const string& title, const string& startpath,
|
void RomAuditDialog::openBrowser(const string& title, const string& startpath,
|
||||||
FilesystemNode::ListMode mode, int cmd)
|
FilesystemNode::ListMode mode, int cmd)
|
||||||
{
|
{
|
||||||
parent()->addDialog(myBrowser);
|
parent().addDialog(myBrowser);
|
||||||
|
|
||||||
myBrowser->setTitle(title);
|
myBrowser->setTitle(title);
|
||||||
myBrowser->setEmitSignal(cmd);
|
myBrowser->setEmitSignal(cmd);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: RomInfoWidget.cxx,v 1.7 2008-03-15 19:11:00 stephena Exp $
|
// $Id: RomInfoWidget.cxx,v 1.8 2008-06-13 13:14:51 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
@ -70,7 +70,7 @@ void RomInfoWidget::setProperties(const Properties& props)
|
||||||
myProperties = props;
|
myProperties = props;
|
||||||
|
|
||||||
// Decide whether the information should be shown immediately
|
// Decide whether the information should be shown immediately
|
||||||
if(instance()->eventHandler().state() == EventHandler::S_LAUNCHER)
|
if(instance().eventHandler().state() == EventHandler::S_LAUNCHER)
|
||||||
{
|
{
|
||||||
parseProperties();
|
parseProperties();
|
||||||
setDirty(); draw();
|
setDirty(); draw();
|
||||||
|
@ -83,7 +83,7 @@ void RomInfoWidget::clearProperties()
|
||||||
myHaveProperties = myDrawSurface = false;
|
myHaveProperties = myDrawSurface = false;
|
||||||
|
|
||||||
// Decide whether the information should be shown immediately
|
// Decide whether the information should be shown immediately
|
||||||
if(instance()->eventHandler().state() == EventHandler::S_LAUNCHER)
|
if(instance().eventHandler().state() == EventHandler::S_LAUNCHER)
|
||||||
{
|
{
|
||||||
setDirty(); draw();
|
setDirty(); draw();
|
||||||
}
|
}
|
||||||
|
@ -100,6 +100,8 @@ void RomInfoWidget::initialize()
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void RomInfoWidget::parseProperties()
|
void RomInfoWidget::parseProperties()
|
||||||
{
|
{
|
||||||
|
// FIXME
|
||||||
|
#if 0
|
||||||
// Initialize to empty properties entry
|
// Initialize to empty properties entry
|
||||||
mySurfaceErrorMsg = "";
|
mySurfaceErrorMsg = "";
|
||||||
myDrawSurface = false;
|
myDrawSurface = false;
|
||||||
|
@ -109,7 +111,7 @@ void RomInfoWidget::parseProperties()
|
||||||
// The surface will always be the maximum size, but sometimes we'll
|
// The surface will always be the maximum size, but sometimes we'll
|
||||||
// only draw certain parts of it
|
// only draw certain parts of it
|
||||||
if(mySurface == NULL)
|
if(mySurface == NULL)
|
||||||
mySurface = instance()->frameBuffer().createSurface(320, 260);
|
mySurface = instance().frameBuffer().createSurface(320, 260);
|
||||||
|
|
||||||
// The input stream for the PNG file
|
// The input stream for the PNG file
|
||||||
ifstream in;
|
ifstream in;
|
||||||
|
@ -124,7 +126,7 @@ void RomInfoWidget::parseProperties()
|
||||||
|
|
||||||
// Get a valid filename representing a snapshot file for this rom
|
// Get a valid filename representing a snapshot file for this rom
|
||||||
const string& filename =
|
const string& filename =
|
||||||
instance()->settings().getString("ssdir") + BSPF_PATH_SEPARATOR +
|
instance().settings().getString("ssdir") + BSPF_PATH_SEPARATOR +
|
||||||
myProperties.get(Cartridge_Name) + ".png";
|
myProperties.get(Cartridge_Name) + ".png";
|
||||||
|
|
||||||
// Open the PNG and check for a valid signature
|
// Open the PNG and check for a valid signature
|
||||||
|
@ -154,7 +156,7 @@ void RomInfoWidget::parseProperties()
|
||||||
}
|
}
|
||||||
else if(type == "IDAT")
|
else if(type == "IDAT")
|
||||||
{
|
{
|
||||||
if(!parseIDATChunk(instance()->frameBuffer(), mySurface,
|
if(!parseIDATChunk(instance().frameBuffer(), mySurface,
|
||||||
width, height, data, size))
|
width, height, data, size))
|
||||||
throw "PNG image too large";
|
throw "PNG image too large";
|
||||||
}
|
}
|
||||||
|
@ -190,12 +192,15 @@ void RomInfoWidget::parseProperties()
|
||||||
myRomInfo.push_back("Controllers: " + myProperties.get(Controller_Left) +
|
myRomInfo.push_back("Controllers: " + myProperties.get(Controller_Left) +
|
||||||
" (left), " + myProperties.get(Controller_Right) + " (right)");
|
" (left), " + myProperties.get(Controller_Right) + " (right)");
|
||||||
// TODO - add the PNG tEXt chunks
|
// TODO - add the PNG tEXt chunks
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void RomInfoWidget::drawWidget(bool hilite)
|
void RomInfoWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
// FIXME
|
||||||
|
#if 0
|
||||||
|
FrameBuffer& fb = instance().frameBuffer();
|
||||||
|
|
||||||
fb.fillRect(_x+2, _y+2, _w-4, _h-4, kWidColor);
|
fb.fillRect(_x+2, _y+2, _w-4, _h-4, kWidColor);
|
||||||
fb.box(_x, _y, _w, _h, kColor, kShadowColor);
|
fb.box(_x, _y, _w, _h, kColor, kShadowColor);
|
||||||
|
@ -220,6 +225,7 @@ void RomInfoWidget::drawWidget(bool hilite)
|
||||||
fb.drawString(_font, myRomInfo[i], xpos, ypos, _w - 10, _textcolor);
|
fb.drawString(_font, myRomInfo[i], xpos, ypos, _w - 10, _textcolor);
|
||||||
ypos += _font->getLineHeight();
|
ypos += _font->getLineHeight();
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -278,6 +284,8 @@ bool RomInfoWidget::parseIHDR(int& width, int& height, uInt8* data, int size)
|
||||||
bool RomInfoWidget::parseIDATChunk(const FrameBuffer& fb, GUI::Surface* surface,
|
bool RomInfoWidget::parseIDATChunk(const FrameBuffer& fb, GUI::Surface* surface,
|
||||||
int width, int height, uInt8* data, int size)
|
int width, int height, uInt8* data, int size)
|
||||||
{
|
{
|
||||||
|
// FIXME
|
||||||
|
#if 0
|
||||||
// The entire decompressed image data
|
// The entire decompressed image data
|
||||||
uLongf bufsize = (width * 3 + 1) * height;
|
uLongf bufsize = (width * 3 + 1) * height;
|
||||||
uInt8* buffer = new uInt8[bufsize];
|
uInt8* buffer = new uInt8[bufsize];
|
||||||
|
@ -296,6 +304,7 @@ bool RomInfoWidget::parseIDATChunk(const FrameBuffer& fb, GUI::Surface* surface,
|
||||||
}
|
}
|
||||||
delete[] buffer;
|
delete[] buffer;
|
||||||
return false;
|
return false;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ScrollBarWidget.cxx,v 1.22 2008-03-02 20:48:51 stephena Exp $
|
// $Id: ScrollBarWidget.cxx,v 1.23 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -247,37 +247,35 @@ void ScrollBarWidget::recalc()
|
||||||
void ScrollBarWidget::drawWidget(bool hilite)
|
void ScrollBarWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "ScrollBarWidget::drawWidget\n";
|
//cerr << "ScrollBarWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
int bottomY = _y + _h;
|
int bottomY = _y + _h;
|
||||||
bool isSinglePage = (_numEntries <= _entriesPerPage);
|
bool isSinglePage = (_numEntries <= _entriesPerPage);
|
||||||
|
|
||||||
fb.frameRect(_x, _y, _w, _h, kShadowColor);
|
s.frameRect(_x, _y, _w, _h, kShadowColor);
|
||||||
|
|
||||||
if(_draggingPart != kNoPart)
|
if(_draggingPart != kNoPart)
|
||||||
_part = _draggingPart;
|
_part = _draggingPart;
|
||||||
|
|
||||||
// Up arrow
|
// Up arrow
|
||||||
fb.frameRect(_x, _y, _w, UP_DOWN_BOX_HEIGHT, kColor);
|
s.frameRect(_x, _y, _w, UP_DOWN_BOX_HEIGHT, kColor);
|
||||||
fb.drawBitmap(up_arrow, _x, _y,
|
s.drawBitmap(up_arrow, _x, _y, isSinglePage ? kColor :
|
||||||
isSinglePage ? kColor :
|
|
||||||
(hilite && _part == kUpArrowPart) ? kScrollColorHi : kScrollColor);
|
(hilite && _part == kUpArrowPart) ? kScrollColorHi : kScrollColor);
|
||||||
|
|
||||||
// Down arrow
|
// Down arrow
|
||||||
fb.frameRect(_x, bottomY - UP_DOWN_BOX_HEIGHT, _w, UP_DOWN_BOX_HEIGHT, kColor);
|
s.frameRect(_x, bottomY - UP_DOWN_BOX_HEIGHT, _w, UP_DOWN_BOX_HEIGHT, kColor);
|
||||||
fb.drawBitmap(down_arrow, _x, bottomY - UP_DOWN_BOX_HEIGHT,
|
s.drawBitmap(down_arrow, _x, bottomY - UP_DOWN_BOX_HEIGHT, isSinglePage ? kColor :
|
||||||
isSinglePage ? kColor :
|
|
||||||
(hilite && _part == kDownArrowPart) ? kScrollColorHi : kScrollColor);
|
(hilite && _part == kDownArrowPart) ? kScrollColorHi : kScrollColor);
|
||||||
|
|
||||||
// Slider
|
// Slider
|
||||||
if(!isSinglePage)
|
if(!isSinglePage)
|
||||||
{
|
{
|
||||||
fb.fillRect(_x, _y + _sliderPos, _w, _sliderHeight,
|
s.fillRect(_x, _y + _sliderPos, _w, _sliderHeight,
|
||||||
(hilite && _part == kSliderPart) ? kScrollColorHi : kScrollColor);
|
(hilite && _part == kSliderPart) ? kScrollColorHi : kScrollColor);
|
||||||
fb.frameRect(_x, _y + _sliderPos, _w, _sliderHeight, kColor);
|
s.frameRect(_x, _y + _sliderPos, _w, _sliderHeight, kColor);
|
||||||
int y = _y + _sliderPos + _sliderHeight / 2;
|
int y = _y + _sliderPos + _sliderHeight / 2;
|
||||||
fb.hLine(_x + 2, y - 2, _x + _w - 3, kWidColor);
|
s.hLine(_x + 2, y - 2, _x + _w - 3, kWidColor);
|
||||||
fb.hLine(_x + 2, y, _x + _w - 3, kWidColor);
|
s.hLine(_x + 2, y, _x + _w - 3, kWidColor);
|
||||||
fb.hLine(_x + 2, y + 2, _x + _w - 3, kWidColor);
|
s.hLine(_x + 2, y + 2, _x + _w - 3, kWidColor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Stack.hxx,v 1.5 2008-02-06 13:45:24 stephena Exp $
|
// $Id: Stack.hxx,v 1.6 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -56,7 +56,7 @@ class FixedStack
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
int size() const { return _size; }
|
int size() const { return _size; }
|
||||||
T operator [](int i)
|
T operator [](int i) const
|
||||||
{
|
{
|
||||||
assert(0 <= i && i < MAX_SIZE);
|
assert(0 <= i && i < MAX_SIZE);
|
||||||
return _stack[i];
|
return _stack[i];
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: StringListWidget.cxx,v 1.10 2008-02-06 13:45:24 stephena Exp $
|
// $Id: StringListWidget.cxx,v 1.11 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -48,15 +48,15 @@ void StringListWidget::setList(const StringList& list)
|
||||||
void StringListWidget::drawWidget(bool hilite)
|
void StringListWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
//cerr << "StringListWidget::drawWidget\n";
|
//cerr << "StringListWidget::drawWidget\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
int i, pos, len = _list.size();
|
int i, pos, len = _list.size();
|
||||||
string buffer;
|
string buffer;
|
||||||
int deltax;
|
int deltax;
|
||||||
|
|
||||||
// Draw a thin frame around the list.
|
// Draw a thin frame around the list.
|
||||||
fb.hLine(_x, _y, _x + _w - 1, kColor);
|
s.hLine(_x, _y, _x + _w - 1, kColor);
|
||||||
fb.hLine(_x, _y + _h - 1, _x + _w - 1, kShadowColor);
|
s.hLine(_x, _y + _h - 1, _x + _w - 1, kShadowColor);
|
||||||
fb.vLine(_x, _y, _y + _h - 1, kColor);
|
s.vLine(_x, _y, _y + _h - 1, kColor);
|
||||||
|
|
||||||
// Draw the list items
|
// Draw the list items
|
||||||
for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++)
|
for (i = 0, pos = _currentPos; i < _rows && pos < len; i++, pos++)
|
||||||
|
@ -69,9 +69,9 @@ void StringListWidget::drawWidget(bool hilite)
|
||||||
if (_selectedItem == pos)
|
if (_selectedItem == pos)
|
||||||
{
|
{
|
||||||
if (_hasFocus && !_editMode)
|
if (_hasFocus && !_editMode)
|
||||||
fb.fillRect(_x + 1, _y + 1 + _fontHeight * i, _w - 1, _fontHeight, kTextColorHi);
|
s.fillRect(_x + 1, _y + 1 + _fontHeight * i, _w - 1, _fontHeight, kTextColorHi);
|
||||||
else
|
else
|
||||||
fb.frameRect(_x + 1, _y + 1 + _fontHeight * i, _w - 1, _fontHeight, kTextColorHi);
|
s.frameRect(_x + 1, _y + 1 + _fontHeight * i, _w - 1, _fontHeight, kTextColorHi);
|
||||||
}
|
}
|
||||||
|
|
||||||
// If in numbering mode, we first print a number prefix
|
// If in numbering mode, we first print a number prefix
|
||||||
|
@ -80,7 +80,7 @@ void StringListWidget::drawWidget(bool hilite)
|
||||||
char temp[10];
|
char temp[10];
|
||||||
sprintf(temp, "%2d. ", (pos + _numberingMode));
|
sprintf(temp, "%2d. ", (pos + _numberingMode));
|
||||||
buffer = temp;
|
buffer = temp;
|
||||||
fb.drawString(_font, buffer, _x + 2, y, _w - 4, textColor);
|
s.drawString(_font, buffer, _x + 2, y, _w - 4, textColor);
|
||||||
}
|
}
|
||||||
|
|
||||||
GUI::Rect r(getEditRect());
|
GUI::Rect r(getEditRect());
|
||||||
|
@ -90,14 +90,14 @@ void StringListWidget::drawWidget(bool hilite)
|
||||||
adjustOffset();
|
adjustOffset();
|
||||||
deltax = -_editScrollOffset;
|
deltax = -_editScrollOffset;
|
||||||
|
|
||||||
fb.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor,
|
s.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor,
|
||||||
kTextAlignLeft, deltax, false);
|
kTextAlignLeft, deltax, false);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
buffer = _list[pos];
|
buffer = _list[pos];
|
||||||
deltax = 0;
|
deltax = 0;
|
||||||
fb.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor);
|
s.drawString(_font, buffer, _x + r.left, y, r.width(), kTextColor);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: TabWidget.cxx,v 1.31 2008-02-06 13:45:24 stephena Exp $
|
// $Id: TabWidget.cxx,v 1.32 2008-06-13 13:14:51 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -255,20 +255,20 @@ void TabWidget::box(int x, int y, int width, int height,
|
||||||
int colorA, int colorB, bool omitBottom)
|
int colorA, int colorB, bool omitBottom)
|
||||||
{
|
{
|
||||||
//cerr << "TabWidget::box\n";
|
//cerr << "TabWidget::box\n";
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
|
|
||||||
fb.hLine(x + 1, y, x + width - 2, colorA);
|
s.hLine(x + 1, y, x + width - 2, colorA);
|
||||||
fb.hLine(x, y + 1, x + width - 1, colorA);
|
s.hLine(x, y + 1, x + width - 1, colorA);
|
||||||
fb.vLine(x, y + 1, y + height - (omitBottom ? 1 : 2), colorA);
|
s.vLine(x, y + 1, y + height - (omitBottom ? 1 : 2), colorA);
|
||||||
fb.vLine(x + 1, y, y + height - (omitBottom ? 2 : 1), colorA);
|
s.vLine(x + 1, y, y + height - (omitBottom ? 2 : 1), colorA);
|
||||||
|
|
||||||
if (!omitBottom)
|
if (!omitBottom)
|
||||||
{
|
{
|
||||||
fb.hLine(x + 1, y + height - 2, x + width - 1, colorB);
|
s.hLine(x + 1, y + height - 2, x + width - 1, colorB);
|
||||||
fb.hLine(x + 1, y + height - 1, x + width - 2, colorB);
|
s.hLine(x + 1, y + height - 1, x + width - 2, colorB);
|
||||||
}
|
}
|
||||||
fb.vLine(x + width - 1, y + 1, y + height - (omitBottom ? 1 : 2), colorB);
|
s.vLine(x + width - 1, y + 1, y + height - (omitBottom ? 1 : 2), colorB);
|
||||||
fb.vLine(x + width - 2, y + 1, y + height - (omitBottom ? 2 : 1), colorB);
|
s.vLine(x + width - 2, y + 1, y + height - (omitBottom ? 2 : 1), colorB);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -279,7 +279,7 @@ void TabWidget::drawWidget(bool hilite)
|
||||||
// it must assume responsibility for refreshing all its children.
|
// it must assume responsibility for refreshing all its children.
|
||||||
Widget::setDirtyInChain(_tabs[_activeTab].firstWidget);
|
Widget::setDirtyInChain(_tabs[_activeTab].firstWidget);
|
||||||
|
|
||||||
FrameBuffer& fb = instance()->frameBuffer();
|
FBSurface& s = dialog().surface();
|
||||||
|
|
||||||
const int left1 = _x + 1;
|
const int left1 = _x + 1;
|
||||||
const int right1 = _x + kTabLeftOffset + _activeTab * (_tabWidth + kTabSpacing);
|
const int right1 = _x + kTabLeftOffset + _activeTab * (_tabWidth + kTabSpacing);
|
||||||
|
@ -287,8 +287,8 @@ void TabWidget::drawWidget(bool hilite)
|
||||||
const int right2 = _x + _w - 2;
|
const int right2 = _x + _w - 2;
|
||||||
|
|
||||||
// Draw horizontal line
|
// Draw horizontal line
|
||||||
fb.hLine(left1, _y + _tabHeight - 2, right1, kShadowColor);
|
s.hLine(left1, _y + _tabHeight - 2, right1, kShadowColor);
|
||||||
fb.hLine(left2, _y + _tabHeight - 2, right2, kShadowColor);
|
s.hLine(left2, _y + _tabHeight - 2, right2, kShadowColor);
|
||||||
|
|
||||||
// Iterate over all tabs and draw them
|
// Iterate over all tabs and draw them
|
||||||
int i, x = _x + kTabLeftOffset;
|
int i, x = _x + kTabLeftOffset;
|
||||||
|
@ -298,19 +298,19 @@ void TabWidget::drawWidget(bool hilite)
|
||||||
int boxcolor = (i == _activeTab) ? kColor : kShadowColor;
|
int boxcolor = (i == _activeTab) ? kColor : kShadowColor;
|
||||||
int yOffset = (i == _activeTab) ? 0 : 2;
|
int yOffset = (i == _activeTab) ? 0 : 2;
|
||||||
box(x, _y + yOffset, _tabWidth, _tabHeight - yOffset, boxcolor, boxcolor, (i == _activeTab));
|
box(x, _y + yOffset, _tabWidth, _tabHeight - yOffset, boxcolor, boxcolor, (i == _activeTab));
|
||||||
fb.drawString(_font, _tabs[i].title, x + kTabPadding,
|
s.drawString(_font, _tabs[i].title, x + kTabPadding,
|
||||||
_y + yOffset / 2 + (_tabHeight - _fontHeight - 1),
|
_y + yOffset / 2 + (_tabHeight - _fontHeight - 1),
|
||||||
_tabWidth - 2 * kTabPadding, fontcolor, kTextAlignCenter);
|
_tabWidth - 2 * kTabPadding, fontcolor, kTextAlignCenter);
|
||||||
x += _tabWidth + kTabSpacing;
|
x += _tabWidth + kTabSpacing;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw a frame around the widget area (belows the tabs)
|
// Draw a frame around the widget area (belows the tabs)
|
||||||
fb.hLine(left1, _y + _tabHeight - 1, right1, kColor);
|
s.hLine(left1, _y + _tabHeight - 1, right1, kColor);
|
||||||
fb.hLine(left2, _y + _tabHeight - 1, right2, kColor);
|
s.hLine(left2, _y + _tabHeight - 1, right2, kColor);
|
||||||
fb.hLine(_x+1, _y + _h - 2, _x + _w - 2, kShadowColor);
|
s.hLine(_x+1, _y + _h - 2, _x + _w - 2, kShadowColor);
|
||||||
fb.hLine(_x+1, _y + _h - 1, _x + _w - 2, kColor);
|
s.hLine(_x+1, _y + _h - 1, _x + _w - 2, kColor);
|
||||||
fb.vLine(_x + _w - 2, _y + _tabHeight - 1, _y + _h - 2, kColor);
|
s.vLine(_x + _w - 2, _y + _tabHeight - 1, _y + _h - 2, kColor);
|
||||||
fb.vLine(_x + _w - 1, _y + _tabHeight - 1, _y + _h - 2, kShadowColor);
|
s.vLine(_x + _w - 1, _y + _tabHeight - 1, _y + _h - 2, kShadowColor);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: UIDialog.cxx,v 1.13 2008-03-23 16:22:46 stephena Exp $
|
// $Id: UIDialog.cxx,v 1.14 2008-06-13 13:14:52 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -28,6 +28,7 @@
|
||||||
#include "PopUpWidget.hxx"
|
#include "PopUpWidget.hxx"
|
||||||
#include "ScrollBarWidget.hxx"
|
#include "ScrollBarWidget.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
|
#include "StringList.hxx"
|
||||||
#include "TabWidget.hxx"
|
#include "TabWidget.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
|
||||||
|
@ -47,6 +48,7 @@ UIDialog::UIDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
int xpos, ypos, tabID;
|
int xpos, ypos, tabID;
|
||||||
int lwidth, pwidth = font.getStringWidth("Standard");
|
int lwidth, pwidth = font.getStringWidth("Standard");
|
||||||
WidgetArray wid;
|
WidgetArray wid;
|
||||||
|
StringList items;
|
||||||
|
|
||||||
// Set real dimensions
|
// Set real dimensions
|
||||||
// _w = 36 * fontWidth + 10;
|
// _w = 36 * fontWidth + 10;
|
||||||
|
@ -94,10 +96,12 @@ UIDialog::UIDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// Launcher font
|
// Launcher font
|
||||||
myLauncherFontPopup = new PopUpWidget(myTab, font, xpos, ypos+1, pwidth, lineHeight,
|
items.clear();
|
||||||
|
items.push_back("Small");
|
||||||
|
items.push_back("Large");
|
||||||
|
myLauncherFontPopup =
|
||||||
|
new PopUpWidget(myTab, font, xpos, ypos+1, pwidth, lineHeight, items,
|
||||||
"Launcher Font: ", lwidth);
|
"Launcher Font: ", lwidth);
|
||||||
myLauncherFontPopup->appendEntry("Small", 1);
|
|
||||||
myLauncherFontPopup->appendEntry("Large", 2);
|
|
||||||
wid.push_back(myLauncherFontPopup);
|
wid.push_back(myLauncherFontPopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
|
@ -171,10 +175,11 @@ UIDialog::UIDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
|
|
||||||
// UI Palette
|
// UI Palette
|
||||||
ypos += 1;
|
ypos += 1;
|
||||||
|
items.clear();
|
||||||
|
items.push_back("Standard");
|
||||||
|
items.push_back("Classic");
|
||||||
myPalettePopup = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
myPalettePopup = new PopUpWidget(myTab, font, xpos, ypos, pwidth, lineHeight,
|
||||||
"Interface Palette: ", lwidth);
|
items, "Interface Palette: ", lwidth);
|
||||||
myPalettePopup->appendEntry("Standard", 1);
|
|
||||||
myPalettePopup->appendEntry("Classic", 2);
|
|
||||||
wid.push_back(myPalettePopup);
|
wid.push_back(myPalettePopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
|
@ -231,7 +236,7 @@ void UIDialog::loadConfig()
|
||||||
int w, h;
|
int w, h;
|
||||||
|
|
||||||
// Launcher size
|
// Launcher size
|
||||||
instance()->settings().getSize("launcherres", w, h);
|
instance().settings().getSize("launcherres", w, h);
|
||||||
w = BSPF_max(w, 320);
|
w = BSPF_max(w, 320);
|
||||||
h = BSPF_max(h, 240);
|
h = BSPF_max(h, 240);
|
||||||
w = BSPF_min(w, 1920);
|
w = BSPF_min(w, 1920);
|
||||||
|
@ -243,15 +248,15 @@ void UIDialog::loadConfig()
|
||||||
myLauncherHeightLabel->setValue(h);
|
myLauncherHeightLabel->setValue(h);
|
||||||
|
|
||||||
// Launcher font
|
// Launcher font
|
||||||
const string& s = instance()->settings().getString("launcherfont");
|
const string& s = instance().settings().getString("launcherfont");
|
||||||
myLauncherFontPopup->setSelectedTag(s == "large" ? 2 : 1);
|
myLauncherFontPopup->setSelected(s == "large" ? 1 : 0);
|
||||||
|
|
||||||
// ROM launcher info viewer
|
// ROM launcher info viewer
|
||||||
bool b = instance()->settings().getBool("romviewer");
|
bool b = instance().settings().getBool("romviewer");
|
||||||
myRomViewerCheckbox->setState(b);
|
myRomViewerCheckbox->setState(b);
|
||||||
|
|
||||||
// Debugger size
|
// Debugger size
|
||||||
instance()->settings().getSize("debuggerres", w, h);
|
instance().settings().getSize("debuggerres", w, h);
|
||||||
w = BSPF_max(w, 1030);
|
w = BSPF_max(w, 1030);
|
||||||
h = BSPF_max(h, 690);
|
h = BSPF_max(h, 690);
|
||||||
w = BSPF_min(w, 1920);
|
w = BSPF_min(w, 1920);
|
||||||
|
@ -263,12 +268,12 @@ void UIDialog::loadConfig()
|
||||||
myDebuggerHeightLabel->setValue(h);
|
myDebuggerHeightLabel->setValue(h);
|
||||||
|
|
||||||
// UI palette
|
// UI palette
|
||||||
int i = instance()->settings().getInt("uipalette");
|
int i = instance().settings().getInt("uipalette");
|
||||||
if(i < 1 || i > 2) i = 1;
|
if(i < 1 || i > 2) i = 1;
|
||||||
myPalettePopup->setSelectedTag(i);
|
myPalettePopup->setSelected(i-1);
|
||||||
|
|
||||||
// Mouse wheel lines
|
// Mouse wheel lines
|
||||||
int mw = instance()->settings().getInt("mwheel");
|
int mw = instance().settings().getInt("mwheel");
|
||||||
if(mw < 1 || mw > 10) mw = 1;
|
if(mw < 1 || mw > 10) mw = 1;
|
||||||
myWheelLinesSlider->setValue(mw);
|
myWheelLinesSlider->setValue(mw);
|
||||||
myWheelLinesLabel->setValue(mw);
|
myWheelLinesLabel->setValue(mw);
|
||||||
|
@ -280,27 +285,27 @@ void UIDialog::loadConfig()
|
||||||
void UIDialog::saveConfig()
|
void UIDialog::saveConfig()
|
||||||
{
|
{
|
||||||
// Launcher size
|
// Launcher size
|
||||||
instance()->settings().setSize("launcherres",
|
instance().settings().setSize("launcherres",
|
||||||
myLauncherWidthSlider->getValue(), myLauncherHeightSlider->getValue());
|
myLauncherWidthSlider->getValue(), myLauncherHeightSlider->getValue());
|
||||||
|
|
||||||
// Launcher font
|
// Launcher font
|
||||||
instance()->settings().setString("launcherfont",
|
instance().settings().setString("launcherfont",
|
||||||
myLauncherFontPopup->getSelectedTag() == 1 ? "small" : "large");
|
myLauncherFontPopup->getSelected() == 1 ? "large" : "small");
|
||||||
|
|
||||||
// ROM launcher info viewer
|
// ROM launcher info viewer
|
||||||
instance()->settings().setBool("romviewer", myRomViewerCheckbox->getState());
|
instance().settings().setBool("romviewer", myRomViewerCheckbox->getState());
|
||||||
|
|
||||||
// Debugger size
|
// Debugger size
|
||||||
instance()->settings().setSize("debuggerres",
|
instance().settings().setSize("debuggerres",
|
||||||
myDebuggerWidthSlider->getValue(), myDebuggerHeightSlider->getValue());
|
myDebuggerWidthSlider->getValue(), myDebuggerHeightSlider->getValue());
|
||||||
|
|
||||||
// UI palette
|
// UI palette
|
||||||
instance()->settings().setInt("uipalette",
|
instance().settings().setInt("uipalette",
|
||||||
myPalettePopup->getSelectedTag());
|
myPalettePopup->getSelected() + 1);
|
||||||
|
|
||||||
// Mouse wheel lines
|
// Mouse wheel lines
|
||||||
int mw = myWheelLinesSlider->getValue();
|
int mw = myWheelLinesSlider->getValue();
|
||||||
instance()->settings().setInt("mwheel", mw);
|
instance().settings().setInt("mwheel", mw);
|
||||||
ScrollBarWidget::setWheelLines(mw);
|
ScrollBarWidget::setWheelLines(mw);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -311,8 +316,8 @@ void UIDialog::setDefaults()
|
||||||
{
|
{
|
||||||
case 0: // Launcher options
|
case 0: // Launcher options
|
||||||
{
|
{
|
||||||
int w = BSPF_min(instance()->desktopWidth(), 640u);
|
int w = BSPF_min(instance().desktopWidth(), 640u);
|
||||||
int h = BSPF_min(instance()->desktopHeight(), 480u);
|
int h = BSPF_min(instance().desktopHeight(), 480u);
|
||||||
myLauncherWidthSlider->setValue(w);
|
myLauncherWidthSlider->setValue(w);
|
||||||
myLauncherWidthLabel->setValue(w);
|
myLauncherWidthLabel->setValue(w);
|
||||||
myLauncherHeightSlider->setValue(h);
|
myLauncherHeightSlider->setValue(h);
|
||||||
|
@ -329,7 +334,7 @@ void UIDialog::setDefaults()
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 2: // Misc. options
|
case 2: // Misc. options
|
||||||
myPalettePopup->setSelectedTag(1);
|
myPalettePopup->setSelected(0);
|
||||||
myWheelLinesSlider->setValue(4);
|
myWheelLinesSlider->setValue(4);
|
||||||
myWheelLinesLabel->setValue(4);
|
myWheelLinesLabel->setValue(4);
|
||||||
break;
|
break;
|
||||||
|
@ -369,7 +374,7 @@ void UIDialog::handleCommand(CommandSender* sender, int cmd, int data, int id)
|
||||||
case kOKCmd:
|
case kOKCmd:
|
||||||
saveConfig();
|
saveConfig();
|
||||||
close();
|
close();
|
||||||
instance()->setUIPalette();
|
instance().setUIPalette();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case kDefaultsCmd:
|
case kDefaultsCmd:
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: VideoDialog.cxx,v 1.50 2008-05-21 14:01:31 stephena Exp $
|
// $Id: VideoDialog.cxx,v 1.51 2008-06-13 13:14:52 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -30,6 +30,7 @@
|
||||||
#include "PopUpWidget.hxx"
|
#include "PopUpWidget.hxx"
|
||||||
#include "Console.hxx"
|
#include "Console.hxx"
|
||||||
#include "Settings.hxx"
|
#include "Settings.hxx"
|
||||||
|
#include "StringList.hxx"
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
|
||||||
#include "VideoDialog.hxx"
|
#include "VideoDialog.hxx"
|
||||||
|
@ -48,6 +49,7 @@ VideoDialog::VideoDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
int lwidth = font.getStringWidth("Dirty Rects: "),
|
int lwidth = font.getStringWidth("Dirty Rects: "),
|
||||||
pwidth = font.getStringWidth("1920x1200");
|
pwidth = font.getStringWidth("1920x1200");
|
||||||
WidgetArray wid;
|
WidgetArray wid;
|
||||||
|
StringList items;
|
||||||
|
|
||||||
// Set real dimensions
|
// Set real dimensions
|
||||||
// _w = 46 * fontWidth + 10;
|
// _w = 46 * fontWidth + 10;
|
||||||
|
@ -56,48 +58,53 @@ VideoDialog::VideoDialog(OSystem* osystem, DialogContainer* parent,
|
||||||
xpos = 5; ypos = 10;
|
xpos = 5; ypos = 10;
|
||||||
|
|
||||||
// Video renderer
|
// Video renderer
|
||||||
myRendererPopup = new PopUpWidget(this, font, xpos, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "Renderer: ", lwidth,
|
items.push_back("Software");
|
||||||
kRendererChanged);
|
|
||||||
myRendererPopup->appendEntry("Software", 1);
|
|
||||||
#ifdef DISPLAY_OPENGL
|
#ifdef DISPLAY_OPENGL
|
||||||
myRendererPopup->appendEntry("OpenGL", 2);
|
items.push_back("OpenGL");
|
||||||
#endif
|
#endif
|
||||||
|
myRendererPopup = new PopUpWidget(this, font, xpos, ypos, pwidth, lineHeight,
|
||||||
|
items, "Renderer: ", lwidth,
|
||||||
|
kRendererChanged);
|
||||||
wid.push_back(myRendererPopup);
|
wid.push_back(myRendererPopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// Video filter
|
// Video filter
|
||||||
myFilterPopup = new PopUpWidget(this, font, xpos, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "GL Filter: ", lwidth);
|
items.push_back("Linear");
|
||||||
myFilterPopup->appendEntry("Linear", 1);
|
items.push_back("Nearest");
|
||||||
myFilterPopup->appendEntry("Nearest", 2);
|
myFilterPopup = new PopUpWidget(this, font, xpos, ypos, pwidth, lineHeight,
|
||||||
|
items, "GL Filter: ", lwidth);
|
||||||
wid.push_back(myFilterPopup);
|
wid.push_back(myFilterPopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// GL FS stretch
|
// GL FS stretch
|
||||||
myFSStretchPopup = new PopUpWidget(this, font, xpos, ypos,
|
items.clear();
|
||||||
pwidth, lineHeight, "GL Stretch: ", lwidth);
|
items.push_back("Never");
|
||||||
myFSStretchPopup->appendEntry("Never", 1);
|
items.push_back("UI mode");
|
||||||
myFSStretchPopup->appendEntry("UI mode", 2);
|
items.push_back("TIA mode");
|
||||||
myFSStretchPopup->appendEntry("TIA mode", 3);
|
items.push_back("Always");
|
||||||
myFSStretchPopup->appendEntry("Always", 4);
|
myFSStretchPopup = new PopUpWidget(this, font, xpos, ypos, pwidth, lineHeight,
|
||||||
|
items, "GL Stretch: ", lwidth);
|
||||||
wid.push_back(myFSStretchPopup);
|
wid.push_back(myFSStretchPopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// Palette
|
// Palette
|
||||||
|
items.clear();
|
||||||
|
items.push_back("Standard");
|
||||||
|
items.push_back("Z26");
|
||||||
|
items.push_back("User");
|
||||||
myPalettePopup = new PopUpWidget(this, font, xpos, ypos, pwidth,
|
myPalettePopup = new PopUpWidget(this, font, xpos, ypos, pwidth,
|
||||||
lineHeight, "Palette: ", lwidth);
|
lineHeight, items, "Palette: ", lwidth);
|
||||||
myPalettePopup->appendEntry("Standard", 1);
|
|
||||||
myPalettePopup->appendEntry("Z26", 2);
|
|
||||||
myPalettePopup->appendEntry("User", 3);
|
|
||||||
wid.push_back(myPalettePopup);
|
wid.push_back(myPalettePopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
// Fullscreen resolution
|
// Fullscreen resolution
|
||||||
|
items.clear();
|
||||||
|
for(uInt32 i = 0; i < instance().supportedResolutions().size(); ++i)
|
||||||
|
items.push_back(instance().supportedResolutions()[i].name);
|
||||||
myFSResPopup = new PopUpWidget(this, font, xpos, ypos, pwidth,
|
myFSResPopup = new PopUpWidget(this, font, xpos, ypos, pwidth,
|
||||||
lineHeight, "FS Res: ", lwidth);
|
lineHeight, items, "FS Res: ", lwidth);
|
||||||
for(uInt32 i = 0; i < instance()->supportedResolutions().size(); ++i)
|
|
||||||
myFSResPopup->appendEntry(instance()->supportedResolutions()[i].name, i+1);
|
|
||||||
wid.push_back(myFSResPopup);
|
wid.push_back(myFSResPopup);
|
||||||
ypos += lineHeight + 4;
|
ypos += lineHeight + 4;
|
||||||
|
|
||||||
|
@ -220,78 +227,82 @@ void VideoDialog::loadConfig()
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
// Renderer setting
|
// Renderer setting
|
||||||
s = instance()->settings().getString("video");
|
s = instance().settings().getString("video");
|
||||||
if(s == "soft") myRendererPopup->setSelectedTag(1);
|
myRendererPopup->clearSelection();
|
||||||
else if(s == "gl") myRendererPopup->setSelectedTag(2);
|
if(s == "soft") myRendererPopup->setSelected(0);
|
||||||
|
else if(s == "gl") myRendererPopup->setSelected(1);
|
||||||
|
|
||||||
// Filter setting
|
// Filter setting
|
||||||
s = instance()->settings().getString("gl_filter");
|
s = instance().settings().getString("gl_filter");
|
||||||
if(s == "linear") myFilterPopup->setSelectedTag(1);
|
myFilterPopup->clearSelection();
|
||||||
else if(s == "nearest") myFilterPopup->setSelectedTag(2);
|
if(s == "linear") myFilterPopup->setSelected(0);
|
||||||
|
else if(s == "nearest") myFilterPopup->setSelected(1);
|
||||||
|
|
||||||
// GL stretch setting
|
// GL stretch setting
|
||||||
s = instance()->settings().getString("gl_fsmax");
|
s = instance().settings().getString("gl_fsmax");
|
||||||
if(s == "never") myFSStretchPopup->setSelectedTag(1);
|
myFSStretchPopup->clearSelection();
|
||||||
else if(s == "ui") myFSStretchPopup->setSelectedTag(2);
|
if(s == "never") myFSStretchPopup->setSelected(0);
|
||||||
else if(s == "tia") myFSStretchPopup->setSelectedTag(3);
|
else if(s == "ui") myFSStretchPopup->setSelected(1);
|
||||||
else if(s == "always") myFSStretchPopup->setSelectedTag(4);
|
else if(s == "tia") myFSStretchPopup->setSelected(2);
|
||||||
else myFSStretchPopup->setSelectedTag(1);
|
else if(s == "always") myFSStretchPopup->setSelected(3);
|
||||||
|
|
||||||
// Palette
|
// Palette
|
||||||
s = instance()->settings().getString("palette");
|
s = instance().settings().getString("palette");
|
||||||
if(s == "standard") myPalettePopup->setSelectedTag(1);
|
myPalettePopup->clearSelection();
|
||||||
else if(s == "z26") myPalettePopup->setSelectedTag(2);
|
if(s == "standard") myPalettePopup->setSelected(0);
|
||||||
else if(s == "user") myPalettePopup->setSelectedTag(3);
|
else if(s == "z26") myPalettePopup->setSelected(1);
|
||||||
|
else if(s == "user") myPalettePopup->setSelected(2);
|
||||||
|
|
||||||
// Fullscreen resolution
|
// Fullscreen resolution
|
||||||
s = instance()->settings().getString("fullres");
|
s = instance().settings().getString("fullres");
|
||||||
myFSResPopup->setSelectedName(s);
|
myFSResPopup->clearSelection();
|
||||||
if(myFSResPopup->getSelectedTag() < 0)
|
myFSResPopup->setSelected(s);
|
||||||
|
if(myFSResPopup->getSelected() < 0)
|
||||||
myFSResPopup->setSelectedMax();
|
myFSResPopup->setSelectedMax();
|
||||||
|
|
||||||
// UI zoom level
|
// UI zoom level
|
||||||
s = instance()->settings().getString("zoom_ui");
|
s = instance().settings().getString("zoom_ui");
|
||||||
i = instance()->settings().getInt("zoom_ui");
|
i = instance().settings().getInt("zoom_ui");
|
||||||
myUIZoomSlider->setValue(i);
|
myUIZoomSlider->setValue(i);
|
||||||
myUIZoomLabel->setLabel(s);
|
myUIZoomLabel->setLabel(s);
|
||||||
|
|
||||||
// TIA zoom level
|
// TIA zoom level
|
||||||
s = instance()->settings().getString("zoom_tia");
|
s = instance().settings().getString("zoom_tia");
|
||||||
i = instance()->settings().getInt("zoom_tia");
|
i = instance().settings().getInt("zoom_tia");
|
||||||
myTIAZoomSlider->setValue(i);
|
myTIAZoomSlider->setValue(i);
|
||||||
myTIAZoomLabel->setLabel(s);
|
myTIAZoomLabel->setLabel(s);
|
||||||
|
|
||||||
// GL aspect ratio setting
|
// GL aspect ratio setting
|
||||||
s = instance()->settings().getString("gl_aspect");
|
s = instance().settings().getString("gl_aspect");
|
||||||
i = instance()->settings().getInt("gl_aspect");
|
i = instance().settings().getInt("gl_aspect");
|
||||||
myAspectRatioSlider->setValue(i);
|
myAspectRatioSlider->setValue(i);
|
||||||
myAspectRatioLabel->setLabel(s);
|
myAspectRatioLabel->setLabel(s);
|
||||||
|
|
||||||
// Framerate (0 or -1 means disabled)
|
// Framerate (0 or -1 means disabled)
|
||||||
s = instance()->settings().getString("framerate");
|
s = instance().settings().getString("framerate");
|
||||||
i = instance()->settings().getInt("framerate");
|
i = instance().settings().getInt("framerate");
|
||||||
myFrameRateSlider->setValue(i < 0 ? 0 : i);
|
myFrameRateSlider->setValue(i < 0 ? 0 : i);
|
||||||
myFrameRateLabel->setLabel(i < 0 ? "0" : s);
|
myFrameRateLabel->setLabel(i < 0 ? "0" : s);
|
||||||
|
|
||||||
// Fullscreen
|
// Fullscreen
|
||||||
b = instance()->settings().getBool("fullscreen");
|
b = instance().settings().getBool("fullscreen");
|
||||||
myFullscreenCheckbox->setState(b);
|
myFullscreenCheckbox->setState(b);
|
||||||
handleFullscreenChange(b);
|
handleFullscreenChange(b);
|
||||||
|
|
||||||
// PAL color-loss effect
|
// PAL color-loss effect
|
||||||
b = instance()->settings().getBool("colorloss");
|
b = instance().settings().getBool("colorloss");
|
||||||
myColorLossCheckbox->setState(b);
|
myColorLossCheckbox->setState(b);
|
||||||
|
|
||||||
// Use sync to vertical blank (GL mode only)
|
// Use sync to vertical blank (GL mode only)
|
||||||
b = instance()->settings().getBool("gl_vsync");
|
b = instance().settings().getBool("gl_vsync");
|
||||||
myUseVSyncCheckbox->setState(b);
|
myUseVSyncCheckbox->setState(b);
|
||||||
|
|
||||||
// Center window
|
// Center window
|
||||||
b = instance()->settings().getBool("center");
|
b = instance().settings().getBool("center");
|
||||||
myCenterCheckbox->setState(b);
|
myCenterCheckbox->setState(b);
|
||||||
|
|
||||||
// Make sure that mutually-exclusive items are not enabled at the same time
|
// Make sure that mutually-exclusive items are not enabled at the same time
|
||||||
i = myRendererPopup->getSelectedTag();
|
i = myRendererPopup->getSelected();
|
||||||
handleRendererChange(i);
|
handleRendererChange(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -303,85 +314,85 @@ void VideoDialog::saveConfig()
|
||||||
bool b;
|
bool b;
|
||||||
|
|
||||||
// Renderer setting
|
// Renderer setting
|
||||||
i = myRendererPopup->getSelectedTag();
|
i = myRendererPopup->getSelected();
|
||||||
if(i == 1) s = "soft";
|
if(i == 0) s = "soft";
|
||||||
else if(i == 2) s = "gl";
|
else if(i == 1) s = "gl";
|
||||||
instance()->settings().setString("video", s);
|
instance().settings().setString("video", s);
|
||||||
|
|
||||||
// Filter setting
|
// Filter setting
|
||||||
i = myFilterPopup->getSelectedTag();
|
i = myFilterPopup->getSelected();
|
||||||
if(i == 1) s = "linear";
|
if(i == 0) s = "linear";
|
||||||
else if(i == 2) s = "nearest";
|
else if(i == 1) s = "nearest";
|
||||||
instance()->settings().setString("gl_filter", s);
|
instance().settings().setString("gl_filter", s);
|
||||||
|
|
||||||
// GL stretch setting
|
// GL stretch setting
|
||||||
i = myFSStretchPopup->getSelectedTag();
|
i = myFSStretchPopup->getSelected();
|
||||||
if(i == 1) s = "never";
|
if(i == 0) s = "never";
|
||||||
else if(i == 2) s = "ui";
|
else if(i == 1) s = "ui";
|
||||||
else if(i == 3) s = "tia";
|
else if(i == 2) s = "tia";
|
||||||
else if(i == 4) s = "always";
|
else if(i == 3) s = "always";
|
||||||
instance()->settings().setString("gl_fsmax", s);
|
instance().settings().setString("gl_fsmax", s);
|
||||||
|
|
||||||
// Palette
|
// Palette
|
||||||
i = myPalettePopup->getSelectedTag();
|
i = myPalettePopup->getSelected();
|
||||||
if(i == 1) s = "standard";
|
if(i == 0) s = "standard";
|
||||||
else if(i == 2) s = "z26";
|
else if(i == 1) s = "z26";
|
||||||
else if(i == 3) s = "user";
|
else if(i == 2) s = "user";
|
||||||
instance()->settings().setString("palette", s);
|
instance().settings().setString("palette", s);
|
||||||
|
|
||||||
// Fullscreen resolution
|
// Fullscreen resolution
|
||||||
s = myFSResPopup->getSelectedString();
|
s = myFSResPopup->getSelectedString();
|
||||||
instance()->settings().setString("fullres", s);
|
instance().settings().setString("fullres", s);
|
||||||
|
|
||||||
// UI Scaler
|
// UI Scaler
|
||||||
s = myUIZoomLabel->getLabel();
|
s = myUIZoomLabel->getLabel();
|
||||||
instance()->settings().setString("zoom_ui", s);
|
instance().settings().setString("zoom_ui", s);
|
||||||
|
|
||||||
// TIA Scaler
|
// TIA Scaler
|
||||||
s = myTIAZoomLabel->getLabel();
|
s = myTIAZoomLabel->getLabel();
|
||||||
instance()->settings().setString("zoom_tia", s);
|
instance().settings().setString("zoom_tia", s);
|
||||||
|
|
||||||
// GL aspect ratio setting
|
// GL aspect ratio setting
|
||||||
s = myAspectRatioLabel->getLabel();
|
s = myAspectRatioLabel->getLabel();
|
||||||
instance()->settings().setString("gl_aspect", s);
|
instance().settings().setString("gl_aspect", s);
|
||||||
|
|
||||||
// Framerate
|
// Framerate
|
||||||
i = myFrameRateSlider->getValue();
|
i = myFrameRateSlider->getValue();
|
||||||
instance()->settings().setInt("framerate", i);
|
instance().settings().setInt("framerate", i);
|
||||||
if(&instance()->console())
|
if(&instance().console())
|
||||||
{
|
{
|
||||||
// Make sure auto-frame calculation is only enabled when necessary
|
// Make sure auto-frame calculation is only enabled when necessary
|
||||||
instance()->console().mediaSource().enableAutoFrame(i <= 0);
|
instance().console().mediaSource().enableAutoFrame(i <= 0);
|
||||||
instance()->console().setFramerate(i);
|
instance().console().setFramerate(i);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Fullscreen
|
// Fullscreen
|
||||||
b = myFullscreenCheckbox->getState();
|
b = myFullscreenCheckbox->getState();
|
||||||
instance()->settings().setBool("fullscreen", b);
|
instance().settings().setBool("fullscreen", b);
|
||||||
|
|
||||||
// PAL color-loss effect
|
// PAL color-loss effect
|
||||||
b = myColorLossCheckbox->getState();
|
b = myColorLossCheckbox->getState();
|
||||||
instance()->settings().setBool("colorloss", b);
|
instance().settings().setBool("colorloss", b);
|
||||||
|
|
||||||
// Use sync to vertical blank (GL mode only)
|
// Use sync to vertical blank (GL mode only)
|
||||||
b = myUseVSyncCheckbox->getState();
|
b = myUseVSyncCheckbox->getState();
|
||||||
instance()->settings().setBool("gl_vsync", b);
|
instance().settings().setBool("gl_vsync", b);
|
||||||
|
|
||||||
// Center window
|
// Center window
|
||||||
b = myCenterCheckbox->getState();
|
b = myCenterCheckbox->getState();
|
||||||
instance()->settings().setBool("center", b);
|
instance().settings().setBool("center", b);
|
||||||
|
|
||||||
// Finally, issue a complete framebuffer re-initialization
|
// Finally, issue a complete framebuffer re-initialization
|
||||||
instance()->createFrameBuffer(false);
|
instance().createFrameBuffer(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void VideoDialog::setDefaults()
|
void VideoDialog::setDefaults()
|
||||||
{
|
{
|
||||||
myRendererPopup->setSelectedTag(1);
|
myRendererPopup->setSelected(0);
|
||||||
myFilterPopup->setSelectedTag(1);
|
myFilterPopup->setSelected(0);
|
||||||
myFSStretchPopup->setSelectedTag(1);
|
myFSStretchPopup->setSelected(0);
|
||||||
myPalettePopup->setSelectedTag(1);
|
myPalettePopup->setSelected(0);
|
||||||
myFSResPopup->setSelectedMax();
|
myFSResPopup->setSelectedMax();
|
||||||
myUIZoomSlider->setValue(2);
|
myUIZoomSlider->setValue(2);
|
||||||
myUIZoomLabel->setLabel("2");
|
myUIZoomLabel->setLabel("2");
|
||||||
|
@ -398,7 +409,7 @@ void VideoDialog::setDefaults()
|
||||||
myCenterCheckbox->setState(true);
|
myCenterCheckbox->setState(true);
|
||||||
|
|
||||||
// Make sure that mutually-exclusive items are not enabled at the same time
|
// Make sure that mutually-exclusive items are not enabled at the same time
|
||||||
handleRendererChange(1); // 1 indicates software mode
|
handleRendererChange(0); // 0 indicates software mode
|
||||||
handleFullscreenChange(false); // indicates fullscreen deactivated
|
handleFullscreenChange(false); // indicates fullscreen deactivated
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -407,7 +418,7 @@ void VideoDialog::handleRendererChange(int item)
|
||||||
{
|
{
|
||||||
#ifdef DISPLAY_OPENGL
|
#ifdef DISPLAY_OPENGL
|
||||||
// When we're in software mode, certain OpenGL-related options are disabled
|
// When we're in software mode, certain OpenGL-related options are disabled
|
||||||
bool gl = (item > 1) ? true : false;
|
bool gl = (item > 0) ? true : false;
|
||||||
|
|
||||||
myFilterPopup->setEnabled(gl);
|
myFilterPopup->setEnabled(gl);
|
||||||
myFSStretchPopup->setEnabled(gl);
|
myFSStretchPopup->setEnabled(gl);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Widget.cxx,v 1.57 2008-02-06 13:45:24 stephena Exp $
|
// $Id: Widget.cxx,v 1.58 2008-06-13 13:14:52 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -35,7 +35,7 @@
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
Widget::Widget(GuiObject* boss, const GUI::Font& font,
|
Widget::Widget(GuiObject* boss, const GUI::Font& font,
|
||||||
int x, int y, int w, int h)
|
int x, int y, int w, int h)
|
||||||
: GuiObject(boss->instance(), boss->parent(), x, y, w, h),
|
: GuiObject(boss->instance(), boss->parent(), boss->dialog(), x, y, w, h),
|
||||||
_type(0),
|
_type(0),
|
||||||
_boss(boss),
|
_boss(boss),
|
||||||
_font((GUI::Font*)&font),
|
_font((GUI::Font*)&font),
|
||||||
|
@ -72,7 +72,7 @@ void Widget::draw()
|
||||||
|
|
||||||
_dirty = false;
|
_dirty = false;
|
||||||
|
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
|
|
||||||
if(!isVisible() || !_boss->isVisible())
|
if(!isVisible() || !_boss->isVisible())
|
||||||
return;
|
return;
|
||||||
|
@ -92,12 +92,12 @@ void Widget::draw()
|
||||||
{
|
{
|
||||||
x++; y++; w-=2; h-=2;
|
x++; y++; w-=2; h-=2;
|
||||||
}
|
}
|
||||||
fb.fillRect(x, y, w, h, (_flags & WIDGET_HILITED) ? _bgcolorhi : _bgcolor);
|
s.fillRect(x, y, w, h, (_flags & WIDGET_HILITED) ? _bgcolorhi : _bgcolor);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Draw border
|
// Draw border
|
||||||
if(hasBorder) {
|
if(hasBorder) {
|
||||||
fb.box(_x, _y, _w, _h, kColor, kShadowColor);
|
s.box(_x, _y, _w, _h, kColor, kShadowColor);
|
||||||
_x += 4;
|
_x += 4;
|
||||||
_y += 4;
|
_y += 4;
|
||||||
_w -= 8;
|
_w -= 8;
|
||||||
|
@ -127,7 +127,7 @@ void Widget::draw()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tell the framebuffer this area is dirty
|
// Tell the framebuffer this area is dirty
|
||||||
fb.addDirtyRect(getAbsX(), getAbsY(), oldW, oldH);
|
s.addDirtyRect(getAbsX(), getAbsY(), oldW, oldH);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
@ -228,7 +228,7 @@ bool Widget::isWidgetInChain(WidgetArray& list, Widget* find)
|
||||||
Widget* Widget::setFocusForChain(GuiObject* boss, WidgetArray& arr,
|
Widget* Widget::setFocusForChain(GuiObject* boss, WidgetArray& arr,
|
||||||
Widget* wid, int direction)
|
Widget* wid, int direction)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = boss->instance()->frameBuffer();
|
FBSurface& s = boss->dialog().surface();
|
||||||
int size = arr.size(), pos = -1;
|
int size = arr.size(), pos = -1;
|
||||||
Widget* tmp;
|
Widget* tmp;
|
||||||
for(int i = 0; i < size; ++i)
|
for(int i = 0; i < size; ++i)
|
||||||
|
@ -247,10 +247,10 @@ Widget* Widget::setFocusForChain(GuiObject* boss, WidgetArray& arr,
|
||||||
if(tmp->_hasFocus)
|
if(tmp->_hasFocus)
|
||||||
{
|
{
|
||||||
tmp->lostFocus();
|
tmp->lostFocus();
|
||||||
fb.frameRect(x, y, w, h, kDlgColor);
|
s.frameRect(x, y, w, h, kDlgColor);
|
||||||
|
|
||||||
tmp->setDirty(); tmp->draw();
|
tmp->setDirty(); tmp->draw();
|
||||||
fb.addDirtyRect(x, y, w, h);
|
s.addDirtyRect(x, y, w, h);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -286,10 +286,10 @@ Widget* Widget::setFocusForChain(GuiObject* boss, WidgetArray& arr,
|
||||||
w = rect.width(), h = rect.height();
|
w = rect.width(), h = rect.height();
|
||||||
|
|
||||||
tmp->receivedFocus();
|
tmp->receivedFocus();
|
||||||
fb.frameRect(x, y, w, h, kWidFrameColor, kDashLine);
|
s.frameRect(x, y, w, h, kWidFrameColor, kDashLine);
|
||||||
|
|
||||||
tmp->setDirty(); tmp->draw();
|
tmp->setDirty(); tmp->draw();
|
||||||
fb.addDirtyRect(x, y, w, h);
|
s.addDirtyRect(x, y, w, h);
|
||||||
|
|
||||||
return tmp;
|
return tmp;
|
||||||
}
|
}
|
||||||
|
@ -341,8 +341,8 @@ void StaticTextWidget::setLabel(const string& label)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void StaticTextWidget::drawWidget(bool hilite)
|
void StaticTextWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
fb.drawString(_font, _label, _x, _y, _w,
|
s.drawString(_font, _label, _x, _y, _w,
|
||||||
isEnabled() ? _textcolor : kColor, _align);
|
isEnabled() ? _textcolor : kColor, _align);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -408,8 +408,8 @@ void ButtonWidget::handleMouseUp(int x, int y, int button, int clickCount)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void ButtonWidget::drawWidget(bool hilite)
|
void ButtonWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
fb.drawString(_font, _label, _x, _y + (_h - _fontHeight)/2 + 1, _w,
|
s.drawString(_font, _label, _x, _y + (_h - _fontHeight)/2 + 1, _w,
|
||||||
!isEnabled() ? kColor : hilite ? _textcolorhi : _textcolor, _align);
|
!isEnabled() ? kColor : hilite ? _textcolorhi : _textcolor, _align);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -504,28 +504,28 @@ void CheckboxWidget::setState(bool state)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void CheckboxWidget::drawWidget(bool hilite)
|
void CheckboxWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
|
|
||||||
// Draw the box
|
// Draw the box
|
||||||
if(_drawBox)
|
if(_drawBox)
|
||||||
fb.box(_x, _y + _boxY, 14, 14, kColor, kShadowColor);
|
s.box(_x, _y + _boxY, 14, 14, kColor, kShadowColor);
|
||||||
|
|
||||||
// Do we draw a square or cross?
|
// Do we draw a square or cross?
|
||||||
fb.fillRect(_x + 2, _y + _boxY + 2, 10, 10, _bgcolor);
|
s.fillRect(_x + 2, _y + _boxY + 2, 10, 10, _bgcolor);
|
||||||
if(isEnabled())
|
if(isEnabled())
|
||||||
{
|
{
|
||||||
if(_state)
|
if(_state)
|
||||||
{
|
{
|
||||||
unsigned int* img = _fillRect ? checked_img_o : checked_img_x;
|
unsigned int* img = _fillRect ? checked_img_o : checked_img_x;
|
||||||
int color = _fillRect ? kWidFrameColor : kCheckColor;
|
int color = _fillRect ? kWidFrameColor : kCheckColor;
|
||||||
fb.drawBitmap(img, _x + 3, _y + _boxY + 3, color);
|
s.drawBitmap(img, _x + 3, _y + _boxY + 3, color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
fb.fillRect(_x + 2, _y + _boxY + 2, 10, 10, kColor);
|
s.fillRect(_x + 2, _y + _boxY + 2, 10, 10, kColor);
|
||||||
|
|
||||||
// Finally draw the label
|
// Finally draw the label
|
||||||
fb.drawString(_font, _label, _x + 20, _y + _textY, _w,
|
s.drawString(_font, _label, _x + 20, _y + _textY, _w,
|
||||||
isEnabled() ? kTextColor : kColor);
|
isEnabled() ? kTextColor : kColor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -650,24 +650,23 @@ bool SliderWidget::handleEvent(Event::Type e)
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void SliderWidget::drawWidget(bool hilite)
|
void SliderWidget::drawWidget(bool hilite)
|
||||||
{
|
{
|
||||||
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
FBSurface& s = _boss->dialog().surface();
|
||||||
|
|
||||||
// Draw the label, if any
|
// Draw the label, if any
|
||||||
if(_labelWidth > 0)
|
if(_labelWidth > 0)
|
||||||
fb.drawString(_font, _label, _x, _y + 2, _labelWidth,
|
s.drawString(_font, _label, _x, _y + 2, _labelWidth,
|
||||||
isEnabled() ? kTextColor : kColor, kTextAlignRight);
|
isEnabled() ? kTextColor : kColor, kTextAlignRight);
|
||||||
|
|
||||||
// Draw the box
|
// Draw the box
|
||||||
fb.box(_x + _labelWidth, _y, _w - _labelWidth, _h, kColor, kShadowColor);
|
s.box(_x + _labelWidth, _y, _w - _labelWidth, _h, kColor, kShadowColor);
|
||||||
|
|
||||||
// Fill the box
|
// Fill the box
|
||||||
fb.fillRect(_x + _labelWidth + 2, _y + 2, _w - _labelWidth - 4, _h - 4,
|
s.fillRect(_x + _labelWidth + 2, _y + 2, _w - _labelWidth - 4, _h - 4,
|
||||||
!isEnabled() ? kColor : kWidColor);
|
!isEnabled() ? kColor : kWidColor);
|
||||||
|
|
||||||
// Draw the 'bar'
|
// Draw the 'bar'
|
||||||
fb.fillRect(_x + _labelWidth + 2, _y + 2, valueToPos(_value), _h - 4,
|
s.fillRect(_x + _labelWidth + 2, _y + 2, valueToPos(_value), _h - 4,
|
||||||
!isEnabled() ? kColor :
|
!isEnabled() ? kColor : hilite ? kSliderColorHi : kSliderColor);
|
||||||
hilite ? kSliderColorHi : kSliderColor);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -13,17 +13,17 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Widget.hxx,v 1.61 2008-05-11 21:18:35 stephena Exp $
|
// $Id: Widget.hxx,v 1.62 2008-06-13 13:14:52 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
|
#include "Dialog.hxx"
|
||||||
|
|
||||||
#ifndef WIDGET_HXX
|
#ifndef WIDGET_HXX
|
||||||
#define WIDGET_HXX
|
#define WIDGET_HXX
|
||||||
|
|
||||||
class Dialog;
|
|
||||||
|
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
#include "bspf.hxx"
|
#include "bspf.hxx"
|
||||||
|
@ -88,7 +88,7 @@ enum {
|
||||||
This is the base class for all widgets.
|
This is the base class for all widgets.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: Widget.hxx,v 1.61 2008-05-11 21:18:35 stephena Exp $
|
@version $Id: Widget.hxx,v 1.62 2008-06-13 13:14:52 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class Widget : public GuiObject
|
class Widget : public GuiObject
|
||||||
{
|
{
|
||||||
|
|
|
@ -6,6 +6,7 @@ MODULE_OBJS := \
|
||||||
src/gui/BrowserDialog.o \
|
src/gui/BrowserDialog.o \
|
||||||
src/gui/CommandDialog.o \
|
src/gui/CommandDialog.o \
|
||||||
src/gui/CommandMenu.o \
|
src/gui/CommandMenu.o \
|
||||||
|
src/gui/ContextMenu.o \
|
||||||
src/gui/DialogContainer.o \
|
src/gui/DialogContainer.o \
|
||||||
src/gui/Dialog.o \
|
src/gui/Dialog.o \
|
||||||
src/gui/EditableWidget.o \
|
src/gui/EditableWidget.o \
|
||||||
|
|
Loading…
Reference in New Issue