Get rid of an extraneous layer parameter.
Also adds a bit of nullptr safety.
This commit is contained in:
parent
6f5e602df9
commit
fec34e8dd8
|
@ -652,7 +652,7 @@ void PAD::TransformShapeWithClearanceToPolygon( SHAPE_POLY_SET& aCornerBuffer,
|
||||||
case PAD_SHAPE::CUSTOM:
|
case PAD_SHAPE::CUSTOM:
|
||||||
{
|
{
|
||||||
SHAPE_POLY_SET outline;
|
SHAPE_POLY_SET outline;
|
||||||
MergePrimitivesAsPolygon( &outline, aLayer, aErrorLoc );
|
MergePrimitivesAsPolygon( &outline, aErrorLoc );
|
||||||
outline.Rotate( -DECIDEG2RAD( m_orient ) );
|
outline.Rotate( -DECIDEG2RAD( m_orient ) );
|
||||||
outline.Move( VECTOR2I( m_pos ) );
|
outline.Move( VECTOR2I( m_pos ) );
|
||||||
|
|
||||||
|
|
|
@ -1400,7 +1400,7 @@ bool DIALOG_PAD_PROPERTIES::padValuesOK()
|
||||||
if( m_dummyPad->GetShape() == PAD_SHAPE::CUSTOM )
|
if( m_dummyPad->GetShape() == PAD_SHAPE::CUSTOM )
|
||||||
{
|
{
|
||||||
SHAPE_POLY_SET mergedPolygon;
|
SHAPE_POLY_SET mergedPolygon;
|
||||||
m_dummyPad->MergePrimitivesAsPolygon( &mergedPolygon, UNDEFINED_LAYER );
|
m_dummyPad->MergePrimitivesAsPolygon( &mergedPolygon );
|
||||||
|
|
||||||
if( mergedPolygon.OutlineCount() > 1 )
|
if( mergedPolygon.OutlineCount() > 1 )
|
||||||
error_msgs.Add( _( "Error: Custom pad shape must resolve to a single polygon." ) );
|
error_msgs.Add( _( "Error: Custom pad shape must resolve to a single polygon." ) );
|
||||||
|
|
|
@ -404,7 +404,7 @@ void DRC_TEST_PROVIDER_COPPER_CLEARANCE::testItemAgainstZones( BOARD_ITEM* aItem
|
||||||
int actual;
|
int actual;
|
||||||
VECTOR2I pos;
|
VECTOR2I pos;
|
||||||
|
|
||||||
if( testClearance )
|
if( zoneTree && testClearance )
|
||||||
{
|
{
|
||||||
constraint = m_drcEngine->EvalRules( CLEARANCE_CONSTRAINT, aItem, zone, aLayer );
|
constraint = m_drcEngine->EvalRules( CLEARANCE_CONSTRAINT, aItem, zone, aLayer );
|
||||||
clearance = constraint.GetValue().Min();
|
clearance = constraint.GetValue().Min();
|
||||||
|
|
|
@ -609,7 +609,7 @@ static void CreatePadsShapesSection( FILE* aFile, BOARD* aPcb )
|
||||||
fprintf( aFile, " POLYGON %g\n", pad->GetDrillSize().x / SCALE_FACTOR );
|
fprintf( aFile, " POLYGON %g\n", pad->GetDrillSize().x / SCALE_FACTOR );
|
||||||
|
|
||||||
SHAPE_POLY_SET outline;
|
SHAPE_POLY_SET outline;
|
||||||
pad->MergePrimitivesAsPolygon( &outline, UNDEFINED_LAYER );
|
pad->MergePrimitivesAsPolygon( &outline );
|
||||||
|
|
||||||
for( int jj = 0; jj < outline.OutlineCount(); ++jj )
|
for( int jj = 0; jj < outline.OutlineCount(); ++jj )
|
||||||
{
|
{
|
||||||
|
|
15
pcbnew/pad.h
15
pcbnew/pad.h
|
@ -278,13 +278,12 @@ public:
|
||||||
* @note The results are relative to the pad position, orientation 0.
|
* @note The results are relative to the pad position, orientation 0.
|
||||||
*
|
*
|
||||||
* @param aMergedPolygon will store the final polygon
|
* @param aMergedPolygon will store the final polygon
|
||||||
* @param aLayer is the layer to take in account, as the exact shape can depend on the layer
|
|
||||||
* @param aErrorLoc is used when a circle (or arc) is approximated by segments
|
* @param aErrorLoc is used when a circle (or arc) is approximated by segments
|
||||||
* = ERROR_INSIDE to build a polygon inside the arc/circle (usual shape to raw/plot)
|
* = ERROR_INSIDE to build a polygon inside the arc/circle (usual shape to raw/plot)
|
||||||
* = ERROR_OUIDE to build a polygon outside the arc/circle
|
* = ERROR_OUIDE to build a polygon outside the arc/circle
|
||||||
* (for instance when building a clearance area)
|
* (for instance when building a clearance area)
|
||||||
*/
|
*/
|
||||||
void MergePrimitivesAsPolygon( SHAPE_POLY_SET* aMergedPolygon, PCB_LAYER_ID aLayer,
|
void MergePrimitivesAsPolygon( SHAPE_POLY_SET* aMergedPolygon,
|
||||||
ERROR_LOC aErrorLoc = ERROR_INSIDE ) const;
|
ERROR_LOC aErrorLoc = ERROR_INSIDE ) const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -667,8 +666,8 @@ public:
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void addPadPrimitivesToPolygon( SHAPE_POLY_SET* aMergedPolygon, PCB_LAYER_ID aLayer,
|
void addPadPrimitivesToPolygon( SHAPE_POLY_SET* aMergedPolygon, int aError,
|
||||||
int aError, ERROR_LOC aErrorLoc ) const;
|
ERROR_LOC aErrorLoc ) const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
wxString m_name; // Pad name (pin number in schematic)
|
wxString m_name; // Pad name (pin number in schematic)
|
||||||
|
@ -677,7 +676,7 @@ private:
|
||||||
|
|
||||||
wxPoint m_pos; // Pad Position on board
|
wxPoint m_pos; // Pad Position on board
|
||||||
|
|
||||||
PAD_SHAPE m_padShape; // Shape: PAD_SHAPE::CIRCLE, PAD_SHAPE::RECT,
|
PAD_SHAPE m_padShape; // Shape: PAD_SHAPE::CIRCLE, PAD_SHAPE::RECT,
|
||||||
// PAD_SHAPE::OVAL, PAD_SHAPE::TRAPEZOID,
|
// PAD_SHAPE::OVAL, PAD_SHAPE::TRAPEZOID,
|
||||||
// PAD_SHAPE::ROUNDRECT, PAD_SHAPE_POLYGON
|
// PAD_SHAPE::ROUNDRECT, PAD_SHAPE_POLYGON
|
||||||
/*
|
/*
|
||||||
|
@ -719,8 +718,8 @@ private:
|
||||||
// size, default 0.25
|
// size, default 0.25
|
||||||
int m_chamferPositions; // The positions of the chamfers (at orient 0)
|
int m_chamferPositions; // The positions of the chamfers (at orient 0)
|
||||||
|
|
||||||
PAD_SHAPE m_anchorPadShape; // For custom shaped pads: shape of pad anchor,
|
PAD_SHAPE m_anchorPadShape; // For custom shaped pads: shape of pad anchor,
|
||||||
// PAD_SHAPE::RECT, PAD_SHAPE::CIRCLE
|
// PAD_SHAPE::RECT, PAD_SHAPE::CIRCLE
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Most of the time the hole is the center of the shape (m_Offset = 0). But some designers
|
* Most of the time the hole is the center of the shape (m_Offset = 0). But some designers
|
||||||
|
@ -743,7 +742,7 @@ private:
|
||||||
|
|
||||||
PAD_ATTRIB m_attribute; // PAD_ATTRIB_NORMAL, PAD_ATTRIB::SMD, PAD_ATTRIB::CONN,
|
PAD_ATTRIB m_attribute; // PAD_ATTRIB_NORMAL, PAD_ATTRIB::SMD, PAD_ATTRIB::CONN,
|
||||||
// PAD_ATTRIB::NPTH
|
// PAD_ATTRIB::NPTH
|
||||||
PAD_PROP m_property; // Property in fab files (BGA, FIDUCIAL, TESTPOINT, etc.)
|
PAD_PROP m_property; // Property in fab files (BGA, FIDUCIAL, TESTPOINT, etc.)
|
||||||
|
|
||||||
double m_orient; // in 1/10 degrees
|
double m_orient; // in 1/10 degrees
|
||||||
|
|
||||||
|
|
|
@ -185,13 +185,16 @@ void PAD::DeletePrimitivesList()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void PAD::addPadPrimitivesToPolygon( SHAPE_POLY_SET* aMergedPolygon, PCB_LAYER_ID aLayer,
|
void PAD::addPadPrimitivesToPolygon( SHAPE_POLY_SET* aMergedPolygon, int aError,
|
||||||
int aError, ERROR_LOC aErrorLoc ) const
|
ERROR_LOC aErrorLoc ) const
|
||||||
{
|
{
|
||||||
SHAPE_POLY_SET polyset;
|
SHAPE_POLY_SET polyset;
|
||||||
|
|
||||||
for( const std::shared_ptr<PCB_SHAPE>& primitive : m_editPrimitives )
|
for( const std::shared_ptr<PCB_SHAPE>& primitive : m_editPrimitives )
|
||||||
primitive->TransformShapeWithClearanceToPolygon( polyset, aLayer, 0, aError, aErrorLoc );
|
{
|
||||||
|
primitive->TransformShapeWithClearanceToPolygon( polyset, UNDEFINED_LAYER, 0, aError,
|
||||||
|
aErrorLoc );
|
||||||
|
}
|
||||||
|
|
||||||
polyset.Simplify( SHAPE_POLY_SET::PM_FAST );
|
polyset.Simplify( SHAPE_POLY_SET::PM_FAST );
|
||||||
|
|
||||||
|
@ -203,8 +206,7 @@ void PAD::addPadPrimitivesToPolygon( SHAPE_POLY_SET* aMergedPolygon, PCB_LAYER_I
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void PAD::MergePrimitivesAsPolygon( SHAPE_POLY_SET* aMergedPolygon, PCB_LAYER_ID aLayer,
|
void PAD::MergePrimitivesAsPolygon( SHAPE_POLY_SET* aMergedPolygon, ERROR_LOC aErrorLoc ) const
|
||||||
ERROR_LOC aErrorLoc ) const
|
|
||||||
{
|
{
|
||||||
const BOARD* board = GetBoard();
|
const BOARD* board = GetBoard();
|
||||||
int maxError = board ? board->GetDesignSettings().m_MaxError : ARC_HIGH_DEF;
|
int maxError = board ? board->GetDesignSettings().m_MaxError : ARC_HIGH_DEF;
|
||||||
|
@ -229,14 +231,14 @@ void PAD::MergePrimitivesAsPolygon( SHAPE_POLY_SET* aMergedPolygon, PCB_LAYER_ID
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
addPadPrimitivesToPolygon( aMergedPolygon, aLayer, maxError, aErrorLoc );
|
addPadPrimitivesToPolygon( aMergedPolygon, maxError, aErrorLoc );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool PAD::GetBestAnchorPosition( VECTOR2I& aPos )
|
bool PAD::GetBestAnchorPosition( VECTOR2I& aPos )
|
||||||
{
|
{
|
||||||
SHAPE_POLY_SET poly;
|
SHAPE_POLY_SET poly;
|
||||||
addPadPrimitivesToPolygon( &poly, UNDEFINED_LAYER, ARC_LOW_DEF, ERROR_INSIDE );
|
addPadPrimitivesToPolygon( &poly, ARC_LOW_DEF, ERROR_INSIDE );
|
||||||
|
|
||||||
if( poly.OutlineCount() > 1 )
|
if( poly.OutlineCount() > 1 )
|
||||||
return false;
|
return false;
|
||||||
|
|
|
@ -449,7 +449,7 @@ void PlotStandardLayer( BOARD* aBoard, PLOTTER* aPlotter, LSET aLayerMask,
|
||||||
// so build a similar pad shape, and inflate/deflate the polygonal shape
|
// so build a similar pad shape, and inflate/deflate the polygonal shape
|
||||||
PAD dummy( *pad );
|
PAD dummy( *pad );
|
||||||
SHAPE_POLY_SET shape;
|
SHAPE_POLY_SET shape;
|
||||||
pad->MergePrimitivesAsPolygon( &shape, UNDEFINED_LAYER );
|
pad->MergePrimitivesAsPolygon( &shape );
|
||||||
|
|
||||||
// Shape polygon can have holes so use InflateWithLinkedHoles(), not Inflate()
|
// Shape polygon can have holes so use InflateWithLinkedHoles(), not Inflate()
|
||||||
// which can create bad shapes if margin.x is < 0
|
// which can create bad shapes if margin.x is < 0
|
||||||
|
|
|
@ -2340,7 +2340,7 @@ bool FABMASTER::loadFootprints( BOARD* aBoard )
|
||||||
}
|
}
|
||||||
|
|
||||||
SHAPE_POLY_SET mergedPolygon;
|
SHAPE_POLY_SET mergedPolygon;
|
||||||
newpad->MergePrimitivesAsPolygon( &mergedPolygon, UNDEFINED_LAYER );
|
newpad->MergePrimitivesAsPolygon( &mergedPolygon );
|
||||||
|
|
||||||
if( mergedPolygon.OutlineCount() > 1 )
|
if( mergedPolygon.OutlineCount() > 1 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -551,7 +551,7 @@ PADSTACK* SPECCTRA_DB::makePADSTACK( BOARD* aBoard, PAD* aPad )
|
||||||
{
|
{
|
||||||
std::vector<wxPoint> polygonal_shape;
|
std::vector<wxPoint> polygonal_shape;
|
||||||
SHAPE_POLY_SET pad_shape;
|
SHAPE_POLY_SET pad_shape;
|
||||||
aPad->MergePrimitivesAsPolygon( &pad_shape, UNDEFINED_LAYER );
|
aPad->MergePrimitivesAsPolygon( &pad_shape );
|
||||||
|
|
||||||
#ifdef EXPORT_CUSTOM_PADS_CONVEX_HULL
|
#ifdef EXPORT_CUSTOM_PADS_CONVEX_HULL
|
||||||
BuildConvexHull( polygonal_shape, pad_shape );
|
BuildConvexHull( polygonal_shape, pad_shape );
|
||||||
|
|
Loading…
Reference in New Issue