svn path=/trunk/KDE/kdebase/apps/; revision=984441
m_waitOnPreviewTimer(0),
m_item(),
m_itemRect(),
m_waitOnPreviewTimer(0),
m_item(),
m_itemRect(),
m_generatingPreview(false),
m_generatingPreview(false),
- m_previewPass(0),
- m_pix()
+ m_hasDefaultIcon(false),
+ m_previewPixmap()
{
KToolTip::setToolTipDelegate(g_delegate);
{
KToolTip::setToolTipDelegate(g_delegate);
// 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);
// 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);
- m_preview = false;
- m_previewPass = 0;
+ m_previewPixmap = QPixmap();
+ m_hasDefaultIcon = false;
m_timer->start(500);
} else {
m_timer->start(500);
} else {
void ToolTipManager::prepareToolTip()
{
if (m_generatingPreview) {
void ToolTipManager::prepareToolTip()
{
if (m_generatingPreview) {
- if (m_previewPass == 1) {
- // We waited 250msec and the preview is still not finished,
- // so show default icon as fallback.
- QPixmap image(KIcon(m_item.iconName()).pixmap(ICON_WIDTH, ICON_HEIGHT));
- showToolTip(image, m_item.getToolTipText());
- }
-
- ++m_previewPass;
m_waitOnPreviewTimer->start(250);
m_waitOnPreviewTimer->start(250);
- } else {
- KIcon icon;
- if (m_preview) {
- // We got a preview.
- icon = KIcon(m_pix);
- } else {
- // No preview, so use an icon.
- // Force a 128x128 icon, a 256x256 one is far too big.
- const QPixmap pixmap = KIcon(m_item.iconName()).pixmap(ICON_WIDTH, ICON_HEIGHT);
- icon = KIcon(pixmap);
- }
- showToolTip(icon, m_item.getToolTipText());
+ const QString text = m_item.getToolTipText();
+ if (!m_previewPixmap.isNull()) {
+ showToolTip(KIcon(m_previewPixmap), text);
+ } else if (!m_hasDefaultIcon) {
+ const QPixmap image(KIcon(m_item.iconName()).pixmap(ICON_WIDTH, ICON_HEIGHT));
+ showToolTip(image, text);
+ m_hasDefaultIcon = true;
connect(job, SIGNAL(gotPreview(const KFileItem&, const QPixmap&)),
this, SLOT(setPreviewPix(const KFileItem&, const QPixmap&)));
connect(job, SIGNAL(failed(const KFileItem&)),
connect(job, SIGNAL(gotPreview(const KFileItem&, const QPixmap&)),
this, SLOT(setPreviewPix(const KFileItem&, const QPixmap&)));
connect(job, SIGNAL(failed(const KFileItem&)),
- this, SLOT(previewFailed(const KFileItem&)));
+ this, SLOT(previewFailed()));
{
if ((m_item.url() != item.url()) || pixmap.isNull()) {
// an old preview or an invalid preview has been received
{
if ((m_item.url() != item.url()) || pixmap.isNull()) {
// an old preview or an invalid preview has been received
+ previewFailed();
+ } else {
+ m_previewPixmap = pixmap;
m_generatingPreview = false;
m_generatingPreview = false;
-
- m_pix = pixmap;
- m_preview = true;
- m_generatingPreview = false;
-void ToolTipManager::previewFailed(const KFileItem& item)
+void ToolTipManager::previewFailed()
m_generatingPreview = false;
}
m_generatingPreview = false;
}
void prepareToolTip();
void startPreviewJob();
void setPreviewPix(const KFileItem& item, const QPixmap& pix);
void prepareToolTip();
void startPreviewJob();
void setPreviewPix(const KFileItem& item, const QPixmap& pix);
- void previewFailed(const KFileItem& item);
private:
void showToolTip(const QIcon& icon, const QString& text);
private:
void showToolTip(const QIcon& icon, const QString& text);
QTimer* m_waitOnPreviewTimer;
KFileItem m_item;
QRect m_itemRect;
QTimer* m_waitOnPreviewTimer;
KFileItem m_item;
QRect m_itemRect;
bool m_generatingPreview;
bool m_generatingPreview;
- int m_previewPass;
- QPixmap m_pix;
+ bool m_hasDefaultIcon;
+ QPixmap m_previewPixmap;