If point intersects with rect the line to the label wrong.

--HG--
branch : develop
This commit is contained in:
dismine 2014-08-17 22:34:01 +03:00
parent fcffc03649
commit aec154e43c

View File

@ -241,9 +241,13 @@ void VToolPoint::RefreshPointGeometry(const VPointF &point)
*/ */
void VToolPoint::RefreshLine() void VToolPoint::RefreshLine()
{ {
QRectF nRec = namePoint->sceneBoundingRect();
nRec.translate(- scenePos());
if (this->rect().intersects(nRec) == false)
{
QRectF nameRec = namePoint->sceneBoundingRect(); QRectF nameRec = namePoint->sceneBoundingRect();
QPointF p1, p2; QPointF p1, p2;
LineIntersectCircle(QPointF(), radius/factor, QLineF(QPointF(), nameRec.center()- scenePos()), p1, p2); LineIntersectCircle(QPointF(), radius/factor, QLineF(QPointF(), nameRec.center() - scenePos()), p1, p2);
QPointF pRec = LineIntersectRect(nameRec, QLineF(scenePos(), nameRec.center())); QPointF pRec = LineIntersectRect(nameRec, QLineF(scenePos(), nameRec.center()));
lineName->setLine(QLineF(p1, pRec - scenePos())); lineName->setLine(QLineF(p1, pRec - scenePos()));
if (currentColor == Qt::gray) if (currentColor == Qt::gray)
@ -254,6 +258,7 @@ void VToolPoint::RefreshLine()
{ {
lineName->setPen(QPen(Qt::black, qApp->toPixel(qApp->widthHairLine())/factor)); lineName->setPen(QPen(Qt::black, qApp->toPixel(qApp->widthHairLine())/factor));
} }
if (QLineF(p1, pRec - scenePos()).length() <= qApp->toPixel(4, Unit::Mm)) if (QLineF(p1, pRec - scenePos()).length() <= qApp->toPixel(4, Unit::Mm))
{ {
lineName->setVisible(false); lineName->setVisible(false);
@ -262,6 +267,11 @@ void VToolPoint::RefreshLine()
{ {
lineName->setVisible(true); lineName->setVisible(true);
} }
}
else
{
lineName->setVisible(false);
}
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------