diff options
author | Tobias Markmann <tm@ayena.de> | 2013-09-18 21:47:37 (GMT) |
---|---|---|
committer | Tobias Markmann <tm@ayena.de> | 2013-10-09 15:56:49 (GMT) |
commit | c2833f8afa8db40cfebfe51ecf5bb42fd87d8dca (patch) | |
tree | b2a3bf68dfdd4c38879c98824947954bbe9f35d7 /Swift/QtUI/QtVCardWidget/QtCloseButton.cpp | |
parent | 1e68d4dffd81e69e2ff740fdf249a696f05e0544 (diff) | |
download | swift-c2833f8afa8db40cfebfe51ecf5bb42fd87d8dca.zip swift-c2833f8afa8db40cfebfe51ecf5bb42fd87d8dca.tar.bz2 |
VCard UI fixes.
Fix QtRemovableItemDelegate and QtCloseButton rendering on Windows.
Fix organization's unit field to allow creation of new units.
Fix QtResizableLineEdit's sizeHint to be relative to font metrics.
Change-Id: I69809c9504fd4c9e00db3b3782f33dcdd941d0cd
License: This patch is BSD-licensed, see Documentation/Licenses/BSD-simplified.txt for details.
Diffstat (limited to 'Swift/QtUI/QtVCardWidget/QtCloseButton.cpp')
-rw-r--r-- | Swift/QtUI/QtVCardWidget/QtCloseButton.cpp | 28 |
1 files changed, 9 insertions, 19 deletions
diff --git a/Swift/QtUI/QtVCardWidget/QtCloseButton.cpp b/Swift/QtUI/QtVCardWidget/QtCloseButton.cpp index a6afe81..ebd62bc 100644 --- a/Swift/QtUI/QtVCardWidget/QtCloseButton.cpp +++ b/Swift/QtUI/QtVCardWidget/QtCloseButton.cpp @@ -14,25 +14,11 @@ namespace Swift { QtCloseButton::QtCloseButton(QWidget *parent) : QAbstractButton(parent) { - lightPixmap = QPixmap(12,12); - lightPixmap.fill(QColor(0,0,0,0)); - QStyleOption opt; - opt.init(this); - opt.state = QStyle::State(0); - opt.state |= QStyle::State_MouseOver; - QPainter lightPixmapPainter(&lightPixmap); - style()->drawPrimitive(QStyle::PE_IndicatorTabClose, &opt, &lightPixmapPainter); - darkPixmap = QPixmap(12,12); - darkPixmap.fill(QColor(0,0,0,0)); - opt.init(this); - opt.state = QStyle::State(0); - QPainter darkPixmapPainter(&darkPixmap); - style()->drawPrimitive(QStyle::PE_IndicatorTabClose, &opt, &darkPixmapPainter); } QSize QtCloseButton::sizeHint() const { - return QSize(width(), height()); + return QSize(style()->pixelMetric(QStyle::PM_TabCloseIndicatorWidth, 0, 0), style()->pixelMetric(QStyle::PM_TabCloseIndicatorHeight, 0, 0)); } bool QtCloseButton::event(QEvent *e) { @@ -45,11 +31,15 @@ bool QtCloseButton::event(QEvent *e) { void QtCloseButton::paintEvent(QPaintEvent *) { QPainter painter(this); painter.setRenderHint(QPainter::HighQualityAntialiasing); - if (underMouse()) { - painter.drawPixmap(0, 0, height(), height(), darkPixmap); - } else { - painter.drawPixmap(0, 0, height(), height(), lightPixmap); + QStyleOption opt; + opt.init(this); + opt.state |= QStyle::State_AutoRaise; + if (underMouse() && !isDown()) { + opt.state |= QStyle::State_Raised; + } else if (isDown()) { + opt.state |= QStyle::State_Sunken; } + style()->drawPrimitive(QStyle::PE_IndicatorTabClose, &opt, &painter, this); } } |