┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEmmanuel Pescosta <[email protected]>2013-08-24 21:00:26 +0200
committerEmmanuel Pescosta <[email protected]>2013-08-24 21:00:26 +0200
commit2bdce34fe1e6613d2747ab798bccb4fa7de8ca3e (patch)
tree8709af40b1e5e8bdbe8e964b2576d71e035e4f40
parent7ffa66f77789f754a4c35a5c4d0ecbfc0a0ae1e7 (diff)
Adjust the size and position of the selection toggle on icon
resize (when changing the zoomlevel). BUG: 310412 REVIEW: 112250 FIXED-IN: 4.11.1
-rw-r--r--src/kitemviews/kitemlistwidget.cpp6
-rw-r--r--src/kitemviews/private/kitemlistselectiontoggle.cpp43
-rw-r--r--src/kitemviews/private/kitemlistselectiontoggle.h2
3 files changed, 40 insertions, 11 deletions
diff --git a/src/kitemviews/kitemlistwidget.cpp b/src/kitemviews/kitemlistwidget.cpp
index 6a7111ad7..85cd70c43 100644
--- a/src/kitemviews/kitemlistwidget.cpp
+++ b/src/kitemviews/kitemlistwidget.cpp
@@ -451,6 +451,12 @@ void KItemListWidget::resizeEvent(QGraphicsSceneResizeEvent* event)
{
QGraphicsWidget::resizeEvent(event);
clearHoverCache();
+
+ if (m_selectionToggle) {
+ const QRectF& toggleRect = selectionToggleRect();
+ m_selectionToggle->setPos(toggleRect.topLeft());
+ m_selectionToggle->resize(toggleRect.size());
+ }
}
qreal KItemListWidget::hoverOpacity() const
diff --git a/src/kitemviews/private/kitemlistselectiontoggle.cpp b/src/kitemviews/private/kitemlistselectiontoggle.cpp
index 66da6a727..6bbf3c2ec 100644
--- a/src/kitemviews/private/kitemlistselectiontoggle.cpp
+++ b/src/kitemviews/private/kitemlistselectiontoggle.cpp
@@ -79,28 +79,49 @@ void KItemListSelectionToggle::hoverLeaveEvent(QGraphicsSceneHoverEvent* event)
m_pixmap = QPixmap();
}
+void KItemListSelectionToggle::resizeEvent(QGraphicsSceneResizeEvent* event)
+{
+ QGraphicsWidget::resizeEvent(event);
+
+ if (!m_pixmap.isNull()) {
+ const int pixmapSize = m_pixmap.size().width(); // Pixmap width is always equal pixmap height
+
+ if (pixmapSize != iconSize()) {
+ // If the required icon size is different from the actual pixmap size,
+ // overwrite the m_pixmap with an empty pixmap and reload the new
+ // icon on next re-painting.
+ m_pixmap = QPixmap();
+ }
+ }
+}
+
void KItemListSelectionToggle::updatePixmap()
{
const char* icon = m_checked ? "list-remove" : "list-add";
+ m_pixmap = KIconLoader::global()->loadIcon(QLatin1String(icon), KIconLoader::NoGroup, iconSize());
+
+ if (m_hovered) {
+ KIconLoader::global()->iconEffect()->apply(m_pixmap, KIconLoader::Desktop, KIconLoader::ActiveState);
+ }
+}
+
+int KItemListSelectionToggle::iconSize() const
+{
+ const int iconSize = qMin(size().width(), size().height());
- int iconSize = qMin(size().width(), size().height());
if (iconSize < KIconLoader::SizeSmallMedium) {
- iconSize = KIconLoader::SizeSmall;
+ return KIconLoader::SizeSmall;
} else if (iconSize < KIconLoader::SizeMedium) {
- iconSize = KIconLoader::SizeSmallMedium;
+ return KIconLoader::SizeSmallMedium;
} else if (iconSize < KIconLoader::SizeLarge) {
- iconSize = KIconLoader::SizeMedium;
+ return KIconLoader::SizeMedium;
} else if (iconSize < KIconLoader::SizeHuge) {
- iconSize = KIconLoader::SizeLarge;
+ return KIconLoader::SizeLarge;
} else if (iconSize < KIconLoader::SizeEnormous) {
- iconSize = KIconLoader::SizeHuge;
+ return KIconLoader::SizeHuge;
}
- m_pixmap = KIconLoader::global()->loadIcon(QLatin1String(icon), KIconLoader::NoGroup, iconSize);
-
- if (m_hovered) {
- KIconLoader::global()->iconEffect()->apply(m_pixmap, KIconLoader::Desktop, KIconLoader::ActiveState);
- }
+ return iconSize;
}
#include "kitemlistselectiontoggle.moc"
diff --git a/src/kitemviews/private/kitemlistselectiontoggle.h b/src/kitemviews/private/kitemlistselectiontoggle.h
index a8050d811..ba29293f6 100644
--- a/src/kitemviews/private/kitemlistselectiontoggle.h
+++ b/src/kitemviews/private/kitemlistselectiontoggle.h
@@ -46,9 +46,11 @@ public:
protected:
virtual void hoverEnterEvent(QGraphicsSceneHoverEvent* event);
virtual void hoverLeaveEvent(QGraphicsSceneHoverEvent* event);
+ virtual void resizeEvent(QGraphicsSceneResizeEvent* event);
private:
void updatePixmap();
+ int iconSize() const;
private:
bool m_checked;