summaryrefslogtreecommitdiff
path: root/src/gui/listbox.cpp
diff options
context:
space:
mode:
authorBjörn Steinbrink <B.Steinbrink@gmx.de>2005-07-31 15:45:33 +0000
committerBjörn Steinbrink <B.Steinbrink@gmx.de>2005-07-31 15:45:33 +0000
commitb7b9299ab765647807f25dc95e8b8cb57f6eb1c5 (patch)
tree7b9a68497ee4b8d19cddc226803b34172b5149fd /src/gui/listbox.cpp
parent51bfbd368cc455b037393d3383346640113e915b (diff)
downloadmana-client-b7b9299ab765647807f25dc95e8b8cb57f6eb1c5.tar.gz
mana-client-b7b9299ab765647807f25dc95e8b8cb57f6eb1c5.tar.bz2
mana-client-b7b9299ab765647807f25dc95e8b8cb57f6eb1c5.tar.xz
mana-client-b7b9299ab765647807f25dc95e8b8cb57f6eb1c5.zip
Added check to stop scrolling at map borders. Small cleanup in the listbox drawing code.
Diffstat (limited to 'src/gui/listbox.cpp')
-rw-r--r--src/gui/listbox.cpp28
1 files changed, 13 insertions, 15 deletions
diff --git a/src/gui/listbox.cpp b/src/gui/listbox.cpp
index 3f82fe1b..fee67cbd 100644
--- a/src/gui/listbox.cpp
+++ b/src/gui/listbox.cpp
@@ -44,27 +44,25 @@ void ListBox::draw(gcn::Graphics *graphics)
graphics->setColor(gcn::Color(110, 160, 255));
graphics->setFont(getFont());
- int i;
int fontHeight = getFont()->getHeight();
- int y = 0;
- for (i = 0; i < mListModel->getNumberOfElements(); ++i)
- {
- if (i == mSelected) {
- if (useOpenGL) {
+ // Draw rectangle below the selected list element
+ if (mSelected >= 0) {
+ if (useOpenGL) {
#ifdef USE_OPENGL
- dynamic_cast<gcn::OpenGLGraphics*>(graphics)->fillRectangle(
- gcn::Rectangle(0, y, getWidth(), fontHeight));
+ dynamic_cast<gcn::OpenGLGraphics*>(graphics)->fillRectangle(
+ gcn::Rectangle(0, fontHeight * mSelected, getWidth(), fontHeight));
#endif
- }
- else {
- dynamic_cast<gcn::SDLGraphics*>(graphics)->fillRectangle(
- gcn::Rectangle(0, y, getWidth(), fontHeight));
- }
}
+ else {
+ dynamic_cast<gcn::SDLGraphics*>(graphics)->fillRectangle(
+ gcn::Rectangle(0, fontHeight * mSelected, getWidth(), fontHeight));
+ }
+ }
+ // Draw the list elements
+ for (int i = 0, y = 0; i < mListModel->getNumberOfElements(); ++i, y += fontHeight)
+ {
graphics->drawText(mListModel->getElementAt(i), 1, y);
-
- y += fontHeight;
}
}