diff options
author | kh1 <qt-info@nokia.com> | 2010-05-17 13:56:58 (GMT) |
---|---|---|
committer | kh1 <qt-info@nokia.com> | 2010-05-17 14:00:58 (GMT) |
commit | 25dd6dfe1c7c78370e7cbb266234f6ec5cf0eb95 (patch) | |
tree | 709745242b1c5bd963cf793cb64b8dcfedbc67d0 | |
parent | cb3d2252eaacf35a5b3c76eaa884ab4b46af74dd (diff) | |
download | Qt-25dd6dfe1c7c78370e7cbb266234f6ec5cf0eb95.zip Qt-25dd6dfe1c7c78370e7cbb266234f6ec5cf0eb95.tar.gz Qt-25dd6dfe1c7c78370e7cbb266234f6ec5cf0eb95.tar.bz2 |
Assistant has unnecessary repaints when expand/collapse selected node.
Task-number: QTBUG-10575
Reviewed-by: ck
-rw-r--r-- | tools/assistant/tools/assistant/contentwindow.cpp | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/tools/assistant/tools/assistant/contentwindow.cpp b/tools/assistant/tools/assistant/contentwindow.cpp index e0347c8..8afa1df 100644 --- a/tools/assistant/tools/assistant/contentwindow.cpp +++ b/tools/assistant/tools/assistant/contentwindow.cpp @@ -133,11 +133,13 @@ bool ContentWindow::eventFilter(QObject *o, QEvent *e) if (m_contentWidget && o == m_contentWidget->viewport() && e->type() == QEvent::MouseButtonRelease) { QMouseEvent *me = static_cast<QMouseEvent*>(e); - QModelIndex index = m_contentWidget->indexAt(me->pos()); - QItemSelectionModel *sm = m_contentWidget->selectionModel(); + const QModelIndex &index = m_contentWidget->indexAt(me->pos()); + if (!index.isValid()) + return QWidget::eventFilter(o, e); - Qt::MouseButtons button = me->button(); - if (index.isValid() && (sm && sm->isSelected(index))) { + const Qt::MouseButtons button = me->button(); + QItemSelectionModel *sm = m_contentWidget->selectionModel(); + if (sm->isSelected(index)) { if ((button == Qt::LeftButton && (me->modifiers() & Qt::ControlModifier)) || (button == Qt::MidButton)) { QHelpContentModel *contentModel = @@ -189,9 +191,11 @@ void ContentWindow::itemClicked(const QModelIndex &index) qobject_cast<QHelpContentModel*>(m_contentWidget->model()); if (contentModel) { - QHelpContentItem *itm = contentModel->contentItemAt(index); - if (itm) - emit linkActivated(itm->url()); + if (QHelpContentItem *itm = contentModel->contentItemAt(index)) { + const QUrl &url = itm->url(); + if (url != CentralWidget::instance()->currentSource()) + emit linkActivated(url); + } } } |