Stop trying to zero-out offset of custom-shaped pads.
It causes *way* to many issues. Fixes https://gitlab.com/kicad/code/kicad/-/issues/15555
This commit is contained in:
parent
f3f57f77d9
commit
68c839b214
|
@ -590,7 +590,7 @@ static struct SCH_BUS_ENTRY_DESC
|
||||||
propMgr.InheritsAfter( TYPE_HASH( SCH_BUS_WIRE_ENTRY ), TYPE_HASH( SCH_BUS_ENTRY_BASE ) );
|
propMgr.InheritsAfter( TYPE_HASH( SCH_BUS_WIRE_ENTRY ), TYPE_HASH( SCH_BUS_ENTRY_BASE ) );
|
||||||
propMgr.InheritsAfter( TYPE_HASH( SCH_BUS_BUS_ENTRY ), TYPE_HASH( SCH_BUS_ENTRY_BASE ) );
|
propMgr.InheritsAfter( TYPE_HASH( SCH_BUS_BUS_ENTRY ), TYPE_HASH( SCH_BUS_ENTRY_BASE ) );
|
||||||
|
|
||||||
auto& plotDashTypeEnum = ENUM_MAP<PLOT_DASH_TYPE>::Instance();
|
ENUM_MAP<PLOT_DASH_TYPE>& plotDashTypeEnum = ENUM_MAP<PLOT_DASH_TYPE>::Instance();
|
||||||
|
|
||||||
if( plotDashTypeEnum.Choices().GetCount() == 0 )
|
if( plotDashTypeEnum.Choices().GetCount() == 0 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -982,7 +982,7 @@ static struct SCH_LINE_DESC
|
||||||
{
|
{
|
||||||
SCH_LINE_DESC()
|
SCH_LINE_DESC()
|
||||||
{
|
{
|
||||||
auto& plotDashTypeEnum = ENUM_MAP<PLOT_DASH_TYPE>::Instance();
|
ENUM_MAP<PLOT_DASH_TYPE>& plotDashTypeEnum = ENUM_MAP<PLOT_DASH_TYPE>::Instance();
|
||||||
|
|
||||||
if( plotDashTypeEnum.Choices().GetCount() == 0 )
|
if( plotDashTypeEnum.Choices().GetCount() == 0 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -947,9 +947,7 @@ void DIALOG_PAD_PROPERTIES::OnPadShapeSelection( wxCommandEvent& event )
|
||||||
m_sizeY.Enable( m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CIRCLE
|
m_sizeY.Enable( m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CIRCLE
|
||||||
&& m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CUSTOM_CIRC_ANCHOR );
|
&& m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CUSTOM_CIRC_ANCHOR );
|
||||||
|
|
||||||
m_offsetShapeOpt->Enable( m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CIRCLE
|
m_offsetShapeOpt->Enable( m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CIRCLE );
|
||||||
&& m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CUSTOM_CIRC_ANCHOR
|
|
||||||
&& m_PadShapeSelector->GetSelection() != CHOICE_SHAPE_CUSTOM_RECT_ANCHOR );
|
|
||||||
|
|
||||||
if( !m_offsetShapeOpt->IsEnabled() )
|
if( !m_offsetShapeOpt->IsEnabled() )
|
||||||
m_offsetShapeOpt->SetValue( false );
|
m_offsetShapeOpt->SetValue( false );
|
||||||
|
|
|
@ -1642,7 +1642,7 @@ void PAD::TransformShapeToPolygon( SHAPE_POLY_SET& aBuffer, PCB_LAYER_ID aLayer,
|
||||||
SHAPE_POLY_SET outline;
|
SHAPE_POLY_SET outline;
|
||||||
MergePrimitivesAsPolygon( &outline, aErrorLoc );
|
MergePrimitivesAsPolygon( &outline, aErrorLoc );
|
||||||
outline.Rotate( m_orient );
|
outline.Rotate( m_orient );
|
||||||
outline.Move( VECTOR2I( m_pos ) );
|
outline.Move( VECTOR2I( padShapePos ) );
|
||||||
|
|
||||||
if( aClearance > 0 || aErrorLoc == ERROR_OUTSIDE )
|
if( aClearance > 0 || aErrorLoc == ERROR_OUTSIDE )
|
||||||
{
|
{
|
||||||
|
|
|
@ -752,11 +752,8 @@ PCB_LAYER_ID PAD_TOOL::explodePad( PAD* aPad )
|
||||||
UNIMPLEMENTED_FOR( shape->SHAPE_T_asString() );
|
UNIMPLEMENTED_FOR( shape->SHAPE_T_asString() );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( shape->GetShape() != SHAPE_T::POLY ) // Poly's are board-relative
|
shape->Rotate( VECTOR2I( 0, 0 ), aPad->GetOrientation() );
|
||||||
{
|
shape->Move( aPad->ShapePos() );
|
||||||
shape->Move( aPad->GetPosition() );
|
|
||||||
shape->Rotate( aPad->GetPosition(), aPad->GetOrientation() );
|
|
||||||
}
|
|
||||||
|
|
||||||
shape->SetLayer( layer );
|
shape->SetLayer( layer );
|
||||||
|
|
||||||
|
@ -780,8 +777,7 @@ std::vector<PCB_SHAPE*> PAD_TOOL::RecombinePad( PAD* aPad, bool aIsDryRun, BOARD
|
||||||
int maxError = board()->GetDesignSettings().m_MaxError;
|
int maxError = board()->GetDesignSettings().m_MaxError;
|
||||||
FOOTPRINT* footprint = aPad->GetParentFootprint();
|
FOOTPRINT* footprint = aPad->GetParentFootprint();
|
||||||
|
|
||||||
// Don't leave an object in the point editor that might no longer exist after
|
// Don't leave an object in the point editor that might no longer exist after recombining.
|
||||||
// recombining the pad.
|
|
||||||
m_toolMgr->RunAction( PCB_ACTIONS::selectionClear );
|
m_toolMgr->RunAction( PCB_ACTIONS::selectionClear );
|
||||||
|
|
||||||
for( BOARD_ITEM* item : footprint->GraphicalItems() )
|
for( BOARD_ITEM* item : footprint->GraphicalItems() )
|
||||||
|
@ -855,41 +851,31 @@ std::vector<PCB_SHAPE*> PAD_TOOL::RecombinePad( PAD* aPad, bool aIsDryRun, BOARD
|
||||||
{
|
{
|
||||||
aCommit.Modify( aPad );
|
aCommit.Modify( aPad );
|
||||||
|
|
||||||
// Create a new minimally-sized circular anchor and convert existing pad
|
if( aPad->GetShape() == PAD_SHAPE::CIRCLE || aPad->GetShape() == PAD_SHAPE::RECTANGLE )
|
||||||
// to a polygon primitive
|
|
||||||
SHAPE_POLY_SET existingOutline;
|
|
||||||
aPad->TransformShapeToPolygon( existingOutline, layer, 0, maxError, ERROR_INSIDE );
|
|
||||||
|
|
||||||
aPad->SetAnchorPadShape( PAD_SHAPE::CIRCLE );
|
|
||||||
// The actual pad shape may be offset from the pad anchor, so we don't want the anchor
|
|
||||||
// shape to be overly large (and stick out from under the actual pad shape). Normally
|
|
||||||
// this means we want the anchor pad to be entirely inside the hole, but offsets are
|
|
||||||
// also used with SMD pads to control the anchor point for track routing.
|
|
||||||
if( aPad->GetDrillSizeX() > 0 )
|
|
||||||
{
|
{
|
||||||
// For a pad with a hole, just make sure the anchor shape is entirely inside the
|
// Use the existing pad as an anchor
|
||||||
// hole.
|
aPad->SetAnchorPadShape( aPad->GetShape() );
|
||||||
aPad->SetSize( aPad->GetDrillSize() / 2 );
|
aPad->SetShape( PAD_SHAPE::CUSTOM );
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// For a SMD pad, an offset is usually used to control the anchor point for routing.
|
// Create a new circular anchor and convert existing pad to a polygon primitive
|
||||||
// In this case it will usually be at least 1/2 the minimum track width inside the
|
SHAPE_POLY_SET existingOutline;
|
||||||
// pad. We halve that value again just to be safe.
|
aPad->TransformShapeToPolygon( existingOutline, layer, 0, maxError, ERROR_INSIDE );
|
||||||
aPad->SetSize( VECTOR2I( board()->GetDesignSettings().m_TrackMinWidth / 2,
|
|
||||||
board()->GetDesignSettings().m_TrackMinWidth / 2 ) );
|
int minExtent = std::min( aPad->GetSize().x, aPad->GetSize().y );
|
||||||
|
aPad->SetAnchorPadShape( PAD_SHAPE::CIRCLE );
|
||||||
|
aPad->SetSize( VECTOR2I( minExtent, minExtent ) );
|
||||||
|
aPad->SetShape( PAD_SHAPE::CUSTOM );
|
||||||
|
|
||||||
|
PCB_SHAPE* shape = new PCB_SHAPE( nullptr, SHAPE_T::POLY );
|
||||||
|
shape->SetFilled( true );
|
||||||
|
shape->SetStroke( STROKE_PARAMS( 0, PLOT_DASH_TYPE::SOLID ) );
|
||||||
|
shape->SetPolyShape( existingOutline );
|
||||||
|
shape->Rotate( VECTOR2I( 0, 0 ), - aPad->GetOrientation() );
|
||||||
|
shape->Move( - aPad->ShapePos() );
|
||||||
|
aPad->AddPrimitive( shape );
|
||||||
}
|
}
|
||||||
|
|
||||||
PCB_SHAPE* shape = new PCB_SHAPE( nullptr, SHAPE_T::POLY );
|
|
||||||
shape->SetFilled( true );
|
|
||||||
shape->SetStroke( STROKE_PARAMS( 0, PLOT_DASH_TYPE::SOLID ) );
|
|
||||||
shape->SetPolyShape( existingOutline );
|
|
||||||
shape->Move( - aPad->GetPosition() );
|
|
||||||
shape->Rotate( VECTOR2I( 0, 0 ), - aPad->GetOrientation() );
|
|
||||||
|
|
||||||
aPad->AddPrimitive( shape );
|
|
||||||
aPad->SetShape( PAD_SHAPE::CUSTOM );
|
|
||||||
aPad->SetOffset( VECTOR2I( 0, 0 ) );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
while( PCB_SHAPE* fpShape = findNext( layer ) )
|
while( PCB_SHAPE* fpShape = findNext( layer ) )
|
||||||
|
@ -936,13 +922,10 @@ std::vector<PCB_SHAPE*> PAD_TOOL::RecombinePad( PAD* aPad, bool aIsDryRun, BOARD
|
||||||
UNIMPLEMENTED_FOR( primitive->SHAPE_T_asString() );
|
UNIMPLEMENTED_FOR( primitive->SHAPE_T_asString() );
|
||||||
}
|
}
|
||||||
|
|
||||||
if( primitive->GetShape() != SHAPE_T::POLY ) // Poly's are board-relative
|
primitive->Move( - aPad->ShapePos() );
|
||||||
{
|
primitive->Rotate( VECTOR2I( 0, 0 ), - aPad->GetOrientation() );
|
||||||
primitive->Move( - aPad->GetPosition() );
|
|
||||||
primitive->Rotate( VECTOR2I( 0, 0 ), - aPad->GetOrientation() );
|
|
||||||
}
|
|
||||||
|
|
||||||
primitive->SetIsAnnotationProxy( fpShape->IsAnnotationProxy());
|
primitive->SetIsAnnotationProxy( fpShape->IsAnnotationProxy() );
|
||||||
aPad->AddPrimitive( primitive );
|
aPad->AddPrimitive( primitive );
|
||||||
|
|
||||||
aCommit.Remove( fpShape );
|
aCommit.Remove( fpShape );
|
||||||
|
|
Loading…
Reference in New Issue