From 054521d3a10f4ef14ecb5e50a395f7496d6dedae Mon Sep 17 00:00:00 2001 From: Tomaz Canabrava Date: Wed, 14 Jan 2015 22:50:08 -0200 Subject: Reduce the amount of calls to create the background on the ToolTip We were deleting / recreating the graphics background item for *every* mouse movement. Now we are just creating the painter path; no more allocations / desalocations, adding, removing from the scene. This should make things a tiny bit faster. Signed-off-by: Tomaz Canabrava Signed-off-by: Dirk Hohndel --- qt-ui/profile/divetooltipitem.cpp | 28 ++++++++++++++-------------- 1 file changed, 14 insertions(+), 14 deletions(-) (limited to 'qt-ui/profile') diff --git a/qt-ui/profile/divetooltipitem.cpp b/qt-ui/profile/divetooltipitem.cpp index fc76e50dc..790c222fd 100644 --- a/qt-ui/profile/divetooltipitem.cpp +++ b/qt-ui/profile/divetooltipitem.cpp @@ -60,11 +60,8 @@ void ToolTipItem::setRect(const QRectF &r) if( r == rectangle ) { return; } - delete background; rectangle = r; - setBrush(QBrush(Qt::white)); - setPen(QPen(Qt::black, 0.5)); // Creates a 2pixels border QPainterPath border; @@ -75,17 +72,7 @@ void ToolTipItem::setRect(const QRectF &r) QPainterPath bg; bg.addRoundedRect(-1, -1, rectangle.width() + 3, rectangle.height() + 4, 3, 3); - QColor c = QColor(Qt::black); - c.setAlpha(155); - - QGraphicsPathItem *b = new QGraphicsPathItem(bg, this); - b->setFlag(ItemStacksBehindParent); - b->setFlag(ItemIgnoresTransformations); - b->setBrush(c); - b->setPen(QPen(QBrush(Qt::transparent), 0)); - b->setZValue(-10); - background = b; - + background->setPath(bg); updateTitlePosition(); } @@ -158,6 +145,16 @@ ToolTipItem::ToolTipItem(QGraphicsItem *parent) : QGraphicsPathItem(parent), entryToolTip.first = NULL; entryToolTip.second = NULL; setFlags(ItemIgnoresTransformations | ItemIsMovable | ItemClipsChildrenToShape); + + QColor c = QColor(Qt::black); + c.setAlpha(155); + background = new QGraphicsPathItem(this); + background->setFlag(ItemStacksBehindParent); + background->setFlag(ItemIgnoresTransformations); + background->setBrush(c); + background->setPen(QPen(QBrush(Qt::transparent), 0)); + background->setZValue(-10); + updateTitlePosition(); setZValue(99); @@ -171,6 +168,9 @@ ToolTipItem::ToolTipItem(QGraphicsItem *parent) : QGraphicsPathItem(parent), title->setFlag(ItemIgnoresTransformations); title->setPen(QPen(Qt::white, 1)); title->setBrush(Qt::white); + + setBrush(QBrush(Qt::white)); + setPen(QPen(Qt::black, 0.5)); } ToolTipItem::~ToolTipItem() -- cgit v1.2.3-70-g09d2