diff options
| author | Peter Penz <[email protected]> | 2010-11-04 19:04:18 +0000 |
|---|---|---|
| committer | Peter Penz <[email protected]> | 2010-11-04 19:04:18 +0000 |
| commit | 0dab03ed4cd2dd6fbc8fe86d33f400c574a4ba6d (patch) | |
| tree | 77435f2aa8c43541135a4e84044f0a3153a0d0ca /src/panels/information/informationpanel.cpp | |
| parent | 6da89c3f302d23638bfcb96370dc4377d800ff95 (diff) | |
Fix issue that moving the mouse above the viewport might trigger showing the meta-information of an only shortly hovered file.
svn path=/trunk/KDE/kdebase/apps/; revision=1193131
Diffstat (limited to 'src/panels/information/informationpanel.cpp')
| -rw-r--r-- | src/panels/information/informationpanel.cpp | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/src/panels/information/informationpanel.cpp b/src/panels/information/informationpanel.cpp index 86a7bb999..0fd67b2b6 100644 --- a/src/panels/information/informationpanel.cpp +++ b/src/panels/information/informationpanel.cpp @@ -96,18 +96,17 @@ void InformationPanel::requestDelayedItemInfo(const KFileItem& item) return; } + cancelRequest(); + if (item.isNull()) { // The cursor is above the viewport. If files are selected, // show information regarding the selection. if (m_selection.size() > 0) { - cancelRequest(); m_fileItem = KFileItem(); m_infoTimer->start(); } } else if (item.url().isValid() && !isEqualToShownUrl(item.url())) { // The cursor is above an item that is not shown currently - cancelRequest(); - m_urlCandidate = item.url(); m_fileItem = item; m_infoTimer->start(); @@ -308,8 +307,10 @@ void InformationPanel::cancelRequest() m_folderStatJob = 0; m_infoTimer->stop(); - m_urlChangedTimer->stop(); m_resetUrlTimer->stop(); + // Don't reset m_urlChangedTimer. As it is assured that the timeout of m_urlChangedTimer + // has the smallest interval (see init()), it is not possible that the exceeded timer + // would overwrite an information provided by a selection or hovering. m_invalidUrlCandidate.clear(); m_urlCandidate.clear(); @@ -328,26 +329,27 @@ void InformationPanel::markUrlAsInvalid() void InformationPanel::init() { - const int defaultDelay = 300; - m_infoTimer = new QTimer(this); - m_infoTimer->setInterval(defaultDelay); + m_infoTimer->setInterval(300); m_infoTimer->setSingleShot(true); connect(m_infoTimer, SIGNAL(timeout()), this, SLOT(slotInfoTimeout())); m_urlChangedTimer = new QTimer(this); - m_urlChangedTimer->setInterval(defaultDelay); + m_urlChangedTimer->setInterval(200); m_urlChangedTimer->setSingleShot(true); connect(m_urlChangedTimer, SIGNAL(timeout()), this, SLOT(showItemInfo())); m_resetUrlTimer = new QTimer(this); - m_resetUrlTimer->setInterval(defaultDelay * 3); + m_resetUrlTimer->setInterval(1000); m_resetUrlTimer->setSingleShot(true); connect(m_resetUrlTimer, SIGNAL(timeout()), this, SLOT(reset())); + Q_ASSERT(m_urlChangedTimer->interval() < m_infoTimer->interval()); + Q_ASSERT(m_urlChangedTimer->interval() < m_resetUrlTimer->interval()); + org::kde::KDirNotify* dirNotify = new org::kde::KDirNotify(QString(), QString(), QDBusConnection::sessionBus(), this); connect(dirNotify, SIGNAL(FileRenamed(QString, QString)), SLOT(slotFileRenamed(QString, QString))); |
