┌   ┐
54
└   ┘

summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorFrank Reininghaus <[email protected]>2013-08-25 19:17:25 +0200
committerFrank Reininghaus <[email protected]>2013-08-25 19:17:25 +0200
commitcba24825c973ff422a84a71563ec7bc22c340088 (patch)
treec922d80124e4b0e2df4df206c1d57a8316863f3c /src
parentebfcb5e19b345a0fbb2425f537232f45d3b3d62a (diff)
parent092c820023466f5291ba7d52f55a8e7b9939a502 (diff)
Merge remote-tracking branch 'origin/KDE/4.11'
Diffstat (limited to 'src')
-rw-r--r--src/kitemviews/kitemlistwidget.cpp6
-rw-r--r--src/kitemviews/kstandarditemlistwidget.cpp7
-rw-r--r--src/kitemviews/private/kitemlistroleeditor.cpp16
-rw-r--r--src/kitemviews/private/kitemlistselectiontoggle.cpp43
-rw-r--r--src/kitemviews/private/kitemlistselectiontoggle.h2
5 files changed, 61 insertions, 13 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/kstandarditemlistwidget.cpp b/src/kitemviews/kstandarditemlistwidget.cpp
index 483517ecc..bc0503663 100644
--- a/src/kitemviews/kstandarditemlistwidget.cpp
+++ b/src/kitemviews/kstandarditemlistwidget.cpp
@@ -1030,12 +1030,15 @@ void KStandardItemListWidget::updateIconsLayoutTextCache()
const int textLength = line.textStart() + line.textLength();
if (textLength < nameText.length()) {
// Elide the last line of the text
- QString lastTextLine = nameText.mid(line.textStart(), line.textLength());
+ QString lastTextLine = nameText.mid(line.textStart());
lastTextLine = m_customizedFontMetrics.elidedText(lastTextLine,
Qt::ElideRight,
- line.naturalTextWidth() - 1);
+ maxWidth);
const QString elidedText = nameText.left(line.textStart()) + lastTextLine;
nameTextInfo->staticText.setText(elidedText);
+
+ const qreal lastLineWidth = m_customizedFontMetrics.boundingRect(lastTextLine).width();
+ nameWidth = qMax(nameWidth, lastLineWidth);
}
break;
}
diff --git a/src/kitemviews/private/kitemlistroleeditor.cpp b/src/kitemviews/private/kitemlistroleeditor.cpp
index 9f20afea2..0a48f1ba0 100644
--- a/src/kitemviews/private/kitemlistroleeditor.cpp
+++ b/src/kitemviews/private/kitemlistroleeditor.cpp
@@ -93,6 +93,22 @@ void KItemListRoleEditor::keyPressEvent(QKeyEvent* event)
emitRoleEditingFinished();
event->accept();
return;
+ case Qt::Key_Left:
+ case Qt::Key_Right: {
+ QTextCursor cursor = textCursor();
+ if (event->modifiers() == Qt::NoModifier && cursor.hasSelection()) {
+ if (event->key() == Qt::Key_Left) {
+ cursor.setPosition(cursor.selectionStart());
+ } else {
+ cursor.setPosition(cursor.selectionEnd());
+ }
+ cursor.clearSelection();
+ setTextCursor(cursor);
+ event->accept();
+ return;
+ }
+ break;
+ }
default:
break;
}
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;