diff options
| author | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2009-07-16 07:43:17 +0000 |
|---|---|---|
| committer | trialuser02 <trialuser02@90c681e8-e032-0410-971d-27865f9a5e38> | 2009-07-16 07:43:17 +0000 |
| commit | 21f99dd9132a2974fbdc95f9c69da5eb13dd01a5 (patch) | |
| tree | f814955d45bb27429a6c8864fdd1bf79591f3464 /src | |
| parent | 8195a135768b85c7deb03272efdaf2b90085702e (diff) | |
| download | qmmp-21f99dd9132a2974fbdc95f9c69da5eb13dd01a5.tar.gz qmmp-21f99dd9132a2974fbdc95f9c69da5eb13dd01a5.tar.bz2 qmmp-21f99dd9132a2974fbdc95f9c69da5eb13dd01a5.zip | |
added Home/End hotkeys
git-svn-id: http://svn.code.sf.net/p/qmmp-dev/code/trunk/qmmp@1043 90c681e8-e032-0410-971d-27865f9a5e38
Diffstat (limited to 'src')
| -rw-r--r-- | src/ui/keyboardmanager.cpp | 147 | ||||
| -rw-r--r-- | src/ui/keyboardmanager.h | 20 |
2 files changed, 94 insertions, 73 deletions
diff --git a/src/ui/keyboardmanager.cpp b/src/ui/keyboardmanager.cpp index 7e76625cd..b931722d0 100644 --- a/src/ui/keyboardmanager.cpp +++ b/src/ui/keyboardmanager.cpp @@ -29,60 +29,65 @@ #include "mainwindow.h" -KeyboardManager::KeyboardManager ( PlayList* pl ) +KeyboardManager::KeyboardManager (PlayList* pl) { m_playlist = pl; } -bool KeyboardManager::handleKeyPress ( QKeyEvent* ke ) +bool KeyboardManager::handleKeyPress (QKeyEvent* ke) { bool handled = TRUE; - switch ( ke->key() ) + switch (ke->key()) { case Qt::Key_Up: - keyUp ( ke ); + keyUp (ke); break; case Qt::Key_Down: - keyDown ( ke ); + keyDown (ke); break; case Qt::Key_PageUp: - keyPgUp ( ke ); + keyPgUp (ke); break; case Qt::Key_PageDown: - keyPgDown ( ke ); + keyPgDown (ke); break; case Qt::Key_Enter: case Qt::Key_Return: - keyEnter ( ke ); + keyEnter (ke); + break; + case Qt::Key_Home: + keyHome(ke); + break; + case Qt::Key_End: + keyEnd(ke); + break; default: handled = FALSE; } return handled; } -bool KeyboardManager::handleKeyRelease ( QKeyEvent* ) +bool KeyboardManager::handleKeyRelease (QKeyEvent*) { return FALSE; } - - -void KeyboardManager::setModel ( PlayListModel *m ) +void KeyboardManager::setModel (PlayListModel *m) { m_playListModel = m; } -void KeyboardManager::keyUp ( QKeyEvent * ke ) +void KeyboardManager::keyUp (QKeyEvent * ke) { QList<int> rows = m_playListModel->getSelectedRows(); ListWidget* list_widget = m_playlist->listWidget(); - if ( rows.count() > 0 ) + if (rows.count() > 0) { if(rows[0] == 0 && rows.count() == 1) return; - if ( ! ( ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier ) ) + if (! (ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier)) { m_playListModel->clearSelection(); list_widget->setAnchorRow(-1); @@ -91,76 +96,76 @@ void KeyboardManager::keyUp ( QKeyEvent * ke ) bool select_top = false; int first_visible = list_widget->firstVisibleRow(); int last_visible = list_widget->visibleRows() + first_visible - 1; - foreach ( int i, rows ) + foreach (int i, rows) { - if ( i > last_visible || i < first_visible ) + if (i > last_visible || i < first_visible) { select_top = true; break; } } - if ( !select_top || ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier ) + if (!select_top || ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier) { - if ( ke->modifiers() == Qt::AltModifier ) + if (ke->modifiers() == Qt::AltModifier) { - m_playListModel->moveItems ( rows[0],rows[0] - 1 ); - list_widget->setAnchorRow ( list_widget->getAnchorRow() - 1 ); + m_playListModel->moveItems (rows[0],rows[0] - 1); + list_widget->setAnchorRow (list_widget->getAnchorRow() - 1); } else { - if ( rows.last() > list_widget->getAnchorRow() && ke->modifiers() & Qt::ShiftModifier ) + if (rows.last() > list_widget->getAnchorRow() && ke->modifiers() & Qt::ShiftModifier) { - m_playListModel->setSelected ( rows.last(),false ); + m_playListModel->setSelected (rows.last(),false); } - else if ( rows[0] > 0 ) + else if (rows[0] > 0) { - m_playListModel->setSelected ( rows[0] - 1,true ); + m_playListModel->setSelected (rows[0] - 1,true); } else { - m_playListModel->setSelected ( rows[0],true ); + m_playListModel->setSelected (rows[0],true); if(list_widget->getAnchorRow() == -1) list_widget->setAnchorRow(rows[0]); } - if ( ! ( ke->modifiers() & Qt::ShiftModifier ) && rows[0] > 0 ) - list_widget->setAnchorRow ( rows[0] - 1 ); + if (! (ke->modifiers() & Qt::ShiftModifier) && rows[0] > 0) + list_widget->setAnchorRow (rows[0] - 1); } } else { - m_playListModel->setSelected ( list_widget->firstVisibleRow(),true ); + m_playListModel->setSelected (list_widget->firstVisibleRow(),true); list_widget->setAnchorRow(list_widget->firstVisibleRow()); } rows = m_playListModel->getSelectedRows(); - if ( rows[0] < list_widget->firstVisibleRow() && list_widget->firstVisibleRow() > 0 ) + if (rows[0] < list_widget->firstVisibleRow() && list_widget->firstVisibleRow() > 0) { int r = rows.last() > list_widget->getAnchorRow() ? rows.last(): rows.first(); - if(ke->modifiers() & Qt::ShiftModifier && (r >= list_widget->firstVisibleRow() )) + if(ke->modifiers() & Qt::ShiftModifier && (r >= list_widget->firstVisibleRow())) ; else - list_widget->scroll ( list_widget->firstVisibleRow() - 1 ); + list_widget->scroll (list_widget->firstVisibleRow() - 1); } } else { //if(list_widget->getAnchorRow() == -1) list_widget->setAnchorRow(list_widget->firstVisibleRow()); - m_playListModel->setSelected ( list_widget->firstVisibleRow(),true ); + m_playListModel->setSelected (list_widget->firstVisibleRow(),true); } } -void KeyboardManager::keyDown ( QKeyEvent * ke ) +void KeyboardManager::keyDown (QKeyEvent * ke) { QList<int> rows = m_playListModel->getSelectedRows(); ListWidget* list_widget = m_playlist->listWidget(); //qWarning("count: %d",rows.count()); - if ( rows.count() > 0 ) + if (rows.count() > 0) { - if ( ! ( ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier ) ) + if (! (ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier)) { m_playListModel->clearSelection(); list_widget->setAnchorRow(-1); @@ -169,93 +174,107 @@ void KeyboardManager::keyDown ( QKeyEvent * ke ) bool select_top = false; int first_visible = list_widget->firstVisibleRow(); int last_visible = list_widget->visibleRows() + first_visible - 1; - foreach ( int i, rows ) + foreach (int i, rows) { - if ( i > last_visible || i < first_visible ) + if (i > last_visible || i < first_visible) { select_top = true; break; } } - if ( !select_top || ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier ) + if (!select_top || ke->modifiers() & Qt::ShiftModifier || ke->modifiers() & Qt::AltModifier) { - if ( ke->modifiers() == Qt::AltModifier ) + if (ke->modifiers() == Qt::AltModifier) { - m_playListModel->moveItems ( rows.last(),rows.last() + 1 ); - list_widget->setAnchorRow ( list_widget->getAnchorRow() + 1 ); + m_playListModel->moveItems (rows.last(),rows.last() + 1); + list_widget->setAnchorRow (list_widget->getAnchorRow() + 1); } else { //qWarning("list_widget %d",list_widget->getAnchorRow()); //qWarning("model count: %d rows.last(): %d",m_playListModel->count(),rows.last()); - if ( rows[0] < list_widget->getAnchorRow() && ke->modifiers() & Qt::ShiftModifier ) - m_playListModel->setSelected ( rows[0],false ); - else if ( rows.last() < m_playListModel->count() - 1 ) + if (rows[0] < list_widget->getAnchorRow() && ke->modifiers() & Qt::ShiftModifier) + m_playListModel->setSelected (rows[0],false); + else if (rows.last() < m_playListModel->count() - 1) { - m_playListModel->setSelected ( rows.last() + 1,true ); + m_playListModel->setSelected (rows.last() + 1,true); } else { - m_playListModel->setSelected ( rows.last(),true ); + m_playListModel->setSelected (rows.last(),true); if(list_widget->getAnchorRow() == -1) list_widget->setAnchorRow(rows.last()); } - if ( ! ( ke->modifiers() & Qt::ShiftModifier ) && rows.last() < m_playListModel->count() - 1 ) - list_widget->setAnchorRow ( rows.last() + 1 ); + if (! (ke->modifiers() & Qt::ShiftModifier) && rows.last() < m_playListModel->count() - 1) + list_widget->setAnchorRow (rows.last() + 1); } } else { - m_playListModel->setSelected ( list_widget->firstVisibleRow(),true ); + m_playListModel->setSelected (list_widget->firstVisibleRow(),true); list_widget->setAnchorRow(list_widget->firstVisibleRow()); } rows = m_playListModel->getSelectedRows(); - if ( !rows.isEmpty() && rows.last() >= list_widget->visibleRows() + list_widget->firstVisibleRow() ) + if (!rows.isEmpty() && rows.last() >= list_widget->visibleRows() + list_widget->firstVisibleRow()) { int r = rows.first() < list_widget->getAnchorRow() ? rows.first(): rows.last(); if(ke->modifiers() & Qt::ShiftModifier && - (r < list_widget->firstVisibleRow() + list_widget->visibleRows() )) + (r < list_widget->firstVisibleRow() + list_widget->visibleRows())) ; else - list_widget->scroll ( list_widget->firstVisibleRow() + 1 ); + list_widget->scroll (list_widget->firstVisibleRow() + 1); } } else { - m_playListModel->setSelected ( list_widget->firstVisibleRow(),true ); + m_playListModel->setSelected (list_widget->firstVisibleRow(),true); //if(list_widget->getAnchorRow() == -1) list_widget->setAnchorRow(list_widget->firstVisibleRow()); } } -void KeyboardManager::keyPgUp ( QKeyEvent * ) +void KeyboardManager::keyPgUp (QKeyEvent *) { ListWidget* list_widget = m_playlist->listWidget(); int page_size = list_widget->visibleRows(); - int offset= ( list_widget->firstVisibleRow()-page_size >= 0 ) ?list_widget->firstVisibleRow()-page_size:0; - list_widget->scroll ( offset ); + int offset= (list_widget->firstVisibleRow()-page_size >= 0) ?list_widget->firstVisibleRow()-page_size:0; + list_widget->scroll (offset); } -void KeyboardManager::keyPgDown ( QKeyEvent * ) +void KeyboardManager::keyPgDown (QKeyEvent *) { ListWidget* list_widget = m_playlist->listWidget(); int page_size = list_widget->visibleRows(); - int offset = ( list_widget->firstVisibleRow() +page_size < m_playListModel->count() ) ? + int offset = (list_widget->firstVisibleRow() +page_size < m_playListModel->count()) ? list_widget->firstVisibleRow() +page_size:m_playListModel->count() - 1; - list_widget->scroll ( offset ); + list_widget->scroll (offset); } -void KeyboardManager::keyEnter ( QKeyEvent * ) +void KeyboardManager::keyEnter (QKeyEvent *) { QList<int> rows = m_playListModel->getSelectedRows(); - MainWindow* mw = qobject_cast<MainWindow*> ( m_playlist->parentWidget() ); - if ( mw && rows.count() > 0 ) + MainWindow* mw = qobject_cast<MainWindow*> (m_playlist->parentWidget()); + if (mw && rows.count() > 0) { - m_playListModel->setCurrent ( rows[0] ); + m_playListModel->setCurrent (rows[0]); mw->replay(); } } + +void KeyboardManager::keyHome(QKeyEvent *) +{ + m_playlist->listWidget()->scroll (0); +} + +void KeyboardManager::keyEnd(QKeyEvent *) +{ + ListWidget* list_widget = m_playlist->listWidget(); + int page_size = list_widget->visibleRows(); + int scroll_to = m_playListModel->count() - page_size; + if(scroll_to >= 0) + list_widget->scroll(scroll_to); +} diff --git a/src/ui/keyboardmanager.h b/src/ui/keyboardmanager.h index 2b33b5ef9..791a93334 100644 --- a/src/ui/keyboardmanager.h +++ b/src/ui/keyboardmanager.h @@ -38,30 +38,32 @@ class KeyboardManager /*! * Constructor. Takes \b PlayList object as an argument. */ - KeyboardManager ( PlayList* ); + KeyboardManager (PlayList*); /*! * Handles key press events from \b PlayList object. Returns \b TRUE * if the key was handled, otherwise \b FALSE. */ - bool handleKeyPress ( QKeyEvent* ); + bool handleKeyPress (QKeyEvent*); /*! * Handles key release events from \b PlayList object. Returns \b TRUE * if the key was handled, otherwise \b FALSE. */ - bool handleKeyRelease ( QKeyEvent* ); + bool handleKeyRelease (QKeyEvent*); /*! * Inits the \b KeyboardManager object with data model. */ - void setModel ( PlayListModel* ); + void setModel (PlayListModel*); protected: - void keyUp ( QKeyEvent* ke ); - void keyDown ( QKeyEvent* ke ); - void keyPgUp ( QKeyEvent* ke ); - void keyPgDown ( QKeyEvent* ke ); - void keyEnter ( QKeyEvent* ke ); + void keyUp (QKeyEvent* ke); + void keyDown (QKeyEvent* ke); + void keyPgUp (QKeyEvent* ke); + void keyPgDown (QKeyEvent* ke); + void keyEnter (QKeyEvent* ke); + void keyHome(QKeyEvent* ke); + void keyEnd(QKeyEvent* ke); private: PlayList* m_playlist; PlayListModel* m_playListModel; |
