mirror of https://github.com/stella-emu/stella.git
made image area in Launcher a square to allow better display of vertical oriented images (e.g. boxes)
changed unused image area background to black
This commit is contained in:
parent
7c58ea2a61
commit
27c694ac0e
|
@ -322,9 +322,6 @@ bool FileListWidget::handleKeyDown(StellaKey key, StellaMod mod)
|
|||
if(StellaModTest::isAlt(mod))
|
||||
{
|
||||
handled = true;
|
||||
#ifdef DEBUG_BUILD
|
||||
cerr << " FileListWidget::handleKeyDown " << mod << ", " << key << endl;
|
||||
#endif
|
||||
switch(key)
|
||||
{
|
||||
case KBDK_HOME:
|
||||
|
|
|
@ -323,11 +323,11 @@ void LauncherDialog::addRomWidgets(int ypos)
|
|||
{
|
||||
xpos += myList->getWidth() + fontWidth;
|
||||
|
||||
// Initial surface size is the same as the viewable area
|
||||
// Initial surface size is the viewable area's width squared
|
||||
const Common::Size imgSize(TIAConstants::viewableWidth * imgZoom,
|
||||
TIAConstants::viewableHeight * imgZoom);
|
||||
// Calculate font area, and in the process the font that can be used
|
||||
TIAConstants::viewableWidth * imgZoom);
|
||||
|
||||
// Calculate font area, and in the process the font that can be used
|
||||
// Infofont is unknown yet, but used in image label too. Assuming maximum font height.
|
||||
int imageHeight = imgSize.h + RomImageWidget::labelHeight(_font);
|
||||
|
||||
|
@ -340,7 +340,7 @@ void LauncherDialog::addRomWidgets(int ypos)
|
|||
myRomImageWidget = new RomImageWidget(this, *myROMInfoFont,
|
||||
xpos, ypos, imageWidth, imageHeight);
|
||||
|
||||
const int yofs = imageHeight + VGAP * 2;
|
||||
const int yofs = imageHeight + myROMInfoFont->getFontHeight() / 2;
|
||||
myRomInfoWidget = new RomInfoWidget(this, *myROMInfoFont,
|
||||
xpos, ypos + yofs, imageWidth, myList->getHeight() - yofs);
|
||||
}
|
||||
|
|
|
@ -48,13 +48,13 @@ void RomImageWidget::setProperties(const FSNode& node, const Properties properti
|
|||
// Decide whether the information should be shown immediately
|
||||
if(instance().eventHandler().state() == EventHandlerState::LAUNCHER)
|
||||
parseProperties(node, full);
|
||||
#ifdef DEBUGGER_SUPPORT
|
||||
else
|
||||
{
|
||||
#ifdef DEBUGGER_SUPPORT
|
||||
cerr << "RomImageWidget::setProperties: else!" << endl;
|
||||
Logger::debug("RomImageWidget::setProperties: else!");
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -67,13 +67,13 @@ void RomImageWidget::clearProperties()
|
|||
// Decide whether the information should be shown immediately
|
||||
if(instance().eventHandler().state() == EventHandlerState::LAUNCHER)
|
||||
setDirty();
|
||||
#ifdef DEBUGGER_SUPPORT
|
||||
else
|
||||
{
|
||||
#ifdef DEBUGGER_SUPPORT
|
||||
cerr << "RomImageWidget::clearProperties: else!" << endl;
|
||||
Logger::debug("RomImageWidget::clearProperties: else!");
|
||||
#endif
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -127,6 +127,7 @@ void RomImageWidget::parseProperties(const FSNode& node, bool full)
|
|||
{
|
||||
myImageIdx = 0;
|
||||
myImageList.clear();
|
||||
myLabel.clear();
|
||||
|
||||
// Get a valid filename representing a snapshot file for this rom and load the snapshot
|
||||
const string& path = instance().snapshotLoadDir().getPath();
|
||||
|
@ -352,10 +353,12 @@ void RomImageWidget::handleMouseMoved(int x, int y)
|
|||
void RomImageWidget::drawWidget(bool hilite)
|
||||
{
|
||||
FBSurface& s = dialog().surface();
|
||||
const int yoff = myImageHeight;
|
||||
|
||||
if(!myHaveProperties || !mySurfaceIsValid || !mySurfaceErrorMsg.empty())
|
||||
{
|
||||
s.fillRect(_x, _y + 1, _w, _h - 1, _bgcolor);
|
||||
s.frameRect(_x, _y, _w, myImageHeight, kColor);
|
||||
}
|
||||
|
||||
if(!myHaveProperties)
|
||||
{
|
||||
|
@ -370,6 +373,7 @@ void RomImageWidget::drawWidget(bool hilite)
|
|||
const uInt32 x = _x * scale + ((_w * scale - dst.w()) >> 1);
|
||||
const uInt32 y = _y * scale + ((myImageHeight * scale - dst.h()) >> 1);
|
||||
|
||||
s.fillRect(_x, _y, _w, myImageHeight, 0);
|
||||
// Make sure when positioning the snapshot surface that we take
|
||||
// the dialog surface position into account
|
||||
const Common::Rect& s_dst = s.dstRect();
|
||||
|
@ -379,7 +383,7 @@ void RomImageWidget::drawWidget(bool hilite)
|
|||
else if(!mySurfaceErrorMsg.empty())
|
||||
{
|
||||
const uInt32 x = _x + ((_w - _font.getStringWidth(mySurfaceErrorMsg)) >> 1);
|
||||
const uInt32 y = _y + ((yoff - _font.getLineHeight()) >> 1);
|
||||
const uInt32 y = _y + ((myImageHeight - _font.getLineHeight()) >> 1);
|
||||
s.drawString(_font, mySurfaceErrorMsg, x, y, _w - 10, _textcolor);
|
||||
}
|
||||
// Draw the image label and counter
|
||||
|
@ -388,6 +392,7 @@ void RomImageWidget::drawWidget(bool hilite)
|
|||
const int yText = _y + myImageHeight + _font.getFontHeight() / 8;
|
||||
const int wText = _font.getStringWidth(buf.str());
|
||||
|
||||
s.fillRect(_x, yText, _w, _font.getFontHeight(), _bgcolor);
|
||||
if(myLabel.length())
|
||||
s.drawString(_font, myLabel, _x, yText, _w - wText - _font.getMaxCharWidth() * 2, _textcolor);
|
||||
if(myImageList.size())
|
||||
|
@ -396,7 +401,7 @@ void RomImageWidget::drawWidget(bool hilite)
|
|||
// Draw the navigation arrows
|
||||
myNavSurface->invalidate();
|
||||
if(isHighlighted() &&
|
||||
((myMouseLeft && myImageIdx) || (!myMouseLeft && myImageIdx < myImageList.size() - 1)))
|
||||
((myMouseLeft && myImageIdx) || (!myMouseLeft && myImageIdx + 1 < myImageList.size())))
|
||||
{
|
||||
const int w = _w / 64;
|
||||
const int w2 = 1; // w / 2;
|
||||
|
|
|
@ -47,6 +47,13 @@ void RomInfoWidget::setProperties(const FSNode& node, const Properties propertie
|
|||
// Decide whether the information should be shown immediately
|
||||
if(instance().eventHandler().state() == EventHandlerState::LAUNCHER)
|
||||
parseProperties(node, full);
|
||||
#ifdef DEBUGGER_SUPPORT
|
||||
else
|
||||
{
|
||||
cerr << "RomInfoWidget::setProperties: else!" << endl;
|
||||
Logger::debug("RomInfoWidget::setProperties: else!");
|
||||
}
|
||||
#endif
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -57,6 +64,13 @@ void RomInfoWidget::clearProperties()
|
|||
// Decide whether the information should be shown immediately
|
||||
if(instance().eventHandler().state() == EventHandlerState::LAUNCHER)
|
||||
setDirty();
|
||||
#ifdef DEBUGGER_SUPPORT
|
||||
else
|
||||
{
|
||||
cerr << "RomInfoWidget::clearProperties: else!" << endl;
|
||||
Logger::debug("RomInfoWidget::clearProperties: else!");
|
||||
}
|
||||
#endif
|
||||
myUrl.clear();
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue