Speed optimization.
--HG-- branch : develop
This commit is contained in:
parent
1ee4ccc8e5
commit
027bd31c2a
|
@ -57,6 +57,7 @@ enum class BestFrom : char
|
||||||
# define SHOW_VERTICES // Show contour vertices
|
# define SHOW_VERTICES // Show contour vertices
|
||||||
# define SHOW_DIRECTION // Show contour direction
|
# define SHOW_DIRECTION // Show contour direction
|
||||||
# define ARRANGED_DETAILS // Show already arranged details
|
# define ARRANGED_DETAILS // Show already arranged details
|
||||||
|
//# define SHOW_SHEET // Show sheet rect
|
||||||
|
|
||||||
// Debugging
|
// Debugging
|
||||||
# define SHOW_CANDIDATE // Show each position
|
# define SHOW_CANDIDATE // Show each position
|
||||||
|
|
|
@ -50,7 +50,7 @@ VPosition::VPosition(const VContour &gContour, int j, const VLayoutDetail &detai
|
||||||
bool rotate, int rotationIncrease, bool saveLength)
|
bool rotate, int rotationIncrease, bool saveLength)
|
||||||
:QRunnable(), bestResult(VBestSquare(gContour.GetSize(), saveLength)), gContour(gContour), detail(detail), i(i),
|
:QRunnable(), bestResult(VBestSquare(gContour.GetSize(), saveLength)), gContour(gContour), detail(detail), i(i),
|
||||||
j(j), paperIndex(0), frame(0), detailsCount(0), details(QVector<VLayoutDetail>()), stop(stop), rotate(rotate),
|
j(j), paperIndex(0), frame(0), detailsCount(0), details(QVector<VLayoutDetail>()), stop(stop), rotate(rotate),
|
||||||
rotationIncrease(rotationIncrease)
|
rotationIncrease(rotationIncrease), angle_between(0)
|
||||||
{
|
{
|
||||||
if ((rotationIncrease >= 1 && rotationIncrease <= 180 && 360 % rotationIncrease == 0) == false)
|
if ((rotationIncrease >= 1 && rotationIncrease <= 180 && 360 % rotationIncrease == 0) == false)
|
||||||
{
|
{
|
||||||
|
@ -161,7 +161,7 @@ void VPosition::DrawDebug(const VContour &contour, const VLayoutDetail &detail,
|
||||||
QPainterPath p;
|
QPainterPath p;
|
||||||
if (contour.GetContour().isEmpty())
|
if (contour.GetContour().isEmpty())
|
||||||
{
|
{
|
||||||
p = DrawContour(contour.CutEdge(QLineF(0, 0, contour.GetWidth(), 0)));
|
p = DrawContour(contour.CutEdge(contour.EmptySheetEdge()));
|
||||||
p.translate(biasWidth/2, biasHeight/2);
|
p.translate(biasWidth/2, biasHeight/2);
|
||||||
paint.drawPath(p);
|
paint.drawPath(p);
|
||||||
}
|
}
|
||||||
|
@ -195,8 +195,10 @@ void VPosition::DrawDebug(const VContour &contour, const VLayoutDetail &detail,
|
||||||
const QRect pictureRect = picture.boundingRect();
|
const QRect pictureRect = picture.boundingRect();
|
||||||
|
|
||||||
// Sheet
|
// Sheet
|
||||||
|
#ifdef SHOW_SHEET
|
||||||
paint.setPen(QPen(Qt::darkRed, 15, Qt::SolidLine, Qt::FlatCap, Qt::MiterJoin));
|
paint.setPen(QPen(Qt::darkRed, 15, Qt::SolidLine, Qt::FlatCap, Qt::MiterJoin));
|
||||||
paint.drawRect(QRectF(biasWidth/2, biasHeight/2, contour.GetWidth(), contour.GetHeight()));
|
paint.drawRect(QRectF(biasWidth/2, biasHeight/2, contour.GetWidth(), contour.GetHeight()));
|
||||||
|
#endif
|
||||||
|
|
||||||
paint.end();
|
paint.end();
|
||||||
|
|
||||||
|
@ -246,7 +248,7 @@ void VPosition::SaveCandidate(VBestSquare &bestResult, const VLayoutDetail &deta
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
bool VPosition::CheckCombineEdges(VLayoutDetail &detail, int j, int &dEdge) const
|
bool VPosition::CheckCombineEdges(VLayoutDetail &detail, int j, int &dEdge)
|
||||||
{
|
{
|
||||||
const QLineF globalEdge = gContour.GlobalEdge(j);
|
const QLineF globalEdge = gContour.GlobalEdge(j);
|
||||||
bool flagMirror = false;
|
bool flagMirror = false;
|
||||||
|
@ -262,9 +264,16 @@ bool VPosition::CheckCombineEdges(VLayoutDetail &detail, int j, int &dEdge) cons
|
||||||
|
|
||||||
CrossingType type = CrossingType::Intersection;
|
CrossingType type = CrossingType::Intersection;
|
||||||
if (SheetContains(detail.BoundingRect()))
|
if (SheetContains(detail.BoundingRect()))
|
||||||
|
{
|
||||||
|
if (not gContour.GetContour().isEmpty())
|
||||||
{
|
{
|
||||||
type = Crossing(detail, j, dEdge);
|
type = Crossing(detail, j, dEdge);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
type = CrossingType::NoIntersection;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch (type)
|
switch (type)
|
||||||
{
|
{
|
||||||
|
@ -561,7 +570,7 @@ bool VPosition::SheetContains(const QRectF &rect) const
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VPosition::CombineEdges(VLayoutDetail &detail, const QLineF &globalEdge, const int &dEdge) const
|
void VPosition::CombineEdges(VLayoutDetail &detail, const QLineF &globalEdge, const int &dEdge)
|
||||||
{
|
{
|
||||||
QLineF detailEdge = detail.Edge(dEdge);
|
QLineF detailEdge = detail.Edge(dEdge);
|
||||||
|
|
||||||
|
@ -571,12 +580,15 @@ void VPosition::CombineEdges(VLayoutDetail &detail, const QLineF &globalEdge, co
|
||||||
|
|
||||||
detailEdge.translate(dx, dy); // Use values for translate detail edge.
|
detailEdge.translate(dx, dy); // Use values for translate detail edge.
|
||||||
|
|
||||||
const qreal angle_between = globalEdge.angleTo(detailEdge); // Seek angle between two edges.
|
angle_between = globalEdge.angleTo(detailEdge); // Seek angle between two edges.
|
||||||
|
|
||||||
// Now we move detail to position near to global contour edge.
|
// Now we move detail to position near to global contour edge.
|
||||||
detail.Translate(dx, dy);
|
detail.Translate(dx, dy);
|
||||||
|
if (not qFuzzyCompare(angle_between+360, 0+360))
|
||||||
|
{
|
||||||
detail.Rotate(detailEdge.p2(), -angle_between);
|
detail.Rotate(detailEdge.p2(), -angle_between);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VPosition::RotateEdges(VLayoutDetail &detail, const QLineF &globalEdge, int dEdge, int angle) const
|
void VPosition::RotateEdges(VLayoutDetail &detail, const QLineF &globalEdge, int dEdge, int angle) const
|
||||||
|
@ -660,7 +672,12 @@ QVector<QPointF> VPosition::CutEdge(const QLineF &edge, unsigned int shift)
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VPosition::Rotate(int increase)
|
void VPosition::Rotate(int increase)
|
||||||
{
|
{
|
||||||
for (int angle = 0; angle < 360; angle = angle+increase)
|
int startAngle = 0;
|
||||||
|
if (qFuzzyCompare(angle_between+360, 0+360))
|
||||||
|
{
|
||||||
|
startAngle = increase;
|
||||||
|
}
|
||||||
|
for (int angle = startAngle; angle < 360; angle = angle+increase)
|
||||||
{
|
{
|
||||||
if (*stop)
|
if (*stop)
|
||||||
{
|
{
|
||||||
|
|
|
@ -82,6 +82,10 @@ private:
|
||||||
volatile bool *stop;
|
volatile bool *stop;
|
||||||
bool rotate;
|
bool rotate;
|
||||||
int rotationIncrease;
|
int rotationIncrease;
|
||||||
|
/**
|
||||||
|
* @brief angle_between keep angle between global edge and detail edge. Need for optimization rotation.
|
||||||
|
*/
|
||||||
|
qreal angle_between;
|
||||||
|
|
||||||
enum class CrossingType : char
|
enum class CrossingType : char
|
||||||
{
|
{
|
||||||
|
@ -101,7 +105,7 @@ private:
|
||||||
|
|
||||||
void SaveCandidate(VBestSquare &bestResult, const VLayoutDetail &detail, int globalI, int detJ, BestFrom type);
|
void SaveCandidate(VBestSquare &bestResult, const VLayoutDetail &detail, int globalI, int detJ, BestFrom type);
|
||||||
|
|
||||||
bool CheckCombineEdges(VLayoutDetail &detail, int j, int &dEdge) const;
|
bool CheckCombineEdges(VLayoutDetail &detail, int j, int &dEdge);
|
||||||
bool CheckRotationEdges(VLayoutDetail &detail, int j, int dEdge, int angle) const;
|
bool CheckRotationEdges(VLayoutDetail &detail, int j, int dEdge, int angle) const;
|
||||||
|
|
||||||
CrossingType Crossing(const VLayoutDetail &detail, const int &globalI, const int &detailI) const;
|
CrossingType Crossing(const VLayoutDetail &detail, const int &globalI, const int &detailI) const;
|
||||||
|
@ -109,7 +113,7 @@ private:
|
||||||
qreal CheckSide(const QLineF &edge, const QPointF &p) const;
|
qreal CheckSide(const QLineF &edge, const QPointF &p) const;
|
||||||
bool SheetContains(const QRectF &rect) const;
|
bool SheetContains(const QRectF &rect) const;
|
||||||
|
|
||||||
void CombineEdges(VLayoutDetail &detail, const QLineF &globalEdge, const int &dEdge) const;
|
void CombineEdges(VLayoutDetail &detail, const QLineF &globalEdge, const int &dEdge);
|
||||||
void RotateEdges(VLayoutDetail &detail, const QLineF &globalEdge, int dEdge, int angle) const;
|
void RotateEdges(VLayoutDetail &detail, const QLineF &globalEdge, int dEdge, int angle) const;
|
||||||
|
|
||||||
QPolygonF GlobalPolygon() const;
|
QPolygonF GlobalPolygon() const;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user