mirror of https://github.com/stella-emu/stella.git
ContextMenu dialog now properly works with scrolled content (both with
the mouse and the keyboard arrow keys). Still TODO is change the scroll placeholder text into something that looks a little nicer (perhaps a graphic arrow or something). Added output of field header names when using 'listrominfo'. This makes it very easy to see what each column actually represents. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@1954 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
7b5be35320
commit
67f53ceb6b
|
@ -8,7 +8,7 @@
|
|||
// SS SS tt ee ll ll aa aa
|
||||
// SSSS ttt eeeee llll llll aaaaa
|
||||
//
|
||||
// Copyright (c) 1995-2010 wby Bradford W. Mott and the Stella team
|
||||
// Copyright (c) 1995-2010 by Bradford W. Mott and the Stella Team
|
||||
//
|
||||
// See the file "license" for information on usage and redistribution of
|
||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||
|
|
|
@ -269,6 +269,32 @@ PropertyType Properties::getPropertyType(const string& name)
|
|||
return LastPropType;
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void Properties::printHeader()
|
||||
{
|
||||
cout << "Cartridge_MD5|"
|
||||
<< "Cartridge_Manufacturer|"
|
||||
<< "Cartridge_ModelNo|"
|
||||
<< "Cartridge_Name|"
|
||||
<< "Cartridge_Note|"
|
||||
<< "Cartridge_Rarity|"
|
||||
<< "Cartridge_Sound|"
|
||||
<< "Cartridge_Type|"
|
||||
<< "Console_LeftDifficulty|"
|
||||
<< "Console_RightDifficulty|"
|
||||
<< "Console_TelevisionType|"
|
||||
<< "Console_SwapPorts|"
|
||||
<< "Controller_Left|"
|
||||
<< "Controller_Right|"
|
||||
<< "Controller_SwapPaddles|"
|
||||
<< "Display_Format|"
|
||||
<< "Display_YStart|"
|
||||
<< "Display_Height|"
|
||||
<< "Display_Phosphor|"
|
||||
<< "Display_PPBlend"
|
||||
<< endl;
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
const char* Properties::ourDefaultProperties[LastPropType] = {
|
||||
"", // Cartridge.MD5
|
||||
|
|
|
@ -165,6 +165,13 @@ class Properties
|
|||
*/
|
||||
static PropertyType getPropertyType(const string& name);
|
||||
|
||||
/**
|
||||
When printing each collection of ROM properties, it is useful to
|
||||
see which columns correspond to the output fields; this method
|
||||
provides that output.
|
||||
*/
|
||||
static void printHeader();
|
||||
|
||||
private:
|
||||
// The array of properties
|
||||
string myProperties[LastPropType];
|
||||
|
|
|
@ -219,6 +219,7 @@ void PropertiesSet::print() const
|
|||
}
|
||||
|
||||
// Now, print the resulting list
|
||||
Properties::printHeader();
|
||||
for(PropsList::const_iterator i = list.begin(); i != list.end(); ++i)
|
||||
i->second.print();
|
||||
}
|
||||
|
|
|
@ -30,11 +30,11 @@ ContextMenu::ContextMenu(GuiObject* boss, const GUI::Font& font,
|
|||
const StringMap& items, int cmd)
|
||||
: Dialog(&boss->instance(), &boss->parent(), 0, 0, 16, 16),
|
||||
CommandSender(boss),
|
||||
_currentItem(-1),
|
||||
_selectedItem(-1),
|
||||
_rowHeight(font.getLineHeight()),
|
||||
_firstEntry(0),
|
||||
_numEntries(0),
|
||||
_selectedOffset(0),
|
||||
_selectedItem(-1),
|
||||
_showScroll(false),
|
||||
_font(&font),
|
||||
_cmd(cmd),
|
||||
|
@ -123,9 +123,9 @@ void ContextMenu::recalc(const GUI::Rect& image)
|
|||
void ContextMenu::setSelected(int item)
|
||||
{
|
||||
if(item >= 0 && item < (int)_entries.size())
|
||||
_selectedItem = _currentItem = item;
|
||||
_selectedItem = item;
|
||||
else
|
||||
_selectedItem = _currentItem = -1;
|
||||
_selectedItem = -1;
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -160,7 +160,7 @@ void ContextMenu::setSelectedMax()
|
|||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void ContextMenu::clearSelection()
|
||||
{
|
||||
_selectedItem = _currentItem = -1;
|
||||
_selectedItem = -1;
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
|
@ -249,12 +249,6 @@ void ContextMenu::handleEvent(Event::Type e)
|
|||
case Event::UIRight:
|
||||
moveDown();
|
||||
break;
|
||||
case Event::UIHome:
|
||||
drawCurrentSelection(0);
|
||||
break;
|
||||
case Event::UIEnd:
|
||||
drawCurrentSelection(_entries.size()-1);
|
||||
break;
|
||||
case Event::UICancel:
|
||||
close();
|
||||
break;
|
||||
|
@ -274,29 +268,27 @@ int ContextMenu::findItem(int x, int y) const
|
|||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void ContextMenu::drawCurrentSelection(int item)
|
||||
{
|
||||
if(item != _currentItem)
|
||||
{
|
||||
// Change selection
|
||||
_currentItem = item;
|
||||
_selectedOffset = item;
|
||||
setDirty();
|
||||
}
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void ContextMenu::sendSelection()
|
||||
{
|
||||
// Select the correct item when scrolling; we have to take into account
|
||||
// that the viewable items are no longer 1-to-1 with the entries
|
||||
int item = _currentItem;
|
||||
int item = _firstEntry + _selectedOffset;
|
||||
|
||||
if(_showScroll)
|
||||
{
|
||||
if(item == 0) // scroll up
|
||||
if(_selectedOffset == 0) // scroll up
|
||||
return scrollUp();
|
||||
else if(item == _numEntries+1) // scroll down
|
||||
else if(_selectedOffset == _numEntries+1) // scroll down
|
||||
return scrollDown();
|
||||
else
|
||||
item = item + _firstEntry - 1;
|
||||
item--;
|
||||
}
|
||||
|
||||
// We remove the dialog when the user has selected an item
|
||||
|
@ -313,40 +305,47 @@ void ContextMenu::sendSelection()
|
|||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void ContextMenu::moveUp()
|
||||
{
|
||||
int item = _currentItem;
|
||||
if(_showScroll)
|
||||
{
|
||||
if(item > 0) // scroll up
|
||||
// Reaching the top of the list means we have to scroll up, but keep the
|
||||
// current item offset
|
||||
// Otherwise, the offset should decrease by 1
|
||||
if(_selectedOffset == 1)
|
||||
scrollUp();
|
||||
else if(_selectedOffset > 1)
|
||||
drawCurrentSelection(_selectedOffset-1);
|
||||
}
|
||||
else
|
||||
{
|
||||
if(_firstEntry > item)
|
||||
_firstEntry--;
|
||||
if(_selectedOffset > 0)
|
||||
drawCurrentSelection(_selectedOffset-1);
|
||||
}
|
||||
}
|
||||
if(item > 0)
|
||||
drawCurrentSelection(--item);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void ContextMenu::moveDown()
|
||||
{
|
||||
int item = _currentItem;
|
||||
if(_showScroll)
|
||||
{
|
||||
if(item == _numEntries+1) // scroll down
|
||||
// Reaching the bottom of the list means we have to scroll down, but keep the
|
||||
// current item offset
|
||||
// Otherwise, the offset should increase by 1
|
||||
if(_selectedOffset == _numEntries)
|
||||
scrollDown();
|
||||
else if(_selectedOffset < (int)_entries.size())
|
||||
drawCurrentSelection(_selectedOffset+1);
|
||||
}
|
||||
else
|
||||
{
|
||||
if(_firstEntry + _numEntries < (int)_entries.size())
|
||||
_firstEntry++;
|
||||
if(_selectedOffset < (int)_entries.size() - 1)
|
||||
drawCurrentSelection(_selectedOffset+1);
|
||||
}
|
||||
setDirty();
|
||||
}
|
||||
if(item < (int)_entries.size() - 1)
|
||||
drawCurrentSelection(++item);
|
||||
}
|
||||
|
||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||
void ContextMenu::scrollUp()
|
||||
{
|
||||
if(_firstEntry > _currentItem)
|
||||
if(_firstEntry > 0)
|
||||
{
|
||||
_firstEntry--;
|
||||
setDirty();
|
||||
|
@ -379,10 +378,9 @@ void ContextMenu::drawDialog()
|
|||
|
||||
// Draw the entries, taking scroll buttons into account
|
||||
int x = _x + 2, y = _y + 2, w = _w - 4;
|
||||
cerr << "_firstEntry = " << _firstEntry << ", _numEntries = " << _numEntries << endl;
|
||||
|
||||
// Show top scroll area
|
||||
int offset = _firstEntry;
|
||||
int offset = _selectedOffset;
|
||||
if(_showScroll)
|
||||
{
|
||||
s.drawString(_font, " ^^^^^", x + 1, y + 2, w, kTextColor);
|
||||
|
@ -390,12 +388,12 @@ cerr << "_firstEntry = " << _firstEntry << ", _numEntries = " << _numEntries <<
|
|||
offset--;
|
||||
}
|
||||
|
||||
for(int i = _firstEntry; i < _firstEntry + _numEntries; ++i)
|
||||
for(int i = _firstEntry, current = 0; i < _firstEntry + _numEntries; ++i, ++current)
|
||||
{
|
||||
bool hilite = (i-offset) == _currentItem;
|
||||
bool hilite = offset == current;
|
||||
if(hilite) s.fillRect(x, y, w, _rowHeight, kTextColorHi);
|
||||
s.drawString(_font, _entries[i].first, x + 1, y + 2, w,
|
||||
hilite ? kWidColor : kTextColor);
|
||||
!hilite ? kTextColor : kWidColor);
|
||||
y += _rowHeight;
|
||||
}
|
||||
|
||||
|
|
|
@ -85,7 +85,6 @@ class ContextMenu : public Dialog, public CommandSender
|
|||
|
||||
private:
|
||||
void recalc(const GUI::Rect& image);
|
||||
void drawMenuEntry(int entry, bool hilite);
|
||||
|
||||
int findItem(int x, int y) const;
|
||||
void drawCurrentSelection(int item);
|
||||
|
@ -94,16 +93,14 @@ class ContextMenu : public Dialog, public CommandSender
|
|||
void moveDown();
|
||||
void scrollUp();
|
||||
void scrollDown();
|
||||
|
||||
void sendSelection();
|
||||
|
||||
private:
|
||||
StringMap _entries;
|
||||
|
||||
int _currentItem;
|
||||
int _selectedItem;
|
||||
int _rowHeight;
|
||||
int _firstEntry, _numEntries;
|
||||
int _selectedOffset, _selectedItem;
|
||||
bool _showScroll;
|
||||
|
||||
const GUI::Font* _font;
|
||||
|
|
Loading…
Reference in New Issue