aboutsummaryrefslogtreecommitdiff
path: root/gui/PopUpWidget.cpp
diff options
context:
space:
mode:
authorMax Horn2002-12-13 21:35:04 +0000
committerMax Horn2002-12-13 21:35:04 +0000
commit7c9ba3a63a6aac77931e489e90ef46ea617835e6 (patch)
tree73b172d328a5e696d9f27c85b41e329c32f3d16d /gui/PopUpWidget.cpp
parent80a962dd025f488e2ab770ac42462af61c72b578 (diff)
downloadscummvm-rg350-7c9ba3a63a6aac77931e489e90ef46ea617835e6.tar.gz
scummvm-rg350-7c9ba3a63a6aac77931e489e90ef46ea617835e6.tar.bz2
scummvm-rg350-7c9ba3a63a6aac77931e489e90ef46ea617835e6.zip
added keyboard & scroll wheel support
svn-id: r5937
Diffstat (limited to 'gui/PopUpWidget.cpp')
-rw-r--r--gui/PopUpWidget.cpp119
1 files changed, 79 insertions, 40 deletions
diff --git a/gui/PopUpWidget.cpp b/gui/PopUpWidget.cpp
index dd4a571b7a..4185cb0857 100644
--- a/gui/PopUpWidget.cpp
+++ b/gui/PopUpWidget.cpp
@@ -47,6 +47,10 @@ static uint32 up_down_arrows[8] = {
const ScummVM::String PopUpWidget::emptyStr;
+//
+// PopUpDialog
+//
+
class PopUpDialog : public Dialog {
protected:
PopUpWidget *_popUpBoss;
@@ -59,20 +63,19 @@ public:
void drawDialog();
- void handleMouseDown(int x, int y, int button, int clickCount);
+// void handleMouseDown(int x, int y, int button, int clickCount);
void handleMouseUp(int x, int y, int button, int clickCount);
-// void handleMouseWheel(int x, int y, int direction); // Scroll through entries with scroll wheel
+ void handleMouseWheel(int x, int y, int direction); // Scroll through entries with scroll wheel
void handleMouseMoved(int x, int y, int button); // Redraw selections depending on mouse position
-// bool handleKeyDown(uint16 ascii, int keycode, int modifiers); // Scroll through entries with arrow keys etc.
+ void handleKeyDown(uint16 ascii, int keycode, int modifiers); // Scroll through entries with arrow keys etc.
// void handleCommand(CommandSender *sender, uint32 cmd, uint32 data);
protected:
-// void backupMenuBackground();
-// void restoreMenuBackground();
-
void drawMenuEntry(int entry, bool hilite);
int findItem(int x, int y) const;
+ void setSelection(int item);
+ bool isMouseDown();
};
PopUpDialog::PopUpDialog(PopUpWidget *boss, int clickX, int clickY)
@@ -118,11 +121,6 @@ void PopUpDialog::drawDialog()
_gui->addDirtyRect(_x, _y, _w, _h);
}
-void PopUpDialog::handleMouseDown(int x, int y, int button, int clickCount)
-{
-}
-
-
void PopUpDialog::handleMouseUp(int x, int y, int button, int clickCount)
{
// Mouse was released. If it wasn't moved much since the original mouse down,
@@ -137,21 +135,59 @@ void PopUpDialog::handleMouseUp(int x, int y, int button, int clickCount)
_openTime = (uint32)-1;
}
+void PopUpDialog::handleMouseWheel(int x, int y, int direction)
+{
+ if (direction < 0) {
+ if (_selection > 0)
+ setSelection(_selection-1);
+ } else if (direction > 0) {
+ if (_selection < _popUpBoss->_entries.size()-1)
+ setSelection(_selection+1);
+ }
+}
+
void PopUpDialog::handleMouseMoved(int x, int y, int button)
{
- // Compute over which item
+ // Compute over which item the mouse is...
int item = findItem(x, y);
- if (item != _selection) {
- // Undraw old selection
- if (_selection >= 0)
- drawMenuEntry(_selection, false);
- // Change selection
- _selection = item;
+ if (item == -1 && !isMouseDown())
+ return;
- // Draw new selection
- if (item >= 0)
- drawMenuEntry(item, true);
+ // ...and update the selection accordingly
+ setSelection(item);
+}
+
+void PopUpDialog::handleKeyDown(uint16 ascii, int keycode, int modifiers)
+{
+ if (keycode == 27) { // escape
+ close();
+ return;
+ }
+
+ if (isMouseDown())
+ return;
+
+ switch (keycode) {
+ case '\n': // enter/return
+ case '\r':
+ setResult(_selection);
+ close();
+ break;
+ case 256+17: // up arrow
+ if (_selection > 0)
+ setSelection(_selection-1);
+ break;
+ case 256+18: // down arrow
+ if (_selection < _popUpBoss->_entries.size()-1)
+ setSelection(_selection+1);
+ break;
+ case 256+22: // home
+ setSelection(0);
+ break;
+ case 256+23: // end
+ setSelection(_popUpBoss->_entries.size()-1);
+ break;
}
}
@@ -160,28 +196,33 @@ int PopUpDialog::findItem(int x, int y) const
if (x >= 0 && x < _w && y >= 0 && y < _h) {
return (y-2) / kLineHeight;
}
- return _popUpBoss->_selectedItem;
+ return -1;
}
-/*
-void PopUpWidget::backupMenuBackground()
+void PopUpDialog::setSelection(int item)
{
- NewGui *gui = _boss->getGui();
+ if (item != _selection) {
+ // Undraw old selection
+ if (_selection >= 0)
+ drawMenuEntry(_selection, false);
+
+ // Change selection
+ _selection = item;
- assert(_menu.buffer);
- gui->blitToBuffer(_menu.x1, _menu.y1, _menu.w, _menu.h, _menu.buffer, _menu.w * 2);
+ // Draw new selection
+ if (item >= 0)
+ drawMenuEntry(item, true);
+ }
}
-void PopUpWidget::restoreMenuBackground()
+bool PopUpDialog::isMouseDown()
{
- NewGui *gui = _boss->getGui();
-
- assert(_menu.buffer);
- gui->blitFromBuffer(_menu.x1, _menu.y1, _menu.w, _menu.h, _menu.buffer, _menu.w * 2);
- gui->addDirtyRect(_menu.x1, _menu.y1, _menu.w, _menu.h);
- draw();
+ // TODO/FIXME - 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::drawMenuEntry(int entry, bool hilite)
{
@@ -193,17 +234,15 @@ void PopUpDialog::drawMenuEntry(int entry, bool hilite)
_gui->fillRect(x, y, w, kLineHeight,
hilite ? _gui->_textcolorhi : _gui->_bgcolor);
- _gui->drawString(_popUpBoss->_entries[entry].name, x+1, y+1, w-2,
+ _gui->drawString(_popUpBoss->_entries[entry].name, x+1, y+2, w-2,
hilite ? _gui->_bgcolor : _gui->_textcolor);
_gui->addDirtyRect(x, y, w, kLineHeight);
}
+
//
+// PopUpWidget
//
-//
-//
-//
-
PopUpWidget::PopUpWidget(Dialog *boss, int x, int y, int w, int h)
: Widget(boss, x, y-1, w, h+2), CommandSender(boss)