Show place label rect.

--HG--
branch : feature
This commit is contained in:
Roman Telezhynskyi 2017-10-24 16:42:09 +03:00
parent 7a2297ed6b
commit f78c122cb0
6 changed files with 98 additions and 15 deletions

View File

@ -281,6 +281,11 @@ void DialogSeamAllowance::SetPiece(const VPiece &piece)
NewSpecialPoint(uiTabPlaceLabels->listWidgetPlaceLabels, piece.GetPlaceLabels().at(i)); NewSpecialPoint(uiTabPlaceLabels->listWidgetPlaceLabels, piece.GetPlaceLabels().at(i));
} }
if (piece.GetPlaceLabels().size() > 0)
{
uiTabPlaceLabels->listWidgetPlaceLabels->setCurrentRow(0);
}
uiTabPaths->comboBoxStartPoint->blockSignals(true); uiTabPaths->comboBoxStartPoint->blockSignals(true);
uiTabPaths->comboBoxStartPoint->clear(); uiTabPaths->comboBoxStartPoint->clear();
uiTabPaths->comboBoxStartPoint->blockSignals(false); uiTabPaths->comboBoxStartPoint->blockSignals(false);
@ -1297,11 +1302,11 @@ QT_WARNING_POP
|| (index == TabOrder::Labels && || (index == TabOrder::Labels &&
uiTabLabels->tabWidget->currentIndex() == uiTabLabels->tabWidget->indexOf(uiTabLabels->tabLabels))) uiTabLabels->tabWidget->currentIndex() == uiTabLabels->tabWidget->indexOf(uiTabLabels->tabLabels)))
{ {
ShowPieceSpecialPoints(uiTabPins->listWidgetPins); ShowPieceSpecialPointsWithRect(uiTabPins->listWidgetPins, false);
} }
else if (index == TabOrder::PlaceLabels) else if (index == TabOrder::PlaceLabels)
{ {
ShowPieceSpecialPoints(uiTabPlaceLabels->listWidgetPlaceLabels); ShowPieceSpecialPointsWithRect(uiTabPlaceLabels->listWidgetPlaceLabels, true);
} }
else else
{ {
@ -1317,7 +1322,7 @@ void DialogSeamAllowance::TabChanged(int index)
{ {
if (index == uiTabLabels->tabWidget->indexOf(uiTabLabels->tabLabels)) if (index == uiTabLabels->tabWidget->indexOf(uiTabLabels->tabLabels))
{ {
ShowPieceSpecialPoints(uiTabPins->listWidgetPins); ShowPieceSpecialPointsWithRect(uiTabPins->listWidgetPins, false);
} }
else else
{ {
@ -2868,6 +2873,15 @@ void DialogSeamAllowance::InitPassmarksTab()
void DialogSeamAllowance::InitPlaceLabelsTab() void DialogSeamAllowance::InitPlaceLabelsTab()
{ {
uiTabPlaceLabels->listWidgetPlaceLabels->setContextMenuPolicy(Qt::CustomContextMenu); uiTabPlaceLabels->listWidgetPlaceLabels->setContextMenuPolicy(Qt::CustomContextMenu);
connect(uiTabPlaceLabels->listWidgetPlaceLabels, &QListWidget::currentRowChanged, this, [this]()
{
if (not m_visSpecialPoints.isNull())
{
m_visSpecialPoints->SetShowRect(true);
m_visSpecialPoints->SetRect(CurrentRect());
m_visSpecialPoints->RefreshGeometry();
}
});
connect(uiTabPlaceLabels->listWidgetPlaceLabels, &QListWidget::customContextMenuRequested, this, connect(uiTabPlaceLabels->listWidgetPlaceLabels, &QListWidget::customContextMenuRequested, this,
&DialogSeamAllowance::ShowPlaceLabelsContextMenu); &DialogSeamAllowance::ShowPlaceLabelsContextMenu);
} }
@ -3126,7 +3140,20 @@ void DialogSeamAllowance::SetPLAngle(QString angleFormula)
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
void DialogSeamAllowance::ShowPieceSpecialPoints(const QListWidget *list) QRectF DialogSeamAllowance::CurrentRect() const
{
QRectF rect;
if (QListWidgetItem *item = uiTabPlaceLabels->listWidgetPlaceLabels->currentItem())
{
VPlaceLabelItem label = CurrentPlaceLabel(qvariant_cast<quint32>(item->data(Qt::UserRole)));
rect = QRectF(QPointF(label.x() - label.GetWidth()/2.0, label.y() - label.GetHeight()/2.0),
QPointF(label.x() + label.GetWidth()/2.0, label.y() + label.GetHeight()/2.0));
}
return rect;
}
//---------------------------------------------------------------------------------------------------------------------
void DialogSeamAllowance::ShowPieceSpecialPointsWithRect(const QListWidget *list, bool showRect)
{ {
SCASSERT(list != nullptr) SCASSERT(list != nullptr)
if (m_visSpecialPoints.isNull()) if (m_visSpecialPoints.isNull())
@ -3135,6 +3162,8 @@ void DialogSeamAllowance::ShowPieceSpecialPoints(const QListWidget *list)
} }
m_visSpecialPoints->SetPoints(GetListInternals<quint32>(list)); m_visSpecialPoints->SetPoints(GetListInternals<quint32>(list));
m_visSpecialPoints->SetShowRect(showRect);
m_visSpecialPoints->SetRect(CurrentRect());
if (not qApp->getCurrentScene()->items().contains(m_visSpecialPoints)) if (not qApp->getCurrentScene()->items().contains(m_visSpecialPoints))
{ {

View File

@ -268,7 +268,8 @@ private:
void SetPLHeight(QString heightFormula); void SetPLHeight(QString heightFormula);
void SetPLAngle(QString angleFormula); void SetPLAngle(QString angleFormula);
void ShowPieceSpecialPoints(const QListWidget *list); QRectF CurrentRect() const;
void ShowPieceSpecialPointsWithRect(const QListWidget *list, bool showRect);
VPiecePath CurrentPath(quint32 id) const; VPiecePath CurrentPath(quint32 id) const;
VPlaceLabelItem CurrentPlaceLabel(quint32 id) const; VPlaceLabelItem CurrentPlaceLabel(quint32 id) const;

View File

@ -31,12 +31,31 @@
#include "../vgeometry/vpointf.h" #include "../vgeometry/vpointf.h"
#include "../vpatterndb/vcontainer.h" #include "../vpatterndb/vcontainer.h"
namespace
{
QPainterPath RectPath(const QRectF &rect)
{
QPainterPath path;
if (not rect.isNull())
{
path.addRect(rect);
}
return path;
}
}
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
VisPieceSpecialPoints::VisPieceSpecialPoints(const VContainer *data, QGraphicsItem *parent) VisPieceSpecialPoints::VisPieceSpecialPoints(const VContainer *data, QGraphicsItem *parent)
: VisPath(data, parent), : VisPath(data, parent),
m_points(), m_points(),
m_spoints() m_spoints(),
m_showRect(false),
m_placeLabelRect(),
m_rectItem(nullptr),
supportColor2(Qt::darkGreen)
{ {
m_rectItem = InitItem<VCurvePathItem>(supportColor2, this);
m_rectItem->SetWidth(widthHairLine);
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
@ -51,13 +70,12 @@ void VisPieceSpecialPoints::RefreshGeometry()
const QSharedPointer<VPointF> p = Visualization::data->GeometricObject<VPointF>(m_spoints.at(i)); const QSharedPointer<VPointF> p = Visualization::data->GeometricObject<VPointF>(m_spoints.at(i));
point->RefreshPointGeometry(*p); point->RefreshPointGeometry(*p);
point->setVisible(true); point->setVisible(true);
}
}
//--------------------------------------------------------------------------------------------------------------------- if (m_showRect)
void VisPieceSpecialPoints::SetPoints(const QVector<quint32> &pins) {
{ DrawPath(m_rectItem, RectPath(m_placeLabelRect), supportColor2, Qt::SolidLine, Qt::RoundCap);
m_spoints = pins; }
}
} }
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------

View File

@ -41,17 +41,43 @@ public:
virtual ~VisPieceSpecialPoints() Q_DECL_EQ_DEFAULT; virtual ~VisPieceSpecialPoints() Q_DECL_EQ_DEFAULT;
virtual void RefreshGeometry() Q_DECL_OVERRIDE; virtual void RefreshGeometry() Q_DECL_OVERRIDE;
void SetPoints(const QVector<quint32> &pins);
void SetPoints(const QVector<quint32> &pins);
void SetShowRect(bool show);
void SetRect(const QRectF &rect);
virtual int type() const Q_DECL_OVERRIDE {return Type;} virtual int type() const Q_DECL_OVERRIDE {return Type;}
enum { Type = UserType + static_cast<int>(Vis::PieceSpecialPoints)}; enum { Type = UserType + static_cast<int>(Vis::PieceSpecialPoints)};
private: private:
Q_DISABLE_COPY(VisPieceSpecialPoints) Q_DISABLE_COPY(VisPieceSpecialPoints)
QVector<VSimplePoint *> m_points; QVector<VSimplePoint *> m_points;
QVector<quint32> m_spoints; QVector<quint32> m_spoints;
bool m_showRect;
QRectF m_placeLabelRect;
VCurvePathItem *m_rectItem;
QColor supportColor2;
VSimplePoint *GetPoint(quint32 i, const QColor &color); VSimplePoint *GetPoint(quint32 i, const QColor &color);
void HideAllItems(); void HideAllItems();
}; };
//---------------------------------------------------------------------------------------------------------------------
inline void VisPieceSpecialPoints::SetPoints(const QVector<quint32> &pins)
{
m_spoints = pins;
}
//---------------------------------------------------------------------------------------------------------------------
inline void VisPieceSpecialPoints::SetShowRect(bool show)
{
m_showRect = show;
}
//---------------------------------------------------------------------------------------------------------------------
inline void VisPieceSpecialPoints::SetRect(const QRectF &rect)
{
m_placeLabelRect = rect;
}
#endif // VISPIECESPECIALPOINTS_H #endif // VISPIECESPECIALPOINTS_H

View File

@ -36,7 +36,8 @@
VCurvePathItem::VCurvePathItem(QGraphicsItem *parent) VCurvePathItem::VCurvePathItem(QGraphicsItem *parent)
: QGraphicsPathItem(parent), : QGraphicsPathItem(parent),
m_directionArrows(), m_directionArrows(),
m_points() m_points(),
m_defaultWidth(widthMainLine)
{ {
} }
@ -107,10 +108,16 @@ void VCurvePathItem::SetPoints(const QVector<QPointF> &points)
m_points = points; m_points = points;
} }
//---------------------------------------------------------------------------------------------------------------------
void VCurvePathItem::SetWidth(qreal width)
{
m_defaultWidth = width;
}
//--------------------------------------------------------------------------------------------------------------------- //---------------------------------------------------------------------------------------------------------------------
void VCurvePathItem::ScalePenWidth() void VCurvePathItem::ScalePenWidth()
{ {
const qreal width = ScaleWidth(widthMainLine, SceneScale(scene())); const qreal width = ScaleWidth(m_defaultWidth, SceneScale(scene()));
QPen toolPen = pen(); QPen toolPen = pen();
toolPen.setWidthF(width); toolPen.setWidthF(width);

View File

@ -50,6 +50,7 @@ public:
void SetDirectionArrows(const QVector<QPair<QLineF, QLineF>> &arrows); void SetDirectionArrows(const QVector<QPair<QLineF, QLineF>> &arrows);
void SetPoints(const QVector<QPointF> &points); void SetPoints(const QVector<QPointF> &points);
void SetWidth(qreal width);
protected: protected:
virtual void ScalePenWidth(); virtual void ScalePenWidth();
private: private:
@ -57,6 +58,7 @@ private:
QVector<QPair<QLineF, QLineF>> m_directionArrows; QVector<QPair<QLineF, QLineF>> m_directionArrows;
QVector<QPointF> m_points; QVector<QPointF> m_points;
qreal m_defaultWidth;
}; };
#endif // VCURVEPATHITEM_H #endif // VCURVEPATHITEM_H