From 0fdfc1eb26875be9e2d2cba58ad253ca085a6ec4 Mon Sep 17 00:00:00 2001 From: ArsenArsen Date: Tue, 16 May 2017 16:22:32 +0200 Subject: [PATCH] Make the scope and text stay in the screen --- colorpicker/colorpickerscene.cpp | 27 ++++++++++++++++++++++++--- 1 file changed, 24 insertions(+), 3 deletions(-) diff --git a/colorpicker/colorpickerscene.cpp b/colorpicker/colorpickerscene.cpp index 4e53dfa..308feb0 100644 --- a/colorpicker/colorpickerscene.cpp +++ b/colorpicker/colorpickerscene.cpp @@ -32,12 +32,33 @@ ColorPickerScene::ColorPickerScene(QPixmap *pixmap, QWidget *parentWidget) } void ColorPickerScene::mouseMoveEvent(QGraphicsSceneMouseEvent *event) { - ellipse->setRect(QRectF(event->scenePos(), QSize(20, 20))); color = pItem->pixmap().toImage().pixelColor(event->scenePos().toPoint()); - text->setPos(QCursor::pos() + QPoint(25, 0)); text->setPlainText(color.name()); - textBackground->setPos(text->pos()); ellipse->setBrush(color); + + qreal bottom = rect().bottom(); // max y + qreal right = rect().right(); // max x + qreal width = text->boundingRect().width(); + qreal height = text->boundingRect().height(); + + QPointF origPoint = event->scenePos() + QPoint(25, 0); + QPointF scopePoint = event->scenePos(); + QPointF resPoint = origPoint; + if (origPoint.x() + width > right) { + scopePoint -= QPoint(20, 0); + resPoint -= QPoint(50 + width, 0); + } + if (origPoint.y() + height > bottom) { + scopePoint -= QPoint(0, 20); + resPoint -= QPoint(0, height); + } + + ellipse->setRect(QRectF(scopePoint, QSize(20, 20))); + text->setPos(resPoint); + textBackground->setPos(text->pos()); + // How does this work? I have no clue.... + // I mean.. It kinda makes sense when you look through it carefully + // But it's still a mess. } void ColorPickerScene::keyPressEvent(QKeyEvent *event) {