X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/494169d25068e3d3dd2dcc8b37b42d32df6935e7..ad83142d636daacda163509898f0afeacf95fdd8:/lib/gui/elistbox.cpp diff --git a/lib/gui/elistbox.cpp b/lib/gui/elistbox.cpp index 873cc937..e2f1c26f 100644 --- a/lib/gui/elistbox.cpp +++ b/lib/gui/elistbox.cpp @@ -96,17 +96,16 @@ void eListbox::moveSelection(int dir) /* now, look wether the current selection is out of screen */ m_selected = m_content->cursorGet(); - - if (m_selected < m_top) + + while (m_selected < m_top) { m_top -= m_items_per_page; if (m_top < 0) m_top = 0; - } else if (m_selected >= m_top + m_items_per_page) - { - /* m_top should be always valid here as it's selected */ - m_top += m_items_per_page; } + while (m_selected >= m_top + m_items_per_page) + /* m_top should be always valid here as it's selected */ + m_top += m_items_per_page; if (m_top != oldtop) invalidate(); @@ -124,7 +123,9 @@ void eListbox::moveSelection(int dir) void eListbox::moveSelectionTo(int index) { printf("Moving to listbox-entry with index %d\n", index); - // TODO: implement it + m_content->cursorHome(); + m_content->cursorMove(index); + moveSelection(justCheck); } int eListbox::event(int event, void *data, void *data2)