X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/cb928888f7e8b0450fc8c4cf0dd4f5ea3c46eb42..11289b4fc3efbc074b668d4516cd896f8ade9761:/src/tooltipmanager.cpp diff --git a/src/tooltipmanager.cpp b/src/tooltipmanager.cpp index 3caff4ae1..e287d85b7 100644 --- a/src/tooltipmanager.cpp +++ b/src/tooltipmanager.cpp @@ -104,7 +104,9 @@ bool ToolTipManager::eventFilter(QObject* watched, QEvent* event) void ToolTipManager::requestToolTip(const QModelIndex& index) { - if (index.column() == DolphinModel::Name) { + // only request a tooltip for the name column and when no selection or + // drag & drop operation is done (indicated by the left mouse button) + if ((index.column() == DolphinModel::Name) && !(QApplication::mouseButtons() & Qt::LeftButton)) { m_waitOnPreviewTimer->stop(); KToolTip::hideTip(); @@ -115,10 +117,9 @@ void ToolTipManager::requestToolTip(const QModelIndex& index) const QModelIndex dirIndex = m_proxyModel->mapToSource(index); m_item = m_dolphinModel->itemForIndex(dirIndex); - // Only start the previewJob when the mouse has been over this item for 200msec, - // this prevents a lot of useless previewJobs (when passing rapidly over a lot of items). + // only start the previewJob when the mouse has been over this item for 200 milliseconds, + // this prevents a lot of useless preview jobs when passing rapidly over a lot of items m_previewTimer->start(200); - // reset these variables m_preview = false; m_previewIsLate = false; m_previewPass = 0; @@ -161,7 +162,9 @@ void ToolTipManager::prepareToolTip() if (m_preview && m_previewIsLate) { // We got a preview, but it is late, the tooltip has already been shown. // So update the tooltip directly. - m_emptyRenderedKToolTipItem->setData(Qt::DecorationRole, KIcon(m_pix)); + if (m_emptyRenderedKToolTipItem != 0) { + m_emptyRenderedKToolTipItem->setData(Qt::DecorationRole, KIcon(m_pix)); + } return; } @@ -185,6 +188,8 @@ void ToolTipManager::showToolTip(KToolTipItem* tip) if (QApplication::mouseButtons() & Qt::LeftButton) { delete tip; tip = 0; + // m_emptyRenderedKToolTipItem is an alias for tip. + m_emptyRenderedKToolTipItem = 0; return; } @@ -272,59 +277,15 @@ void ToolTipManager::setPreviewPix(const KFileItem& item, return; } - QPixmap icon = pixmap; - // only paint borders if the pixmap is opaque - if (!icon.hasAlphaChannel()) { - // TODO: Make code from IconManager for drawing a border accessible for - // other classes (the following code has been adapted from IconManager). - // The frame is painted on top of the pixmap, this is needed to keep - // the text preview visually nice (the previewer adds ugly borders). - QPainter painter; - // make a buffer pixmap, tends to crash when 'icon' is directly painted ... - QPixmap framedIcon(icon.size().width(), pixmap.size().height()); - framedIcon.fill(); - const int width = framedIcon.width() - 1; - const int height = framedIcon.height() - 1; - - // draw the pixmap - painter.begin(&framedIcon); - painter.drawPixmap(0,0, icon); - - // draw the frame - painter.setRenderHint(QPainter::Antialiasing, false); - painter.setPen(QColor(0, 0, 0)); - painter.drawRect(0, 0, width - 0, height - 1); - painter.drawRect(1, 1, width - 2, height - 2); - painter.setPen(QColor(255, 255, 255)); - painter.drawRect(2, 2, width - 4, height - 4); - - painter.end(); - icon = framedIcon; - - // provide an alpha channel for the frame - QPixmap alphaChannel(icon.size()); - alphaChannel.fill(); - - QPainter alphaPainter(&alphaChannel); - alphaPainter.setBrush(Qt::NoBrush); - alphaPainter.setRenderHint(QPainter::Antialiasing, false); - alphaPainter.setPen(QColor(32, 32, 32)); - alphaPainter.drawRect(0, 0, width, height); - alphaPainter.setPen(QColor(64, 64, 64)); - alphaPainter.drawRect(1, 1, width - 2, height - 2); - - icon.setAlphaChannel(alphaChannel); - } - if (m_previewIsLate) { // always use the maximal width - QPixmap paddedImage(QSize(PREVIEW_WIDTH, icon.height())); + QPixmap paddedImage(QSize(PREVIEW_WIDTH, pixmap.height())); paddedImage.fill(Qt::transparent); QPainter painter(&paddedImage); - painter.drawPixmap((PREVIEW_WIDTH - icon.width()) / 2, 0, icon); + painter.drawPixmap((PREVIEW_WIDTH - pixmap.width()) / 2, 0, pixmap); m_pix = paddedImage; } else { - m_pix = icon; + m_pix = pixmap; } m_preview = true; m_generatingPreview = false;