aboutsummaryrefslogtreecommitdiff
path: root/lib/gui/elistbox.cpp
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-01-25 12:09:25 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-01-25 12:09:25 +0000
commit1681d7dadff09e071c4f79954a90969fb7815210 (patch)
treedeb99c3bb93e7e494b780905c7be36cecafc306b /lib/gui/elistbox.cpp
parent738adbb747be92f19cd7864490c982cac558358c (diff)
downloadenigma2-1681d7dadff09e071c4f79954a90969fb7815210.tar.gz
enigma2-1681d7dadff09e071c4f79954a90969fb7815210.zip
add selchanged signal to listbox
Diffstat (limited to 'lib/gui/elistbox.cpp')
-rw-r--r--lib/gui/elistbox.cpp15
1 files changed, 8 insertions, 7 deletions
diff --git a/lib/gui/elistbox.cpp b/lib/gui/elistbox.cpp
index a5d18e6b..f1efadfd 100644
--- a/lib/gui/elistbox.cpp
+++ b/lib/gui/elistbox.cpp
@@ -8,7 +8,7 @@ eListbox::eListbox(eWidget *parent)
,m_content_changed(false), m_top(0), m_selected(0), m_itemheight(25)
,m_items_per_page(0), m_selection_enabled(1), m_scrollbar(NULL)
{
- setContent(new eListboxStringContent());
+// setContent(new eListboxStringContent());
ePtr<eActionMap> ptr;
eActionMap::getInstance(ptr);
@@ -48,10 +48,13 @@ void eListbox::setScrollbarMode(int mode)
void eListbox::setContent(iListboxContent *content)
{
+ int oldsel = m_selected;
m_content = content;
if (content)
m_content->setListbox(this);
entryReset();
+ if (oldsel == m_selected)
+ /* emit */ selectionChanged();
}
void eListbox::moveSelection(int dir)
@@ -59,15 +62,12 @@ void eListbox::moveSelection(int dir)
/* refuse to do anything without a valid list. */
if (!m_content)
return;
-
/* if our list does not have one entry, don't do anything. */
if (!m_items_per_page)
return;
-
/* we need the old top/sel to see what we have to redraw */
int oldtop = m_top;
int oldsel = m_selected;
-
/* first, move cursor */
switch (dir)
{
@@ -128,7 +128,6 @@ void eListbox::moveSelection(int dir)
/* now, look wether the current selection is out of screen */
m_selected = m_content->cursorGet();
-
while (m_selected < m_top)
{
m_top -= m_items_per_page;
@@ -139,14 +138,16 @@ void eListbox::moveSelection(int dir)
/* m_top should be always valid here as it's selected */
m_top += m_items_per_page;
+ if (oldsel != m_selected)
+ /* emit */ selectionChanged();
+
updateScrollBar();
if (m_top != oldtop)
invalidate();
else if (m_selected != oldsel)
{
-
- /* redraw the old and newly selected */
+ /* redraw the old and newly selected */
gRegion inv = eRect(0, m_itemheight * (m_selected-m_top), size().width(), m_itemheight);
inv |= eRect(0, m_itemheight * (oldsel-m_top), size().width(), m_itemheight);